binary-collections 2.0.13 → 2.0.14
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 +307 -238
- package/binaries/clean-nodemodule.cjs +307 -238
- package/binaries/clean-nodemodules.cjs +307 -238
- package/binaries/composer.cjs +323 -0
- package/binaries/composer.cmd +2 -0
- package/binaries/composer.phar +0 -0
- package/binaries/dev.cjs +307 -238
- package/binaries/empty.cjs +307 -238
- package/binaries/git-reduce-size.cjs +307 -238
- package/binaries/javakill.cjs +307 -238
- package/binaries/kill-process.cjs +307 -238
- package/binaries/nodekill.cjs +307 -238
- package/binaries/prod.cjs +307 -238
- package/binaries/py.cjs +307 -238
- package/binaries/rmfind.cjs +307 -238
- package/binaries/rmx.cjs +307 -238
- package/binaries/submodule-token.cjs +307 -238
- package/binaries/test-cjs.cjs +307 -238
- package/binaries/test-esm.cjs +307 -238
- package/binaries/yarn-clean.cjs +307 -238
- package/binaries/yc.cjs +307 -238
- package/binaries/ycw.cjs +307 -238
- package/docs-src/binary-collections.md +1 -1
- package/docs-src/clean-github-actions-caches.md +1 -1
- package/docs-src/copy-move-file.md +1 -4
- package/docs-src/del-ps.md +1 -1
- package/docs-src/find-node-modules.md +1 -1
- package/docs-src/generate-test-ci.md +56 -0
- package/docs-src/get-latest-workflow-status.md +100 -0
- package/docs-src/git-diff.md +1 -1
- package/docs-src/git-fix.md +1 -1
- package/docs-src/git-purge.md +1 -1
- package/docs-src/kill-night-crows.md +1 -1
- package/docs-src/node-cache-cleaner.md +2 -2
- package/docs-src/node-package-packer.md +1 -1
- package/docs-src/opencode-cli.md +127 -0
- package/docs-src/package-resolutions-updater.md +1 -1
- package/docs-src/rmpath.md +1 -1
- package/docs-src/run-by-checksum.md +1 -1
- package/docs-src/submodule-remove.md +1 -1
- package/docs-src/upload-backend.md +29 -0
- package/docs-src/vscode-cli.md +84 -0
- package/docs-src/workflow-badge.md +120 -0
- package/lib/binary-collections/config.cjs +14 -2
- package/lib/binary-collections/config.d.cts +10 -0
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +43 -21
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +43 -21
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +43 -21
- package/lib/binary-collections.mjs +6 -6
- package/lib/chunk-2SJKVOTN.mjs +146 -0
- package/lib/{chunk-2MN4VPV2.mjs → chunk-3F6EIHYG.mjs} +2 -2
- package/lib/chunk-546KAIYT.mjs +113 -0
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-5WAOOOGZ.mjs +77 -0
- package/lib/chunk-72XTQ3CK.mjs +45 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-7Q6YEUQF.mjs +246 -0
- package/lib/{chunk-NQXUYO67.mjs → chunk-AJ3OIYYP.mjs} +43 -21
- package/lib/chunk-AQZ7LMFS.mjs +100 -0
- package/lib/chunk-BDCMTOZI.mjs +246 -0
- package/lib/chunk-BEUM4LH4.mjs +184 -0
- package/lib/{chunk-TBWXE7ST.mjs → chunk-BO4TZS4Q.mjs} +5 -2
- package/lib/chunk-CM3IC5YC.mjs +226 -0
- package/lib/{chunk-FLYSZFLW.mjs → chunk-D42YBRZW.mjs} +1 -1
- package/lib/chunk-FR3DMHJC.mjs +146 -0
- package/lib/chunk-I3O5ZRYU.mjs +77 -0
- package/lib/chunk-J4M5EL5P.mjs +108 -0
- package/lib/chunk-JK3MG2KF.mjs +236 -0
- package/lib/chunk-JMUFQSPE.mjs +184 -0
- package/lib/chunk-JVMLKHD2.mjs +62 -0
- package/lib/chunk-KAT2JNLZ.mjs +146 -0
- package/lib/{chunk-CD3HF3LK.mjs → chunk-KRCPFWIF.mjs} +6 -3
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/chunk-MCCMMZSM.mjs +60 -0
- package/lib/chunk-OA2RKEY3.mjs +162 -0
- package/lib/{chunk-X2B3X7D4.mjs → chunk-PAZH45HS.mjs} +7 -1
- package/lib/chunk-QZMGBDSA.mjs +32 -0
- package/lib/chunk-RKPIBGKE.mjs +61 -0
- package/lib/chunk-SARIXFHP.mjs +44 -0
- package/lib/chunk-SJYP66BO.mjs +62 -0
- package/lib/chunk-SWUAEY4H.mjs +44 -0
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/chunk-UAIF5VIA.mjs +89 -0
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-UHPFLJXH.mjs +227 -0
- package/lib/chunk-UYNBNLV5.mjs +113 -0
- package/lib/chunk-WOC4FZ6F.mjs +164 -0
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/{chunk-RDN6HF5Z.mjs → chunk-XI67TI46.mjs} +1 -1
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/chunk-YLV4QATP.mjs +86 -0
- package/lib/chunk-YWSLMAQ7.mjs +65 -0
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- package/lib/cross-env/index.mjs +3 -3
- package/lib/del-gradle.cjs +1 -1
- package/lib/del-gradle.mjs +22 -16
- package/lib/del-node-modules.cjs +1 -1
- package/lib/del-node-modules.mjs +148 -142
- package/lib/find-node-modules-cli.cjs +1 -1
- package/lib/find-node-modules-cli.mjs +10 -4
- package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +18 -6
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +16 -4
- package/lib/{git-diff.js → git/git-diff.js} +3 -3
- package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
- package/lib/{git-fix.cjs → git/git-fix.cjs} +134 -3
- package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
- package/lib/{git-purge.cjs → git/git-purge.cjs} +1 -1
- package/lib/{git-purge.mjs → git/git-purge.mjs} +4 -4
- package/lib/git/user-config.cjs +131 -1
- package/lib/git/user-config.mjs +3 -1
- package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +38 -10
- package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +7 -6
- package/lib/{clean-github-actions-caches.cjs → github-workflows/clean-github-actions-caches.cjs} +38 -10
- package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -4
- package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
- package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
- package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
- package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
- package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
- package/lib/github-workflows/get-latest-workflow-status.mjs +8 -0
- package/lib/github-workflows/utils.cjs +271 -0
- package/lib/github-workflows/utils.d.cts +76 -0
- package/lib/github-workflows/utils.mjs +8 -0
- package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
- package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
- package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
- package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
- package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
- package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
- package/lib/github-workflows/workflow-test-data.cjs +73 -0
- package/lib/github-workflows/workflow-test-data.d.cts +63 -0
- package/lib/github-workflows/workflow-test-data.mjs +6 -0
- package/lib/opencode/cli/auth-rotate.cjs +143 -0
- package/lib/opencode/cli/auth-rotate.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.js +70 -0
- package/lib/opencode/cli/auth-rotate.mjs +10 -0
- package/lib/opencode/cli/list-projects.cjs +184 -0
- package/lib/opencode/cli/list-projects.d.ts +1 -0
- package/lib/opencode/cli/list-projects.js +32 -0
- package/lib/opencode/cli/list-projects.mjs +11 -0
- package/lib/opencode/cli/list-sessions.cjs +215 -0
- package/lib/opencode/cli/list-sessions.d.ts +1 -0
- package/lib/opencode/cli/list-sessions.js +45 -0
- package/lib/opencode/cli/list-sessions.mjs +11 -0
- package/lib/opencode/database.cjs +349 -0
- package/lib/opencode/database.d.ts +91 -0
- package/lib/opencode/database.js +252 -0
- package/lib/opencode/database.mjs +28 -0
- package/lib/opencode/database.runner.cjs +145 -0
- package/lib/opencode/database.runner.d.ts +1 -0
- package/lib/opencode/database.runner.js +56 -0
- package/lib/opencode/database.runner.mjs +37 -0
- package/lib/opencode/opencode-zen.runner.cjs +48 -0
- package/lib/opencode/opencode-zen.runner.d.mts +1 -0
- package/lib/opencode/opencode-zen.runner.mjs +31 -0
- package/lib/opencode/sqlite.cjs +114 -0
- package/lib/opencode/sqlite.d.ts +18 -0
- package/lib/opencode/sqlite.js +82 -0
- package/lib/opencode/sqlite.mjs +10 -0
- package/lib/opencode/storage.cjs +124 -0
- package/lib/opencode/storage.d.ts +27 -0
- package/lib/opencode/storage.js +101 -0
- package/lib/opencode/storage.mjs +38 -0
- package/lib/opencode/storage.runner.cjs +50 -0
- package/lib/opencode/storage.runner.d.ts +1 -0
- package/lib/opencode/storage.runner.js +13 -0
- package/lib/opencode/storage.runner.mjs +29 -0
- package/lib/opencode/types.cjs +17 -0
- package/lib/opencode/types.d.ts +31 -0
- package/lib/opencode/types.js +2 -0
- package/lib/opencode/types.mjs +7 -0
- package/lib/opencode/utils/check-api.cjs +59 -0
- package/lib/opencode/utils/check-api.d.ts +12 -0
- package/lib/opencode/utils/check-api.js +46 -0
- package/lib/opencode/utils/check-api.mjs +8 -0
- package/lib/opencode-cli.cjs +473 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +115 -0
- package/lib/opencode-cli.mjs +111 -0
- package/lib/package-resolutions-updater-cli.cjs +181 -154
- package/lib/package-resolutions-updater-cli.mjs +3 -2
- package/lib/package-resolutions-updater.cjs +181 -154
- package/lib/package-resolutions-updater.d.mts +12 -3
- package/lib/package-resolutions-updater.mjs +3 -2
- package/lib/print-directory-tree.cjs +131 -3
- package/lib/print-directory-tree.mjs +6 -3
- package/lib/rmpath-cli.cjs +131 -5
- package/lib/rmpath-cli.mjs +3 -1
- package/lib/rmpath.cjs +147 -11
- package/lib/rmpath.mjs +3 -1
- package/lib/run-by-checksum/hash.cjs +18 -2
- package/lib/run-by-checksum/hash.d.ts +4 -1
- package/lib/run-by-checksum/hash.js +38 -4
- package/lib/run-by-checksum/hash.mjs +1 -1
- package/lib/run-by-checksum/run.cjs +18 -2
- package/lib/run-by-checksum/run.mjs +2 -2
- package/lib/run-by-checksum-cli.cjs +18 -2
- package/lib/run-by-checksum-cli.mjs +2 -2
- package/lib/submodule-install.cjs +130 -4
- package/lib/submodule-install.mjs +5 -4
- package/lib/submodule-remove-cli.cjs +131 -5
- package/lib/submodule-remove-cli.mjs +3 -1
- package/lib/submodule-remove.cjs +146 -5
- package/lib/submodule-remove.mjs +3 -1
- package/lib/utils/findEnvFiles.cjs +3 -0
- package/lib/utils/findEnvFiles.d.cts +2 -2
- package/lib/utils/findEnvFiles.mjs +1 -1
- package/lib/vscode/project.cjs +0 -0
- package/lib/vscode/project.d.ts +0 -0
- package/lib/vscode/project.js +1 -0
- package/lib/vscode/project.mjs +7 -0
- package/lib/vscode/storage.cjs +138 -0
- package/lib/vscode/storage.d.ts +51 -0
- package/lib/vscode/storage.js +169 -0
- package/lib/vscode/storage.mjs +42 -0
- package/lib/vscode/storage.runner.cjs +125 -0
- package/lib/vscode/storage.runner.d.ts +1 -0
- package/lib/vscode/storage.runner.js +47 -0
- package/lib/vscode/storage.runner.mjs +60 -0
- package/lib/vscode-cli.cjs +155 -0
- package/lib/vscode-cli.d.ts +2 -0
- package/lib/vscode-cli.js +80 -0
- package/lib/vscode-cli.mjs +71 -0
- package/package.json +43 -21
- package/readme.md +41 -8
- package/releases/readme.md +1 -1
- package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
- package/vendor/clue/ndjson-react/README.md +365 -0
- package/vendor/composer/pcre/README.md +189 -0
- package/vendor/composer/semver/README.md +99 -0
- package/vendor/composer/xdebug-handler/README.md +305 -0
- package/vendor/ergebnis/agent-detector/README.md +107 -0
- package/vendor/evenement/evenement/README.md +64 -0
- package/vendor/fidry/cpu-core-counter/README.md +138 -0
- package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
- package/vendor/psr/container/README.md +13 -0
- package/vendor/psr/event-dispatcher/README.md +6 -0
- package/vendor/psr/log/README.md +58 -0
- package/vendor/react/cache/README.md +367 -0
- package/vendor/react/child-process/README.md +619 -0
- package/vendor/react/dns/README.md +453 -0
- package/vendor/react/event-loop/README.md +930 -0
- package/vendor/react/promise/README.md +722 -0
- package/vendor/react/socket/README.md +1564 -0
- package/vendor/react/stream/README.md +1249 -0
- package/vendor/sebastian/diff/README.md +151 -0
- package/vendor/symfony/console/README.md +30 -0
- package/vendor/symfony/deprecation-contracts/README.md +26 -0
- package/vendor/symfony/event-dispatcher/README.md +25 -0
- package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
- package/vendor/symfony/filesystem/README.md +23 -0
- package/vendor/symfony/finder/README.md +24 -0
- package/vendor/symfony/options-resolver/README.md +25 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
- package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php81/README.md +18 -0
- package/vendor/symfony/polyfill-php84/README.md +23 -0
- package/vendor/symfony/polyfill-php85/README.md +20 -0
- package/vendor/symfony/process/README.md +23 -0
- package/vendor/symfony/service-contracts/README.md +9 -0
- package/vendor/symfony/stopwatch/README.md +52 -0
- package/vendor/symfony/string/README.md +24 -0
- package/lib/del-gradle.js +0 -16
- package/lib/del-node-modules.js +0 -211
- package/lib/find-node-modules-cli.js +0 -4
- /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
- /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
- /package/lib/{find-node-modules-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
- /package/lib/{git-diff-cli.d.ts → git/git-diff-cli.d.ts} +0 -0
- /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
- /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
- /package/lib/{git-fix.d.cts → git/git-fix.d.cts} +0 -0
- /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
- /package/lib/{del-node-modules.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
- /package/lib/{clean-github-actions-caches.d.cts → github-workflows/clean-github-actions-caches.d.cts} +0 -0
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_config
|
|
4
|
+
} from "./chunk-SWUAEY4H.mjs";
|
|
5
|
+
import {
|
|
6
|
+
__commonJS,
|
|
7
|
+
__require,
|
|
8
|
+
init_esm_shims
|
|
9
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
10
|
+
|
|
11
|
+
// src/github-workflows/utils.cjs
|
|
12
|
+
var require_utils = __commonJS({
|
|
13
|
+
"src/github-workflows/utils.cjs"(exports, module) {
|
|
14
|
+
init_esm_shims();
|
|
15
|
+
var axios = __require("axios");
|
|
16
|
+
var { spawn } = __require("cross-spawn");
|
|
17
|
+
var { GITHUB_ACCESS_TOKEN: TOKEN } = require_config();
|
|
18
|
+
if (!TOKEN) {
|
|
19
|
+
console.error("Missing env var: ACCESS_TOKEN or GITHUB_TOKEN");
|
|
20
|
+
process.exit(1);
|
|
21
|
+
}
|
|
22
|
+
var BASE = "https://api.github.com";
|
|
23
|
+
var HEADERS = {
|
|
24
|
+
Authorization: `Bearer ${TOKEN}`,
|
|
25
|
+
Accept: "application/vnd.github+json",
|
|
26
|
+
"X-GitHub-Api-Version": "2022-11-28"
|
|
27
|
+
};
|
|
28
|
+
async function request(url) {
|
|
29
|
+
try {
|
|
30
|
+
const res = await axios.get(url, { headers: HEADERS });
|
|
31
|
+
return res.data;
|
|
32
|
+
} catch (err) {
|
|
33
|
+
if (err == null ? void 0 : err.response) {
|
|
34
|
+
const statusText = err.response.statusText || "Request failed";
|
|
35
|
+
const responseText = typeof err.response.data === "string" ? err.response.data : JSON.stringify(err.response.data);
|
|
36
|
+
throw new Error(`${err.response.status} ${statusText}
|
|
37
|
+
${responseText}`);
|
|
38
|
+
}
|
|
39
|
+
throw err;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
function runGit(args) {
|
|
43
|
+
return new Promise((resolve, reject) => {
|
|
44
|
+
var _a, _b;
|
|
45
|
+
const child = spawn("git", args, {
|
|
46
|
+
cwd: process.cwd(),
|
|
47
|
+
stdio: ["ignore", "pipe", "pipe"]
|
|
48
|
+
});
|
|
49
|
+
let stdout = "";
|
|
50
|
+
let stderr = "";
|
|
51
|
+
(_a = child.stdout) == null ? void 0 : _a.on("data", (chunk) => {
|
|
52
|
+
stdout += chunk.toString();
|
|
53
|
+
});
|
|
54
|
+
(_b = child.stderr) == null ? void 0 : _b.on("data", (chunk) => {
|
|
55
|
+
stderr += chunk.toString();
|
|
56
|
+
});
|
|
57
|
+
child.on("error", reject);
|
|
58
|
+
child.on("close", (code) => {
|
|
59
|
+
if (code === 0) return resolve(stdout.trim());
|
|
60
|
+
reject(new Error(stderr.trim() || `git ${args.join(" ")} exited with code ${code}`));
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
function parseOwnerFromUrl(remoteUrl) {
|
|
65
|
+
const normalized = remoteUrl.trim().replace(/\.git$/i, "");
|
|
66
|
+
const match = normalized.match(/github\.com[:/](?<owner>[^/]+)\/(?<repo>[^/]+)$/i);
|
|
67
|
+
return (match == null ? void 0 : match.groups) || null;
|
|
68
|
+
}
|
|
69
|
+
function getOwnerFromRemoteUrl(remoteUrl) {
|
|
70
|
+
const parsed = parseOwnerFromUrl(remoteUrl);
|
|
71
|
+
return (parsed == null ? void 0 : parsed.owner) || null;
|
|
72
|
+
}
|
|
73
|
+
function getRepoFromRemoteUrl(remoteUrl) {
|
|
74
|
+
const parsed = parseOwnerFromUrl(remoteUrl);
|
|
75
|
+
return (parsed == null ? void 0 : parsed.repo) || null;
|
|
76
|
+
}
|
|
77
|
+
async function getCurrentOwner() {
|
|
78
|
+
const commands = [
|
|
79
|
+
["config", "--local", "--get", "remote.origin.url"],
|
|
80
|
+
["remote", "get-url", "origin"]
|
|
81
|
+
];
|
|
82
|
+
for (const args of commands) {
|
|
83
|
+
try {
|
|
84
|
+
const remoteUrl = await runGit(args);
|
|
85
|
+
const owner = getOwnerFromRemoteUrl(remoteUrl);
|
|
86
|
+
if (owner) return owner;
|
|
87
|
+
} catch {
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
throw new Error("Unable to determine repository owner from git remote.origin.url");
|
|
91
|
+
}
|
|
92
|
+
async function getCurrentRepo() {
|
|
93
|
+
const commands = [
|
|
94
|
+
["config", "--local", "--get", "remote.origin.url"],
|
|
95
|
+
["remote", "get-url", "origin"]
|
|
96
|
+
];
|
|
97
|
+
for (const args of commands) {
|
|
98
|
+
try {
|
|
99
|
+
const remoteUrl = await runGit(args);
|
|
100
|
+
const repo = getRepoFromRemoteUrl(remoteUrl);
|
|
101
|
+
if (repo) return repo;
|
|
102
|
+
} catch {
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
throw new Error("Unable to determine repository name from git remote.origin.url");
|
|
106
|
+
}
|
|
107
|
+
async function getOwnerRepo() {
|
|
108
|
+
const owner = await getCurrentOwner();
|
|
109
|
+
const repo = await getCurrentRepo();
|
|
110
|
+
return { owner, repo };
|
|
111
|
+
}
|
|
112
|
+
async function getLatestRun(owner, repo, workflowId) {
|
|
113
|
+
var _a;
|
|
114
|
+
let url;
|
|
115
|
+
if (workflowId) {
|
|
116
|
+
url = `${BASE}/repos/${owner}/${repo}/actions/workflows/${encodeURIComponent(workflowId)}/runs?per_page=1`;
|
|
117
|
+
} else {
|
|
118
|
+
url = `${BASE}/repos/${owner}/${repo}/actions/runs?per_page=1`;
|
|
119
|
+
}
|
|
120
|
+
const data = await request(url);
|
|
121
|
+
return (_a = data.workflow_runs) == null ? void 0 : _a[0];
|
|
122
|
+
}
|
|
123
|
+
async function getJobs(owner, repo, runId) {
|
|
124
|
+
const data = await request(`${BASE}/repos/${owner}/${repo}/actions/runs/${runId}/jobs`);
|
|
125
|
+
return data.jobs || [];
|
|
126
|
+
}
|
|
127
|
+
module.exports = {
|
|
128
|
+
BASE,
|
|
129
|
+
HEADERS,
|
|
130
|
+
request,
|
|
131
|
+
runGit,
|
|
132
|
+
parseOwnerFromUrl,
|
|
133
|
+
getOwnerFromRemoteUrl,
|
|
134
|
+
getRepoFromRemoteUrl,
|
|
135
|
+
getCurrentOwner,
|
|
136
|
+
getCurrentRepo,
|
|
137
|
+
getOwnerRepo,
|
|
138
|
+
getLatestRun,
|
|
139
|
+
getJobs
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
export {
|
|
145
|
+
require_utils
|
|
146
|
+
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_config
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-SARIXFHP.mjs";
|
|
5
5
|
import {
|
|
6
6
|
runChatGpt
|
|
7
7
|
} from "./chunk-GAGABICI.mjs";
|
|
@@ -13,7 +13,7 @@ import {
|
|
|
13
13
|
init_esm_shims
|
|
14
14
|
} from "./chunk-QQ4A6DLD.mjs";
|
|
15
15
|
|
|
16
|
-
// src/git-diff.js
|
|
16
|
+
// src/git/git-diff.js
|
|
17
17
|
init_esm_shims();
|
|
18
18
|
var import_config = __toESM(require_config(), 1);
|
|
19
19
|
import ansiColors from "ansi-colors";
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_utils as require_utils2
|
|
4
|
+
} from "./chunk-A3VUZEJK.mjs";
|
|
5
|
+
import {
|
|
6
|
+
require_config
|
|
7
|
+
} from "./chunk-SARIXFHP.mjs";
|
|
8
|
+
import {
|
|
9
|
+
require_utils
|
|
10
|
+
} from "./chunk-6RK5UCTP.mjs";
|
|
11
|
+
import {
|
|
12
|
+
__commonJS,
|
|
13
|
+
__require,
|
|
14
|
+
init_esm_shims
|
|
15
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
16
|
+
|
|
17
|
+
// src/git/user-config.cjs
|
|
18
|
+
var require_user_config = __commonJS({
|
|
19
|
+
"src/git/user-config.cjs"(exports, module) {
|
|
20
|
+
init_esm_shims();
|
|
21
|
+
var { loadDotenv } = require_config();
|
|
22
|
+
var gch = __require("git-command-helper");
|
|
23
|
+
var { runGitCommand, runGitCommandOutput } = require_utils2();
|
|
24
|
+
var { getArgs } = require_utils();
|
|
25
|
+
loadDotenv();
|
|
26
|
+
function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
|
|
27
|
+
console.log("\n=== Configuring Git User ===");
|
|
28
|
+
let username, email;
|
|
29
|
+
if (cliUser && cliEmail) {
|
|
30
|
+
username = cliUser.trim();
|
|
31
|
+
email = cliEmail.trim();
|
|
32
|
+
console.log("[i] Using CLI-provided user configuration");
|
|
33
|
+
} else {
|
|
34
|
+
username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : void 0;
|
|
35
|
+
email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : void 0;
|
|
36
|
+
if (username || email) {
|
|
37
|
+
console.log("[i] Using environment variable user configuration");
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
if (!username && !email) {
|
|
41
|
+
console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (username) {
|
|
45
|
+
const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
|
|
46
|
+
if (!success) {
|
|
47
|
+
console.log("[i] Failed to set Git username, but continuing...");
|
|
48
|
+
}
|
|
49
|
+
} else {
|
|
50
|
+
console.log("[i] No username provided, skipping username configuration");
|
|
51
|
+
}
|
|
52
|
+
if (email) {
|
|
53
|
+
const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
|
|
54
|
+
if (!success) {
|
|
55
|
+
console.log("[i] Failed to set Git email, but continuing...");
|
|
56
|
+
}
|
|
57
|
+
} else {
|
|
58
|
+
console.log("[i] No email provided, skipping email configuration");
|
|
59
|
+
}
|
|
60
|
+
if (username || email) {
|
|
61
|
+
console.log("[\u2713] Git user configuration completed");
|
|
62
|
+
}
|
|
63
|
+
if (username) {
|
|
64
|
+
const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
|
|
65
|
+
if (remoteUrl) {
|
|
66
|
+
console.log(`[i] Remote URL: ${remoteUrl}`);
|
|
67
|
+
const parsedUrl = gch.parseGitHubUrl(remoteUrl);
|
|
68
|
+
if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
|
|
69
|
+
console.warn(
|
|
70
|
+
`
|
|
71
|
+
[!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`
|
|
72
|
+
);
|
|
73
|
+
console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
|
|
74
|
+
console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git
|
|
75
|
+
`);
|
|
76
|
+
const args = getArgs();
|
|
77
|
+
const updateRemote = options.updateRemote || args["update-remote"] === true;
|
|
78
|
+
if (updateRemote) {
|
|
79
|
+
let newUrl = remoteUrl;
|
|
80
|
+
if (/^https:\/\//.test(remoteUrl)) {
|
|
81
|
+
newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
|
|
82
|
+
} else if (/^git@github.com:/.test(remoteUrl)) {
|
|
83
|
+
console.warn(
|
|
84
|
+
`[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`
|
|
85
|
+
);
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
if (newUrl !== remoteUrl) {
|
|
89
|
+
const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
|
|
90
|
+
if (updated) {
|
|
91
|
+
console.log(`[\u2713] Remote URL updated to: ${newUrl}`);
|
|
92
|
+
} else {
|
|
93
|
+
console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
|
|
94
|
+
}
|
|
95
|
+
} else {
|
|
96
|
+
console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
|
|
97
|
+
}
|
|
98
|
+
} else {
|
|
99
|
+
console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
module.exports = {
|
|
106
|
+
configureGitUser
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
export {
|
|
112
|
+
require_user_config
|
|
113
|
+
};
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
init_esm_shims
|
|
4
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
5
|
+
|
|
6
|
+
// src/opencode/sqlite.ts
|
|
7
|
+
init_esm_shims();
|
|
8
|
+
import Database from "better-sqlite3";
|
|
9
|
+
import fs from "fs-extra";
|
|
10
|
+
import path from "upath";
|
|
11
|
+
var DEFAULT_DB_PATH = path.join(process.cwd(), "data", "database", "db.sqlite");
|
|
12
|
+
var SQLite = class {
|
|
13
|
+
constructor(dbPath = DEFAULT_DB_PATH) {
|
|
14
|
+
const dir = path.dirname(dbPath);
|
|
15
|
+
if (!fs.existsSync(dir)) {
|
|
16
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
17
|
+
}
|
|
18
|
+
this.db = new Database(dbPath);
|
|
19
|
+
this.db.pragma("journal_mode = WAL");
|
|
20
|
+
this.db.pragma("synchronous = NORMAL");
|
|
21
|
+
this.db.pragma("temp_store = MEMORY");
|
|
22
|
+
this.db.pragma("foreign_keys = ON");
|
|
23
|
+
}
|
|
24
|
+
// -------------------------
|
|
25
|
+
// Migration / schema init
|
|
26
|
+
// -------------------------
|
|
27
|
+
migrate(schemaFilePath) {
|
|
28
|
+
const schema = fs.readFileSync(schemaFilePath, "utf-8");
|
|
29
|
+
this.db.exec(schema);
|
|
30
|
+
}
|
|
31
|
+
// -------------------------
|
|
32
|
+
// Core query helpers
|
|
33
|
+
// -------------------------
|
|
34
|
+
prepare(sql) {
|
|
35
|
+
return this.db.prepare(sql);
|
|
36
|
+
}
|
|
37
|
+
get(sql, params = {}) {
|
|
38
|
+
return this.db.prepare(sql).get(params);
|
|
39
|
+
}
|
|
40
|
+
all(sql, params = {}) {
|
|
41
|
+
return this.db.prepare(sql).all(params);
|
|
42
|
+
}
|
|
43
|
+
run(sql, params = {}) {
|
|
44
|
+
return this.db.prepare(sql).run(params);
|
|
45
|
+
}
|
|
46
|
+
// -------------------------
|
|
47
|
+
// Transactions
|
|
48
|
+
// -------------------------
|
|
49
|
+
transaction(fn) {
|
|
50
|
+
const trx = this.db.transaction(fn);
|
|
51
|
+
return trx();
|
|
52
|
+
}
|
|
53
|
+
// -------------------------
|
|
54
|
+
// Upsert helper (very useful for build cache)
|
|
55
|
+
// -------------------------
|
|
56
|
+
upsert(sql, params = {}) {
|
|
57
|
+
return this.db.prepare(sql).run(params);
|
|
58
|
+
}
|
|
59
|
+
// -------------------------
|
|
60
|
+
// Bulk insert helper
|
|
61
|
+
// -------------------------
|
|
62
|
+
insertMany(sql, rows) {
|
|
63
|
+
const stmt = this.db.prepare(sql);
|
|
64
|
+
const trx = this.db.transaction((rows2) => {
|
|
65
|
+
for (const row of rows2) {
|
|
66
|
+
stmt.run(row);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
trx(rows);
|
|
70
|
+
}
|
|
71
|
+
// -------------------------
|
|
72
|
+
// Utility
|
|
73
|
+
// -------------------------
|
|
74
|
+
close() {
|
|
75
|
+
this.db.close();
|
|
76
|
+
}
|
|
77
|
+
// Raw access if needed (escape hatch)
|
|
78
|
+
raw() {
|
|
79
|
+
return this.db;
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
export {
|
|
84
|
+
DEFAULT_DB_PATH,
|
|
85
|
+
SQLite
|
|
86
|
+
};
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_config
|
|
4
|
+
} from "./chunk-SWUAEY4H.mjs";
|
|
5
|
+
import {
|
|
6
|
+
__toESM,
|
|
7
|
+
init_esm_shims
|
|
8
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
9
|
+
|
|
10
|
+
// src/rmpath.mjs
|
|
11
|
+
init_esm_shims();
|
|
12
|
+
var import_config = __toESM(require_config(), 1);
|
|
13
|
+
import fs from "fs-extra";
|
|
14
|
+
import * as glob from "glob";
|
|
15
|
+
import path from "upath";
|
|
16
|
+
import { fileURLToPath } from "url";
|
|
17
|
+
var __filename = fileURLToPath(import.meta.url);
|
|
18
|
+
var __dirname = path.dirname(__filename);
|
|
19
|
+
(0, import_config.loadDotenv)();
|
|
20
|
+
var deletePatterns = [];
|
|
21
|
+
function resolveDeletePatterns(targetPath) {
|
|
22
|
+
if (fs.existsSync(targetPath) && fs.lstatSync(targetPath).isFile()) {
|
|
23
|
+
deletePatterns.push(targetPath);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const vowels = ["a", "i", "u", "e", "o", "A", "I", "U", "E", "O"];
|
|
27
|
+
const letters = [];
|
|
28
|
+
for (let i = 97; i <= 122; i++) letters.push(String.fromCharCode(i));
|
|
29
|
+
for (let i = 65; i <= 90; i++) letters.push(String.fromCharCode(i));
|
|
30
|
+
for (const letter of letters) {
|
|
31
|
+
for (const vowel of vowels) {
|
|
32
|
+
deletePatterns.push(
|
|
33
|
+
`.${letter}*`,
|
|
34
|
+
`@${letter}*`,
|
|
35
|
+
`${letter}*`,
|
|
36
|
+
`@${letter}${vowel}*`,
|
|
37
|
+
`.${letter}${vowel}*`,
|
|
38
|
+
`${letter}${vowel}*`
|
|
39
|
+
);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
async function deleteMatchingFiles(baseDir) {
|
|
44
|
+
for (const pattern of deletePatterns) {
|
|
45
|
+
if (fs.existsSync(pattern)) {
|
|
46
|
+
fs.rmSync(pattern, { recursive: true, force: true });
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
const matches = glob.sync(path.join(baseDir, pattern), { dot: true, nocase: true });
|
|
50
|
+
for (const fpath of matches) {
|
|
51
|
+
try {
|
|
52
|
+
console.log(`deleting ${fpath}`);
|
|
53
|
+
fs.rmSync(fpath, { recursive: true, force: true });
|
|
54
|
+
} catch (_e) {
|
|
55
|
+
console.error(`cannot delete ${fpath}`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async function deleteMainScript(targetPath) {
|
|
61
|
+
if (!fs.existsSync(targetPath)) {
|
|
62
|
+
targetPath = path.resolve(process.cwd(), targetPath);
|
|
63
|
+
}
|
|
64
|
+
resolveDeletePatterns(targetPath);
|
|
65
|
+
await deleteMatchingFiles(targetPath);
|
|
66
|
+
console.log(`cleaning ${targetPath}`);
|
|
67
|
+
try {
|
|
68
|
+
fs.rmSync(targetPath, { recursive: true, force: true });
|
|
69
|
+
} catch (_e) {
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export {
|
|
74
|
+
resolveDeletePatterns,
|
|
75
|
+
deleteMatchingFiles,
|
|
76
|
+
deleteMainScript
|
|
77
|
+
};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_utils
|
|
4
|
+
} from "./chunk-FR3DMHJC.mjs";
|
|
5
|
+
import {
|
|
6
|
+
__toESM,
|
|
7
|
+
init_esm_shims
|
|
8
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
9
|
+
|
|
10
|
+
// src/github-workflows/get-latest-workflow-status.mjs
|
|
11
|
+
init_esm_shims();
|
|
12
|
+
var import_utils = __toESM(require_utils(), 1);
|
|
13
|
+
function printReport(run, jobs) {
|
|
14
|
+
var _a;
|
|
15
|
+
console.log("\n==============================");
|
|
16
|
+
console.log("\u{1F680} Latest Workflow Run");
|
|
17
|
+
console.log("==============================");
|
|
18
|
+
console.log(`Name : ${run.name}`);
|
|
19
|
+
console.log(`Status : ${run.status}`);
|
|
20
|
+
console.log(`Conclusion: ${run.conclusion}`);
|
|
21
|
+
console.log(`Branch : ${run.head_branch}`);
|
|
22
|
+
console.log(`Run ID : ${run.id}`);
|
|
23
|
+
console.log(`URL : ${run.html_url}`);
|
|
24
|
+
console.log("\n==============================");
|
|
25
|
+
console.log("\u{1F9E9} Jobs & Steps");
|
|
26
|
+
console.log("==============================\n");
|
|
27
|
+
for (const job of jobs) {
|
|
28
|
+
console.log(`\u{1F9F1} Job: ${job.name}`);
|
|
29
|
+
console.log(` Status: ${job.status} | Conclusion: ${job.conclusion}`);
|
|
30
|
+
if (!((_a = job.steps) == null ? void 0 : _a.length)) {
|
|
31
|
+
console.log(" (no steps found)\n");
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
for (const step of job.steps) {
|
|
35
|
+
const icon = step.conclusion === "success" ? "\u2705" : step.conclusion === "failure" ? "\u274C" : step.conclusion === "skipped" ? "\u23ED\uFE0F" : "\u26AA";
|
|
36
|
+
console.log(` ${icon} ${step.name} -> ${step.conclusion} (${step.status})`);
|
|
37
|
+
}
|
|
38
|
+
console.log("");
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export {
|
|
43
|
+
import_utils,
|
|
44
|
+
printReport
|
|
45
|
+
};
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
init_esm_shims
|
|
4
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
5
|
+
|
|
6
|
+
// src/github-workflows/get-latest-workflow-status.mjs
|
|
7
|
+
init_esm_shims();
|
|
8
|
+
function printReport(run, jobs) {
|
|
9
|
+
var _a;
|
|
10
|
+
console.log("\n==============================");
|
|
11
|
+
console.log("\u{1F680} Latest Workflow Run");
|
|
12
|
+
console.log("==============================");
|
|
13
|
+
console.log(`Name : ${run.name}`);
|
|
14
|
+
console.log(`Status : ${run.status}`);
|
|
15
|
+
console.log(`Conclusion: ${run.conclusion}`);
|
|
16
|
+
console.log(`Branch : ${run.head_branch}`);
|
|
17
|
+
console.log(`Run ID : ${run.id}`);
|
|
18
|
+
console.log(`URL : ${run.html_url}`);
|
|
19
|
+
console.log("\n==============================");
|
|
20
|
+
console.log("\u{1F9E9} Jobs & Steps");
|
|
21
|
+
console.log("==============================\n");
|
|
22
|
+
for (const job of jobs) {
|
|
23
|
+
console.log(`\u{1F9F1} Job: ${job.name}`);
|
|
24
|
+
console.log(` Status: ${job.status} | Conclusion: ${job.conclusion}`);
|
|
25
|
+
if (!((_a = job.steps) == null ? void 0 : _a.length)) {
|
|
26
|
+
console.log(" (no steps found)\n");
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
for (const step of job.steps) {
|
|
30
|
+
const icon = step.conclusion === "success" ? "\u2705" : step.conclusion === "failure" ? "\u274C" : step.conclusion === "skipped" ? "\u23ED\uFE0F" : "\u26AA";
|
|
31
|
+
console.log(` ${icon} ${step.name} -> ${step.conclusion} (${step.status})`);
|
|
32
|
+
}
|
|
33
|
+
console.log("");
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export {
|
|
38
|
+
printReport
|
|
39
|
+
};
|