binary-collections 2.0.13 → 2.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.opencode/plugins/opencode-request-logger/README.md +44 -0
- package/.venv/Lib/site-packages/pyarrow/tests/data/orc/README.md +22 -0
- 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/install-opencode-plugins.md +86 -0
- 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 +155 -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-types.cjs +17 -0
- package/lib/binary-collections/config-types.d.ts +12 -0
- package/lib/binary-collections/config-types.js +2 -0
- package/lib/binary-collections/config-types.mjs +7 -0
- package/lib/binary-collections/config.cjs +28 -8
- package/lib/binary-collections/config.d.cts +26 -8
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +49 -25
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +49 -25
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +49 -25
- package/lib/binary-collections.mjs +6 -6
- package/lib/changelog.cjs +142 -4
- package/lib/changelog.mjs +9 -5
- package/lib/chunk-3T6AMFI3.mjs +52 -0
- package/lib/{chunk-2MN4VPV2.mjs → chunk-3ZF2QMDK.mjs} +4 -4
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-B77D3SR4.mjs +28 -0
- package/lib/chunk-BPED62FN.mjs +115 -0
- package/lib/{chunk-RDN6HF5Z.mjs → chunk-DHFRWM2W.mjs} +1 -1
- package/lib/chunk-DPEE3FBB.mjs +146 -0
- package/lib/{chunk-MGPYPKIE.mjs → chunk-H7AE4IO3.mjs} +5 -1
- package/lib/{chunk-H44UWUFY.mjs → chunk-J4M5EL5P.mjs} +3 -0
- package/lib/chunk-KCJYREA2.mjs +67 -0
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/{chunk-TBWXE7ST.mjs → chunk-NHD4HLSU.mjs} +24 -31
- package/lib/{chunk-RDGDLSPD.mjs → chunk-OWNVMKAA.mjs} +6 -5
- package/lib/chunk-SKVF4TMD.mjs +59 -0
- package/lib/{chunk-BZWVHODJ.mjs → chunk-TDUUOAQD.mjs} +5 -5
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/{chunk-FLYSZFLW.mjs → chunk-UAEKSLAX.mjs} +1 -1
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-V6PTSDW5.mjs +82 -0
- package/lib/{chunk-NQXUYO67.mjs → chunk-WNUEY6VJ.mjs} +49 -25
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/{chunk-LVSPEFU2.mjs → chunk-Z53IUBUN.mjs} +6 -5
- package/lib/{chunk-CD3HF3LK.mjs → chunk-Z7RM46Q4.mjs} +5 -11
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- 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} +32 -12
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +30 -10
- 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} +142 -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 +139 -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} +46 -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} +46 -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 +549 -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 +279 -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 +730 -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/node-cache-cleaner-cli.mjs +3 -3
- package/lib/opencode/cli/auth-rotate.cjs +458 -0
- package/lib/opencode/cli/auth-rotate.d.ts +3 -0
- package/lib/opencode/cli/auth-rotate.js +65 -0
- package/lib/opencode/cli/auth-rotate.mjs +14 -0
- package/lib/opencode/cli/auth-rotate.runner.cjs +454 -0
- package/lib/opencode/cli/auth-rotate.runner.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.runner.js +8 -0
- package/lib/opencode/cli/auth-rotate.runner.mjs +21 -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/install-opencode-plugins-cli.cjs +82 -0
- package/lib/opencode/install-opencode-plugins-cli.d.ts +1 -0
- package/lib/opencode/install-opencode-plugins-cli.js +78 -0
- package/lib/opencode/install-opencode-plugins-cli.mjs +65 -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 +373 -0
- package/lib/opencode/utils/check-api.d.ts +16 -0
- package/lib/opencode/utils/check-api.js +132 -0
- package/lib/opencode/utils/check-api.mjs +12 -0
- package/lib/opencode/utils/check-api.runner.cjs +0 -0
- package/lib/opencode/utils/check-api.runner.d.ts +0 -0
- package/lib/opencode/utils/check-api.runner.js +1 -0
- package/lib/opencode/utils/check-api.runner.mjs +7 -0
- package/lib/opencode-cli.cjs +796 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +116 -0
- package/lib/opencode-cli.mjs +116 -0
- package/lib/package-resolutions-updater-cli.cjs +189 -154
- package/lib/package-resolutions-updater-cli.mjs +3 -2
- package/lib/package-resolutions-updater.cjs +189 -154
- package/lib/package-resolutions-updater.d.mts +12 -3
- package/lib/package-resolutions-updater.mjs +3 -2
- package/lib/print-directory-tree.cjs +139 -3
- package/lib/print-directory-tree.mjs +6 -3
- package/lib/print-tarball-tree-cli.cjs +305 -0
- package/lib/print-tarball-tree-cli.d.mts +2 -0
- package/lib/print-tarball-tree-cli.mjs +54 -0
- package/lib/print-tarball-tree.cjs +43 -216
- package/lib/print-tarball-tree.d.mts +4 -1
- package/lib/print-tarball-tree.mjs +12 -66
- package/lib/rmpath-cli.cjs +139 -5
- package/lib/rmpath-cli.mjs +3 -1
- package/lib/rmpath.cjs +155 -11
- package/lib/rmpath.mjs +3 -1
- package/lib/run-by-checksum/hash.cjs +50 -56
- package/lib/run-by-checksum/hash.d.cts +24 -0
- package/lib/run-by-checksum/hash.mjs +3 -7
- package/lib/run-by-checksum/run.cjs +95 -42
- package/lib/run-by-checksum/run.js +3 -3
- package/lib/run-by-checksum/run.mjs +2 -2
- package/lib/run-by-checksum-cli.cjs +96 -58
- package/lib/run-by-checksum-cli.mjs +2 -2
- package/lib/submodule-install.cjs +138 -4
- package/lib/submodule-install.mjs +5 -4
- package/lib/submodule-remove-cli.cjs +139 -5
- package/lib/submodule-remove-cli.mjs +3 -1
- package/lib/submodule-remove.cjs +154 -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/utils/isDebug.cjs +13 -0
- package/lib/utils/isDebug.d.cts +9 -0
- package/lib/utils/isDebug.mjs +6 -0
- 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 +50 -26
- package/readme.md +104 -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/chunk-WSHVPGNM.mjs +0 -44
- package/lib/chunk-X2B3X7D4.mjs +0 -35
- 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/run-by-checksum/hash.d.ts +0 -14
- package/lib/run-by-checksum/hash.js +0 -85
- package/readme.html +0 -784
- /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,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.DATABASE_PATH = exports.SESSION_DIFF_DIR = exports.SESSION_PATH = exports.STORAGE_PATH = exports.PROJECT_DIR = exports.AUTH_PATH = exports.LOG_DIR = exports.CACHE_DIR = exports.CONFIG_DIR = exports.OPCODE_DIR = void 0;
|
|
16
|
+
exports.scanJson = scanJson;
|
|
17
|
+
exports.scanDirs = scanDirs;
|
|
18
|
+
exports.readJson = readJson;
|
|
19
|
+
exports.getSessionFileById = getSessionFileById;
|
|
20
|
+
exports.getOpenCodeAuth = getOpenCodeAuth;
|
|
21
|
+
exports.saveOpenCodeAuth = saveOpenCodeAuth;
|
|
22
|
+
const upath_1 = __importDefault(require("upath"));
|
|
23
|
+
const os_1 = __importDefault(require("os"));
|
|
24
|
+
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
25
|
+
const jsonc_parser_1 = require("jsonc-parser");
|
|
26
|
+
/** Root data directory (`~/.local/share/opencode`). */
|
|
27
|
+
exports.OPCODE_DIR = upath_1.default.join(os_1.default.homedir(), '.local/share/opencode');
|
|
28
|
+
/** Config directory (`~/.config/opencode`). */
|
|
29
|
+
exports.CONFIG_DIR = upath_1.default.join(os_1.default.homedir(), '.config/opencode');
|
|
30
|
+
/** Cache directory (`~/.cache/opencode`). */
|
|
31
|
+
exports.CACHE_DIR = upath_1.default.join(os_1.default.homedir(), '.cache/opencode');
|
|
32
|
+
/** Logs directory. */
|
|
33
|
+
exports.LOG_DIR = upath_1.default.join(exports.OPCODE_DIR, 'log');
|
|
34
|
+
/** Path to the auth JSON file. */
|
|
35
|
+
exports.AUTH_PATH = upath_1.default.join(exports.OPCODE_DIR, 'auth.json');
|
|
36
|
+
/** Project storage directory (sessions, messages). */
|
|
37
|
+
exports.PROJECT_DIR = upath_1.default.join(exports.OPCODE_DIR, 'project');
|
|
38
|
+
/** @deprecated Legacy storage sub-path. Use `OPCODE_DIR` or `PROJECT_DIR` instead. */
|
|
39
|
+
exports.STORAGE_PATH = upath_1.default.join(exports.OPCODE_DIR, 'storage');
|
|
40
|
+
/** @deprecated Legacy session sub-path. Use `PROJECT_DIR` instead. */
|
|
41
|
+
exports.SESSION_PATH = upath_1.default.join(exports.STORAGE_PATH, 'session');
|
|
42
|
+
/** Session diff directory. */
|
|
43
|
+
exports.SESSION_DIFF_DIR = upath_1.default.join(exports.STORAGE_PATH, 'session_diff');
|
|
44
|
+
/** Path to the OpenCode database. */
|
|
45
|
+
exports.DATABASE_PATH = upath_1.default.join(exports.OPCODE_DIR, 'opencode.db');
|
|
46
|
+
function scanJson(dir) {
|
|
47
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
const results = [];
|
|
49
|
+
try {
|
|
50
|
+
const entries = yield fs_extra_1.default.readdir(dir);
|
|
51
|
+
for (const entry of entries) {
|
|
52
|
+
if (!entry.endsWith('.json'))
|
|
53
|
+
continue;
|
|
54
|
+
const content = yield fs_extra_1.default.readFile(upath_1.default.join(dir, entry), 'utf-8');
|
|
55
|
+
results.push(JSON.parse(content));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch (_a) {
|
|
59
|
+
// Ignore errors, return what we have
|
|
60
|
+
}
|
|
61
|
+
return results;
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
function scanDirs(dir) {
|
|
65
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
+
try {
|
|
67
|
+
const entries = yield fs_extra_1.default.readdir(dir, { withFileTypes: true });
|
|
68
|
+
return entries.filter((e) => e.isDirectory()).map((e) => e.name);
|
|
69
|
+
}
|
|
70
|
+
catch (_a) {
|
|
71
|
+
return [];
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
function readJson(filePath) {
|
|
76
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
77
|
+
try {
|
|
78
|
+
const content = yield fs_extra_1.default.readFile(filePath, 'utf-8');
|
|
79
|
+
return (0, jsonc_parser_1.parse)(content);
|
|
80
|
+
}
|
|
81
|
+
catch (_a) {
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
function getSessionFileById(sessionId) {
|
|
87
|
+
return upath_1.default.join(exports.SESSION_DIFF_DIR, `${sessionId}.json`);
|
|
88
|
+
}
|
|
89
|
+
function getOpenCodeAuth() {
|
|
90
|
+
const file = upath_1.default.join(exports.OPCODE_DIR, 'auth.json');
|
|
91
|
+
if (!fs_extra_1.default.existsSync(file))
|
|
92
|
+
return null;
|
|
93
|
+
return readJson(file);
|
|
94
|
+
}
|
|
95
|
+
function saveOpenCodeAuth(auth) {
|
|
96
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
97
|
+
const file = upath_1.default.join(exports.OPCODE_DIR, 'auth.json');
|
|
98
|
+
yield fs_extra_1.default.ensureFile(file);
|
|
99
|
+
yield fs_extra_1.default.writeFile(file, JSON.stringify(auth, null, 2), 'utf-8');
|
|
100
|
+
});
|
|
101
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
AUTH_PATH,
|
|
4
|
+
CACHE_DIR,
|
|
5
|
+
CONFIG_DIR,
|
|
6
|
+
DATABASE_PATH,
|
|
7
|
+
LOG_DIR,
|
|
8
|
+
OPCODE_DIR,
|
|
9
|
+
PROJECT_DIR,
|
|
10
|
+
SESSION_DIFF_DIR,
|
|
11
|
+
SESSION_PATH,
|
|
12
|
+
STORAGE_PATH,
|
|
13
|
+
getOpenCodeAuth,
|
|
14
|
+
getSessionFileById,
|
|
15
|
+
readJson,
|
|
16
|
+
saveOpenCodeAuth,
|
|
17
|
+
scanDirs,
|
|
18
|
+
scanJson
|
|
19
|
+
} from "../chunk-XW5NZAKI.mjs";
|
|
20
|
+
import "../chunk-QQ4A6DLD.mjs";
|
|
21
|
+
export {
|
|
22
|
+
AUTH_PATH,
|
|
23
|
+
CACHE_DIR,
|
|
24
|
+
CONFIG_DIR,
|
|
25
|
+
DATABASE_PATH,
|
|
26
|
+
LOG_DIR,
|
|
27
|
+
OPCODE_DIR,
|
|
28
|
+
PROJECT_DIR,
|
|
29
|
+
SESSION_DIFF_DIR,
|
|
30
|
+
SESSION_PATH,
|
|
31
|
+
STORAGE_PATH,
|
|
32
|
+
getOpenCodeAuth,
|
|
33
|
+
getSessionFileById,
|
|
34
|
+
readJson,
|
|
35
|
+
saveOpenCodeAuth,
|
|
36
|
+
scanDirs,
|
|
37
|
+
scanJson
|
|
38
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __copyProps = (to, from, except, desc) => {
|
|
8
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
9
|
+
for (let key of __getOwnPropNames(from))
|
|
10
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
11
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
12
|
+
}
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
17
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
18
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
19
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
|
|
24
|
+
// src/opencode/storage.ts
|
|
25
|
+
var import_upath = __toESM(require("upath"), 1);
|
|
26
|
+
var import_os = __toESM(require("os"), 1);
|
|
27
|
+
var import_fs_extra = __toESM(require("fs-extra"), 1);
|
|
28
|
+
var import_jsonc_parser = require("jsonc-parser");
|
|
29
|
+
var OPCODE_DIR = import_upath.default.join(import_os.default.homedir(), ".local/share/opencode");
|
|
30
|
+
var CONFIG_DIR = import_upath.default.join(import_os.default.homedir(), ".config/opencode");
|
|
31
|
+
var CACHE_DIR = import_upath.default.join(import_os.default.homedir(), ".cache/opencode");
|
|
32
|
+
var LOG_DIR = import_upath.default.join(OPCODE_DIR, "log");
|
|
33
|
+
var AUTH_PATH = import_upath.default.join(OPCODE_DIR, "auth.json");
|
|
34
|
+
var PROJECT_DIR = import_upath.default.join(OPCODE_DIR, "project");
|
|
35
|
+
var STORAGE_PATH = import_upath.default.join(OPCODE_DIR, "storage");
|
|
36
|
+
var SESSION_PATH = import_upath.default.join(STORAGE_PATH, "session");
|
|
37
|
+
var SESSION_DIFF_DIR = import_upath.default.join(STORAGE_PATH, "session_diff");
|
|
38
|
+
var DATABASE_PATH = import_upath.default.join(OPCODE_DIR, "opencode.db");
|
|
39
|
+
|
|
40
|
+
// src/opencode/storage.runner.ts
|
|
41
|
+
console.log(`OPCODE_DIR: ${OPCODE_DIR}`);
|
|
42
|
+
console.log(`CONFIG_DIR: ${CONFIG_DIR}`);
|
|
43
|
+
console.log(`CACHE_DIR: ${CACHE_DIR}`);
|
|
44
|
+
console.log(`LOG_DIR: ${LOG_DIR}`);
|
|
45
|
+
console.log(`AUTH_PATH: ${AUTH_PATH}`);
|
|
46
|
+
console.log(`PROJECT_DIR: ${PROJECT_DIR}`);
|
|
47
|
+
console.log(`STORAGE_PATH: ${STORAGE_PATH}`);
|
|
48
|
+
console.log(`SESSION_PATH: ${SESSION_PATH}`);
|
|
49
|
+
console.log(`SESSION_DIFF_DIR: ${SESSION_DIFF_DIR}`);
|
|
50
|
+
console.log(`DATABASE_PATH: ${DATABASE_PATH}`);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const storage_js_1 = require("./storage.js");
|
|
4
|
+
console.log(`OPCODE_DIR: ${storage_js_1.OPCODE_DIR}`);
|
|
5
|
+
console.log(`CONFIG_DIR: ${storage_js_1.CONFIG_DIR}`);
|
|
6
|
+
console.log(`CACHE_DIR: ${storage_js_1.CACHE_DIR}`);
|
|
7
|
+
console.log(`LOG_DIR: ${storage_js_1.LOG_DIR}`);
|
|
8
|
+
console.log(`AUTH_PATH: ${storage_js_1.AUTH_PATH}`);
|
|
9
|
+
console.log(`PROJECT_DIR: ${storage_js_1.PROJECT_DIR}`);
|
|
10
|
+
console.log(`STORAGE_PATH: ${storage_js_1.STORAGE_PATH}`);
|
|
11
|
+
console.log(`SESSION_PATH: ${storage_js_1.SESSION_PATH}`);
|
|
12
|
+
console.log(`SESSION_DIFF_DIR: ${storage_js_1.SESSION_DIFF_DIR}`);
|
|
13
|
+
console.log(`DATABASE_PATH: ${storage_js_1.DATABASE_PATH}`);
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
AUTH_PATH,
|
|
4
|
+
CACHE_DIR,
|
|
5
|
+
CONFIG_DIR,
|
|
6
|
+
DATABASE_PATH,
|
|
7
|
+
LOG_DIR,
|
|
8
|
+
OPCODE_DIR,
|
|
9
|
+
PROJECT_DIR,
|
|
10
|
+
SESSION_DIFF_DIR,
|
|
11
|
+
SESSION_PATH,
|
|
12
|
+
STORAGE_PATH
|
|
13
|
+
} from "../chunk-XW5NZAKI.mjs";
|
|
14
|
+
import {
|
|
15
|
+
init_esm_shims
|
|
16
|
+
} from "../chunk-QQ4A6DLD.mjs";
|
|
17
|
+
|
|
18
|
+
// src/opencode/storage.runner.ts
|
|
19
|
+
init_esm_shims();
|
|
20
|
+
console.log(`OPCODE_DIR: ${OPCODE_DIR}`);
|
|
21
|
+
console.log(`CONFIG_DIR: ${CONFIG_DIR}`);
|
|
22
|
+
console.log(`CACHE_DIR: ${CACHE_DIR}`);
|
|
23
|
+
console.log(`LOG_DIR: ${LOG_DIR}`);
|
|
24
|
+
console.log(`AUTH_PATH: ${AUTH_PATH}`);
|
|
25
|
+
console.log(`PROJECT_DIR: ${PROJECT_DIR}`);
|
|
26
|
+
console.log(`STORAGE_PATH: ${STORAGE_PATH}`);
|
|
27
|
+
console.log(`SESSION_PATH: ${SESSION_PATH}`);
|
|
28
|
+
console.log(`SESSION_DIFF_DIR: ${SESSION_DIFF_DIR}`);
|
|
29
|
+
console.log(`DATABASE_PATH: ${DATABASE_PATH}`);
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __copyProps = (to, from, except, desc) => {
|
|
6
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
7
|
+
for (let key of __getOwnPropNames(from))
|
|
8
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
9
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
10
|
+
}
|
|
11
|
+
return to;
|
|
12
|
+
};
|
|
13
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
14
|
+
|
|
15
|
+
// src/opencode/types.ts
|
|
16
|
+
var types_exports = {};
|
|
17
|
+
module.exports = __toCommonJS(types_exports);
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export type OpenCodeAuthData = {
|
|
2
|
+
opencode: {
|
|
3
|
+
type: string;
|
|
4
|
+
key: string;
|
|
5
|
+
};
|
|
6
|
+
nvidia: {
|
|
7
|
+
type: string;
|
|
8
|
+
key: string;
|
|
9
|
+
};
|
|
10
|
+
'github-copilot': {
|
|
11
|
+
type: string;
|
|
12
|
+
refresh: string;
|
|
13
|
+
access: string;
|
|
14
|
+
expires: number;
|
|
15
|
+
};
|
|
16
|
+
google: {
|
|
17
|
+
type: string;
|
|
18
|
+
key: string;
|
|
19
|
+
};
|
|
20
|
+
deepseek: {
|
|
21
|
+
type: string;
|
|
22
|
+
key: string;
|
|
23
|
+
};
|
|
24
|
+
openai: {
|
|
25
|
+
type: string;
|
|
26
|
+
refresh: string;
|
|
27
|
+
access: string;
|
|
28
|
+
expires: number;
|
|
29
|
+
accountId: string;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
@@ -0,0 +1,373 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __esm = (fn, res) => function __init() {
|
|
8
|
+
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
|
|
9
|
+
};
|
|
10
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
11
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
12
|
+
};
|
|
13
|
+
var __export = (target, all) => {
|
|
14
|
+
for (var name in all)
|
|
15
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
16
|
+
};
|
|
17
|
+
var __copyProps = (to, from, except, desc) => {
|
|
18
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
19
|
+
for (let key of __getOwnPropNames(from))
|
|
20
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
21
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
22
|
+
}
|
|
23
|
+
return to;
|
|
24
|
+
};
|
|
25
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
26
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
27
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
28
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
29
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
30
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
31
|
+
mod
|
|
32
|
+
));
|
|
33
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
34
|
+
|
|
35
|
+
// node_modules/tsup/assets/cjs_shims.js
|
|
36
|
+
var init_cjs_shims = __esm({
|
|
37
|
+
"node_modules/tsup/assets/cjs_shims.js"() {
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
// src/utils/findEnvFiles.cjs
|
|
42
|
+
var require_findEnvFiles = __commonJS({
|
|
43
|
+
"src/utils/findEnvFiles.cjs"(exports2, module2) {
|
|
44
|
+
init_cjs_shims();
|
|
45
|
+
var fs = require("fs");
|
|
46
|
+
var path = require("path");
|
|
47
|
+
var glob = require("glob");
|
|
48
|
+
var DEFAULT_IGNORES = [
|
|
49
|
+
"**/node_modules/**",
|
|
50
|
+
"**/.git/**",
|
|
51
|
+
"**/.yarn/**",
|
|
52
|
+
"**/.pnpm/**",
|
|
53
|
+
"**/dist/**",
|
|
54
|
+
"**/build/**",
|
|
55
|
+
"**/coverage/**",
|
|
56
|
+
"**/vendor/**",
|
|
57
|
+
"**/tmp/**",
|
|
58
|
+
"**/.cache/**",
|
|
59
|
+
"**/assets/**",
|
|
60
|
+
"**/logs/**",
|
|
61
|
+
"**/output/**",
|
|
62
|
+
"**/public/**",
|
|
63
|
+
"**/static/**",
|
|
64
|
+
"**/temp/**",
|
|
65
|
+
"**/backup/**",
|
|
66
|
+
"**/backups/**",
|
|
67
|
+
"**/examples/**",
|
|
68
|
+
"**/docs/**",
|
|
69
|
+
"**/tests/**",
|
|
70
|
+
"**/__tests__/**",
|
|
71
|
+
"**/spec/**",
|
|
72
|
+
"**/__specs__/**",
|
|
73
|
+
"**/scripts/**",
|
|
74
|
+
"**/bin/**",
|
|
75
|
+
"**/hooks/**",
|
|
76
|
+
"**/config/**",
|
|
77
|
+
"**/configs/**",
|
|
78
|
+
"**/settings/**",
|
|
79
|
+
"**/.vscode/**",
|
|
80
|
+
"**/.idea/**"
|
|
81
|
+
];
|
|
82
|
+
function findEnvFiles(startDir = process.cwd(), filter) {
|
|
83
|
+
const found = /* @__PURE__ */ new Set();
|
|
84
|
+
function addFile(file) {
|
|
85
|
+
const normalized = path.normalize(file);
|
|
86
|
+
if (typeof filter === "function" && !filter(normalized)) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
found.add(normalized);
|
|
90
|
+
}
|
|
91
|
+
let current = path.resolve(startDir);
|
|
92
|
+
while (true) {
|
|
93
|
+
const envPath = path.join(current, ".env");
|
|
94
|
+
if (fs.existsSync(envPath)) {
|
|
95
|
+
addFile(envPath);
|
|
96
|
+
}
|
|
97
|
+
const parent = path.dirname(current);
|
|
98
|
+
if (parent === current) {
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
current = parent;
|
|
102
|
+
}
|
|
103
|
+
const files = glob.globSync("**/.env*", {
|
|
104
|
+
cwd: startDir,
|
|
105
|
+
absolute: true,
|
|
106
|
+
nodir: true,
|
|
107
|
+
ignore: DEFAULT_IGNORES
|
|
108
|
+
});
|
|
109
|
+
for (const file of files) {
|
|
110
|
+
addFile(file);
|
|
111
|
+
}
|
|
112
|
+
return [...found];
|
|
113
|
+
}
|
|
114
|
+
function findEnvWithToken(startDir = process.cwd(), tokenName = "GITHUB_TOKEN") {
|
|
115
|
+
const envFiles = findEnvFiles(startDir);
|
|
116
|
+
return envFiles.find((file) => {
|
|
117
|
+
try {
|
|
118
|
+
const content = fs.readFileSync(file, "utf-8");
|
|
119
|
+
if (tokenName instanceof RegExp) {
|
|
120
|
+
return tokenName.test(content);
|
|
121
|
+
}
|
|
122
|
+
const regex = new RegExp(`^\\s*${tokenName}\\s*=`, "m");
|
|
123
|
+
return regex.test(content);
|
|
124
|
+
} catch (err) {
|
|
125
|
+
console.warn(`Failed to read ${file}: ${err instanceof Error ? err.message : String(err)}`);
|
|
126
|
+
return false;
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
module2.exports = {
|
|
131
|
+
DEFAULT_IGNORES,
|
|
132
|
+
findEnvFiles,
|
|
133
|
+
findEnvWithToken,
|
|
134
|
+
default: findEnvFiles
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
// src/binary-collections/config.cjs
|
|
140
|
+
var require_config = __commonJS({
|
|
141
|
+
"src/binary-collections/config.cjs"(exports2, module2) {
|
|
142
|
+
init_cjs_shims();
|
|
143
|
+
var path = require("upath");
|
|
144
|
+
var minimistLib = require("minimist");
|
|
145
|
+
var { findEnvWithToken } = require_findEnvFiles();
|
|
146
|
+
var dotenv = require("dotenv");
|
|
147
|
+
var { cosmiconfig } = require("cosmiconfig");
|
|
148
|
+
var loadDotenv = (tokenKey = /ACCESS_TOKEN|GITHUB_TOKEN/) => dotenv.config({ path: findEnvWithToken(void 0, tokenKey), quiet: true, overwrite: true });
|
|
149
|
+
loadDotenv();
|
|
150
|
+
var cliArgv = minimistLib(process.argv.slice(2), {
|
|
151
|
+
string: ["token"]
|
|
152
|
+
});
|
|
153
|
+
var GITHUB_ACCESS_TOKEN = cliArgv.token || process.env.ACCESS_TOKEN || process.env.GITHUB_TOKEN || process.env.GH_TOKEN;
|
|
154
|
+
function getTempPath2(...segments) {
|
|
155
|
+
return path.join(process.env.TEMP_DIR || path.join(process.cwd(), "tmp"), ...segments);
|
|
156
|
+
}
|
|
157
|
+
async function getConfig(options = {}) {
|
|
158
|
+
const explorer = cosmiconfig("binary-collections", {
|
|
159
|
+
searchStrategy: "project",
|
|
160
|
+
stopDir: options.stopDir
|
|
161
|
+
});
|
|
162
|
+
try {
|
|
163
|
+
const result = await explorer.search(options.searchFrom);
|
|
164
|
+
return result ? result.config : null;
|
|
165
|
+
} catch {
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
module2.exports = {
|
|
170
|
+
getTempPath: getTempPath2,
|
|
171
|
+
GITHUB_ACCESS_TOKEN,
|
|
172
|
+
loadDotenv,
|
|
173
|
+
getConfig
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
// src/utils/isDebug.cjs
|
|
179
|
+
var require_isDebug = __commonJS({
|
|
180
|
+
"src/utils/isDebug.cjs"(exports2, module2) {
|
|
181
|
+
init_cjs_shims();
|
|
182
|
+
function isDebug2() {
|
|
183
|
+
if (globalThis.DEBUG !== void 0) {
|
|
184
|
+
if (typeof globalThis.DEBUG === "boolean") {
|
|
185
|
+
return globalThis.DEBUG;
|
|
186
|
+
}
|
|
187
|
+
return globalThis.DEBUG === "true" || globalThis.DEBUG === "1";
|
|
188
|
+
}
|
|
189
|
+
return process.env.DEBUG === "true" || process.env.NODE_ENV === "development" || process.env.DEBUG === "1";
|
|
190
|
+
}
|
|
191
|
+
module2.exports = isDebug2;
|
|
192
|
+
module2.exports.default = isDebug2;
|
|
193
|
+
module2.exports.isDebug = isDebug2;
|
|
194
|
+
}
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
// src/run-by-checksum/hash.cjs
|
|
198
|
+
var require_hash = __commonJS({
|
|
199
|
+
"src/run-by-checksum/hash.cjs"(exports2, module2) {
|
|
200
|
+
init_cjs_shims();
|
|
201
|
+
var fs = require("fs-extra");
|
|
202
|
+
var glob = require("glob");
|
|
203
|
+
var path = require("upath");
|
|
204
|
+
var CryptoJS = require("crypto-js");
|
|
205
|
+
var globSync = typeof glob.sync === "function" ? glob.sync : glob.globSync;
|
|
206
|
+
function getAllFiles({ patterns = [], ignore = [], cwd } = {}) {
|
|
207
|
+
const files = /* @__PURE__ */ new Set();
|
|
208
|
+
const root = path.resolve(cwd || process.cwd());
|
|
209
|
+
for (const pattern of patterns) {
|
|
210
|
+
const matched = globSync(pattern, {
|
|
211
|
+
cwd: root,
|
|
212
|
+
nodir: true,
|
|
213
|
+
ignore,
|
|
214
|
+
absolute: false
|
|
215
|
+
});
|
|
216
|
+
for (const f of matched) {
|
|
217
|
+
files.add(path.normalize(path.resolve(root, f)));
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
return Array.from(files).sort();
|
|
221
|
+
}
|
|
222
|
+
function isBinaryFile(filePath, bytesToCheck = 8e3) {
|
|
223
|
+
const size = Math.max(0, Number(bytesToCheck) || 0);
|
|
224
|
+
if (size === 0) {
|
|
225
|
+
return false;
|
|
226
|
+
}
|
|
227
|
+
const fd = fs.openSync(filePath, "r");
|
|
228
|
+
try {
|
|
229
|
+
const buffer = Buffer.allocUnsafe(size);
|
|
230
|
+
const bytesRead = fs.readSync(fd, buffer, 0, size, 0);
|
|
231
|
+
for (let i = 0; i < bytesRead; i++) {
|
|
232
|
+
if (buffer[i] === 0) {
|
|
233
|
+
return true;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
return false;
|
|
237
|
+
} finally {
|
|
238
|
+
fs.closeSync(fd);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
function hashFile(file) {
|
|
242
|
+
if (!isBinaryFile(file)) {
|
|
243
|
+
const content = fs.readFileSync(file, "utf8");
|
|
244
|
+
const normalized = content.replace(/\s+/g, " ").trim();
|
|
245
|
+
return CryptoJS.SHA256(normalized).toString(CryptoJS.enc.Hex);
|
|
246
|
+
}
|
|
247
|
+
const stats = fs.statSync(file);
|
|
248
|
+
const binHash = CryptoJS.algo.SHA256.create();
|
|
249
|
+
binHash.update(file);
|
|
250
|
+
binHash.update(String(stats.size));
|
|
251
|
+
return binHash.finalize().toString(CryptoJS.enc.Hex);
|
|
252
|
+
}
|
|
253
|
+
function buildChecksum(files = []) {
|
|
254
|
+
const hash = CryptoJS.algo.SHA256.create();
|
|
255
|
+
for (const file of files) {
|
|
256
|
+
hash.update(file);
|
|
257
|
+
hash.update(hashFile(file));
|
|
258
|
+
}
|
|
259
|
+
return hash.finalize().toString(CryptoJS.enc.Hex);
|
|
260
|
+
}
|
|
261
|
+
function sha2562(data, trim = 128) {
|
|
262
|
+
const hash = CryptoJS.SHA256(String(data)).toString(CryptoJS.enc.Hex);
|
|
263
|
+
return trim ? hash.substring(0, trim) : hash;
|
|
264
|
+
}
|
|
265
|
+
module2.exports = { getAllFiles, buildChecksum, sha256: sha2562 };
|
|
266
|
+
}
|
|
267
|
+
});
|
|
268
|
+
|
|
269
|
+
// src/opencode/utils/check-api.ts
|
|
270
|
+
var check_api_exports = {};
|
|
271
|
+
__export(check_api_exports, {
|
|
272
|
+
checkOpenCodeApi: () => checkOpenCodeApi
|
|
273
|
+
});
|
|
274
|
+
module.exports = __toCommonJS(check_api_exports);
|
|
275
|
+
init_cjs_shims();
|
|
276
|
+
var import_axios = __toESM(require("axios"), 1);
|
|
277
|
+
var import_sbg_utility = require("sbg-utility");
|
|
278
|
+
var import_config = __toESM(require_config(), 1);
|
|
279
|
+
var import_isDebug = __toESM(require_isDebug(), 1);
|
|
280
|
+
var import_hash = __toESM(require_hash(), 1);
|
|
281
|
+
var import_proxy_agent = require("proxy-agent");
|
|
282
|
+
function getProxyUrl(proxyUrl) {
|
|
283
|
+
return proxyUrl || process.env.OPENCODE_PROXY || process.env.ALL_PROXY || process.env.all_proxy || process.env.HTTPS_PROXY || process.env.https_proxy || process.env.HTTP_PROXY || process.env.http_proxy;
|
|
284
|
+
}
|
|
285
|
+
function maskProxyUrl(proxyUrl) {
|
|
286
|
+
try {
|
|
287
|
+
const url = new URL(proxyUrl);
|
|
288
|
+
if (url.username || url.password) {
|
|
289
|
+
url.username = "***";
|
|
290
|
+
url.password = "***";
|
|
291
|
+
}
|
|
292
|
+
return url.toString();
|
|
293
|
+
} catch {
|
|
294
|
+
return proxyUrl.replace(/:\/\/.*@/, "://***@");
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
async function checkOpenCodeApi(prompt, apiKey, model = "deepseek-v4-flash-free", proxyUrl) {
|
|
298
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
299
|
+
const debug = (0, import_isDebug.isDebug)();
|
|
300
|
+
const resolvedProxyUrl = getProxyUrl(proxyUrl);
|
|
301
|
+
let proxyAgent;
|
|
302
|
+
if (resolvedProxyUrl) {
|
|
303
|
+
const proxyUrlValue = resolvedProxyUrl;
|
|
304
|
+
proxyAgent = new import_proxy_agent.ProxyAgent({
|
|
305
|
+
getProxyForUrl: () => proxyUrlValue
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
try {
|
|
309
|
+
if (debug && resolvedProxyUrl) {
|
|
310
|
+
console.log(`Using proxy: ${maskProxyUrl(resolvedProxyUrl)}`);
|
|
311
|
+
}
|
|
312
|
+
const res = await import_axios.default.post(
|
|
313
|
+
"https://opencode.ai/zen/v1/chat/completions",
|
|
314
|
+
{
|
|
315
|
+
model,
|
|
316
|
+
messages: [{ role: "user", content: prompt }],
|
|
317
|
+
max_tokens: 512
|
|
318
|
+
},
|
|
319
|
+
{
|
|
320
|
+
headers: {
|
|
321
|
+
Authorization: `Bearer ${apiKey}`,
|
|
322
|
+
"Content-Type": "application/json"
|
|
323
|
+
},
|
|
324
|
+
validateStatus: () => true,
|
|
325
|
+
timeout: 3e4,
|
|
326
|
+
proxy: false,
|
|
327
|
+
httpAgent: proxyAgent,
|
|
328
|
+
httpsAgent: proxyAgent
|
|
329
|
+
}
|
|
330
|
+
);
|
|
331
|
+
if (debug) {
|
|
332
|
+
console.log("OpenCode status:", res.status);
|
|
333
|
+
}
|
|
334
|
+
const filePath = (0, import_config.getTempPath)("logs", `opencode-api-check-${(0, import_hash.sha256)(apiKey)}.json`);
|
|
335
|
+
if (debug) {
|
|
336
|
+
(0, import_sbg_utility.writefile)(filePath, JSON.stringify(res.data, null, 2));
|
|
337
|
+
console.log(`OpenCode API check response dumped to: ${filePath}`);
|
|
338
|
+
}
|
|
339
|
+
const errorType = (_b = (_a = res.data) == null ? void 0 : _a.error) == null ? void 0 : _b.type;
|
|
340
|
+
if (res.status === 429 && errorType === "FreeUsageLimitError") {
|
|
341
|
+
if (debug) {
|
|
342
|
+
console.warn("OpenCode API rate limit exceeded. Skipping this key.");
|
|
343
|
+
}
|
|
344
|
+
return false;
|
|
345
|
+
}
|
|
346
|
+
if (res.status < 200 || res.status >= 300) {
|
|
347
|
+
if (debug) {
|
|
348
|
+
console.error("OpenCode API returned non-2xx response:", res.data);
|
|
349
|
+
}
|
|
350
|
+
return false;
|
|
351
|
+
}
|
|
352
|
+
const message = (_e = (_d = (_c = res.data) == null ? void 0 : _c.choices) == null ? void 0 : _d[0]) == null ? void 0 : _e.message;
|
|
353
|
+
const output = (message == null ? void 0 : message.content) || (message == null ? void 0 : message.reasoning_content);
|
|
354
|
+
return Boolean(output && output.trim().length > 0);
|
|
355
|
+
} catch (err) {
|
|
356
|
+
if (debug) {
|
|
357
|
+
console.error("OpenCode API check failed");
|
|
358
|
+
if (import_axios.default.isAxiosError(err)) {
|
|
359
|
+
console.error("Message:", err.message);
|
|
360
|
+
console.error("Code:", err.code);
|
|
361
|
+
console.error("Status:", (_f = err.response) == null ? void 0 : _f.status);
|
|
362
|
+
console.error("Response:", (_g = err.response) == null ? void 0 : _g.data);
|
|
363
|
+
} else {
|
|
364
|
+
console.error(err);
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
return false;
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
371
|
+
0 && (module.exports = {
|
|
372
|
+
checkOpenCodeApi
|
|
373
|
+
});
|