binary-collections 2.0.14 → 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/docs-src/install-opencode-plugins.md +86 -0
- package/docs-src/opencode-cli.md +38 -10
- 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 +16 -8
- package/lib/binary-collections/config.d.cts +18 -10
- package/lib/binary-collections/config.mjs +1 -1
- package/lib/binary-collections/findScript.cjs +8 -6
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +8 -6
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +8 -6
- package/lib/binary-collections.mjs +3 -3
- package/lib/changelog.cjs +142 -4
- package/lib/changelog.mjs +9 -5
- package/lib/{chunk-SARIXFHP.mjs → chunk-3T6AMFI3.mjs} +16 -8
- package/lib/{chunk-3F6EIHYG.mjs → chunk-3ZF2QMDK.mjs} +3 -3
- package/lib/chunk-B77D3SR4.mjs +28 -0
- package/lib/chunk-BPED62FN.mjs +115 -0
- package/lib/{chunk-XI67TI46.mjs → chunk-DHFRWM2W.mjs} +1 -1
- package/lib/{chunk-2SJKVOTN.mjs → chunk-DPEE3FBB.mjs} +1 -1
- package/lib/{chunk-UYNBNLV5.mjs → chunk-H7AE4IO3.mjs} +1 -1
- package/lib/{chunk-YWSLMAQ7.mjs → chunk-KCJYREA2.mjs} +14 -12
- package/lib/{chunk-JK3MG2KF.mjs → chunk-NHD4HLSU.mjs} +1 -1
- package/lib/{chunk-I3O5ZRYU.mjs → chunk-OWNVMKAA.mjs} +1 -1
- package/lib/chunk-SKVF4TMD.mjs +59 -0
- package/lib/{chunk-SJYP66BO.mjs → chunk-TDUUOAQD.mjs} +1 -1
- package/lib/{chunk-D42YBRZW.mjs → chunk-UAEKSLAX.mjs} +1 -1
- package/lib/chunk-V6PTSDW5.mjs +82 -0
- package/lib/{chunk-AJ3OIYYP.mjs → chunk-WNUEY6VJ.mjs} +8 -6
- package/lib/{chunk-YLV4QATP.mjs → chunk-Z53IUBUN.mjs} +6 -5
- package/lib/{chunk-JMUFQSPE.mjs → chunk-Z7RM46Q4.mjs} +1 -1
- package/lib/cross-env/index.mjs +3 -3
- package/lib/git/git-diff-cli.cjs +16 -8
- package/lib/git/git-diff-cli.mjs +3 -3
- package/lib/git/git-diff.cjs +16 -8
- package/lib/git/git-diff.mjs +3 -3
- package/lib/git/git-fix.cjs +16 -8
- package/lib/git/git-fix.mjs +2 -2
- package/lib/git/user-config.cjs +16 -8
- package/lib/git/user-config.mjs +2 -2
- package/lib/github-workflows/clean-github-actions-caches-cli.cjs +16 -8
- package/lib/github-workflows/clean-github-actions-caches-cli.mjs +2 -2
- package/lib/github-workflows/clean-github-actions-caches.cjs +16 -8
- package/lib/github-workflows/clean-github-actions-caches.mjs +2 -2
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +16 -8
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +2 -2
- package/lib/github-workflows/utils.cjs +16 -8
- package/lib/github-workflows/utils.mjs +2 -2
- package/lib/github-workflows/workflow-badge-cli.cjs +16 -8
- package/lib/github-workflows/workflow-badge-cli.mjs +4 -4
- package/lib/node-cache-cleaner-cli.mjs +3 -3
- package/lib/opencode/cli/auth-rotate.cjs +343 -28
- package/lib/opencode/cli/auth-rotate.d.ts +3 -1
- package/lib/opencode/cli/auth-rotate.js +10 -15
- package/lib/opencode/cli/auth-rotate.mjs +6 -2
- 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/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/utils/check-api.cjs +332 -18
- package/lib/opencode/utils/check-api.d.ts +5 -1
- package/lib/opencode/utils/check-api.js +101 -15
- package/lib/opencode/utils/check-api.mjs +5 -1
- 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 +352 -29
- package/lib/opencode-cli.js +3 -2
- package/lib/opencode-cli.mjs +11 -6
- package/lib/package-resolutions-updater-cli.cjs +16 -8
- package/lib/package-resolutions-updater-cli.mjs +2 -2
- package/lib/package-resolutions-updater.cjs +16 -8
- package/lib/package-resolutions-updater.mjs +2 -2
- package/lib/print-directory-tree.cjs +16 -8
- package/lib/print-directory-tree.mjs +1 -1
- 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 +16 -8
- package/lib/rmpath-cli.mjs +2 -2
- package/lib/rmpath.cjs +16 -8
- package/lib/rmpath.mjs +2 -2
- package/lib/run-by-checksum/hash.cjs +45 -67
- package/lib/run-by-checksum/{hash.d.ts → hash.d.cts} +9 -2
- package/lib/run-by-checksum/hash.mjs +3 -7
- package/lib/run-by-checksum/run.cjs +95 -58
- 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 -74
- package/lib/run-by-checksum-cli.mjs +2 -2
- package/lib/submodule-install.cjs +16 -8
- package/lib/submodule-install.mjs +1 -1
- package/lib/submodule-remove-cli.cjs +16 -8
- package/lib/submodule-remove-cli.mjs +2 -2
- package/lib/submodule-remove.cjs +16 -8
- package/lib/submodule-remove.mjs +2 -2
- package/lib/utils/isDebug.cjs +13 -0
- package/lib/utils/isDebug.d.cts +9 -0
- package/lib/utils/isDebug.mjs +6 -0
- package/package.json +9 -7
- package/readme.md +63 -0
- package/releases/readme.md +1 -1
- package/lib/chunk-546KAIYT.mjs +0 -113
- package/lib/chunk-5WAOOOGZ.mjs +0 -77
- package/lib/chunk-72XTQ3CK.mjs +0 -45
- package/lib/chunk-7Q6YEUQF.mjs +0 -246
- package/lib/chunk-AQZ7LMFS.mjs +0 -100
- package/lib/chunk-BDCMTOZI.mjs +0 -246
- package/lib/chunk-BEUM4LH4.mjs +0 -184
- package/lib/chunk-BO4TZS4Q.mjs +0 -246
- package/lib/chunk-BZWVHODJ.mjs +0 -62
- package/lib/chunk-CM3IC5YC.mjs +0 -226
- package/lib/chunk-FR3DMHJC.mjs +0 -146
- package/lib/chunk-H44UWUFY.mjs +0 -105
- package/lib/chunk-JVMLKHD2.mjs +0 -62
- package/lib/chunk-KAT2JNLZ.mjs +0 -146
- package/lib/chunk-KRCPFWIF.mjs +0 -193
- package/lib/chunk-LVSPEFU2.mjs +0 -86
- package/lib/chunk-MCCMMZSM.mjs +0 -60
- package/lib/chunk-MGPYPKIE.mjs +0 -109
- package/lib/chunk-OA2RKEY3.mjs +0 -162
- package/lib/chunk-PAZH45HS.mjs +0 -41
- package/lib/chunk-QZMGBDSA.mjs +0 -32
- package/lib/chunk-RDGDLSPD.mjs +0 -76
- package/lib/chunk-RKPIBGKE.mjs +0 -61
- package/lib/chunk-SWUAEY4H.mjs +0 -44
- package/lib/chunk-UAIF5VIA.mjs +0 -89
- package/lib/chunk-UHPFLJXH.mjs +0 -227
- package/lib/chunk-WOC4FZ6F.mjs +0 -164
- package/lib/chunk-WSHVPGNM.mjs +0 -44
- package/lib/run-by-checksum/hash.js +0 -119
- package/readme.html +0 -784
|
@@ -4,6 +4,12 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __getProtoOf = Object.getPrototypeOf;
|
|
6
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
|
+
};
|
|
7
13
|
var __export = (target, all) => {
|
|
8
14
|
for (var name in all)
|
|
9
15
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -26,15 +32,250 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
32
|
));
|
|
27
33
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
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 fs2 = require("fs");
|
|
46
|
+
var path2 = 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 = path2.normalize(file);
|
|
86
|
+
if (typeof filter === "function" && !filter(normalized)) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
found.add(normalized);
|
|
90
|
+
}
|
|
91
|
+
let current = path2.resolve(startDir);
|
|
92
|
+
while (true) {
|
|
93
|
+
const envPath = path2.join(current, ".env");
|
|
94
|
+
if (fs2.existsSync(envPath)) {
|
|
95
|
+
addFile(envPath);
|
|
96
|
+
}
|
|
97
|
+
const parent = path2.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 = fs2.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 path2 = 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 path2.join(process.env.TEMP_DIR || path2.join(process.cwd(), "tmp"), ...segments);
|
|
156
|
+
}
|
|
157
|
+
async function getConfig2(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: getConfig2
|
|
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 fs2 = require("fs-extra");
|
|
202
|
+
var glob = require("glob");
|
|
203
|
+
var path2 = 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 = path2.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(path2.normalize(path2.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 = fs2.openSync(filePath, "r");
|
|
228
|
+
try {
|
|
229
|
+
const buffer = Buffer.allocUnsafe(size);
|
|
230
|
+
const bytesRead = fs2.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
|
+
fs2.closeSync(fd);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
function hashFile(file) {
|
|
242
|
+
if (!isBinaryFile(file)) {
|
|
243
|
+
const content = fs2.readFileSync(file, "utf8");
|
|
244
|
+
const normalized = content.replace(/\s+/g, " ").trim();
|
|
245
|
+
return CryptoJS.SHA256(normalized).toString(CryptoJS.enc.Hex);
|
|
246
|
+
}
|
|
247
|
+
const stats = fs2.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
|
+
|
|
29
269
|
// src/opencode/cli/auth-rotate.ts
|
|
30
270
|
var auth_rotate_exports = {};
|
|
31
271
|
__export(auth_rotate_exports, {
|
|
32
272
|
handleAuthRotate: () => handleAuthRotate
|
|
33
273
|
});
|
|
34
274
|
module.exports = __toCommonJS(auth_rotate_exports);
|
|
35
|
-
|
|
275
|
+
init_cjs_shims();
|
|
36
276
|
|
|
37
277
|
// src/opencode/storage.ts
|
|
278
|
+
init_cjs_shims();
|
|
38
279
|
var import_upath = __toESM(require("upath"), 1);
|
|
39
280
|
var import_os = __toESM(require("os"), 1);
|
|
40
281
|
var import_fs_extra = __toESM(require("fs-extra"), 1);
|
|
@@ -69,38 +310,112 @@ async function saveOpenCodeAuth(auth) {
|
|
|
69
310
|
}
|
|
70
311
|
|
|
71
312
|
// src/opencode/utils/check-api.ts
|
|
313
|
+
init_cjs_shims();
|
|
72
314
|
var import_axios = __toESM(require("axios"), 1);
|
|
73
315
|
var import_sbg_utility = require("sbg-utility");
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
316
|
+
var import_config = __toESM(require_config(), 1);
|
|
317
|
+
var import_isDebug = __toESM(require_isDebug(), 1);
|
|
318
|
+
var import_hash = __toESM(require_hash(), 1);
|
|
319
|
+
var import_proxy_agent = require("proxy-agent");
|
|
320
|
+
function getProxyUrl(proxyUrl) {
|
|
321
|
+
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;
|
|
322
|
+
}
|
|
323
|
+
function maskProxyUrl(proxyUrl) {
|
|
324
|
+
try {
|
|
325
|
+
const url = new URL(proxyUrl);
|
|
326
|
+
if (url.username || url.password) {
|
|
327
|
+
url.username = "***";
|
|
328
|
+
url.password = "***";
|
|
329
|
+
}
|
|
330
|
+
return url.toString();
|
|
331
|
+
} catch {
|
|
332
|
+
return proxyUrl.replace(/:\/\/.*@/, "://***@");
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
async function checkOpenCodeApi(prompt, apiKey, model = "deepseek-v4-flash-free", proxyUrl) {
|
|
336
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
337
|
+
const debug = (0, import_isDebug.isDebug)();
|
|
338
|
+
const resolvedProxyUrl = getProxyUrl(proxyUrl);
|
|
339
|
+
let proxyAgent;
|
|
340
|
+
if (resolvedProxyUrl) {
|
|
341
|
+
const proxyUrlValue = resolvedProxyUrl;
|
|
342
|
+
proxyAgent = new import_proxy_agent.ProxyAgent({
|
|
343
|
+
getProxyForUrl: () => proxyUrlValue
|
|
344
|
+
});
|
|
345
|
+
}
|
|
346
|
+
try {
|
|
347
|
+
if (debug && resolvedProxyUrl) {
|
|
348
|
+
console.log(`Using proxy: ${maskProxyUrl(resolvedProxyUrl)}`);
|
|
349
|
+
}
|
|
350
|
+
const res = await import_axios.default.post(
|
|
351
|
+
"https://opencode.ai/zen/v1/chat/completions",
|
|
352
|
+
{
|
|
353
|
+
model,
|
|
354
|
+
messages: [{ role: "user", content: prompt }],
|
|
355
|
+
max_tokens: 512
|
|
356
|
+
},
|
|
357
|
+
{
|
|
358
|
+
headers: {
|
|
359
|
+
Authorization: `Bearer ${apiKey}`,
|
|
360
|
+
"Content-Type": "application/json"
|
|
361
|
+
},
|
|
362
|
+
validateStatus: () => true,
|
|
363
|
+
timeout: 3e4,
|
|
364
|
+
proxy: false,
|
|
365
|
+
httpAgent: proxyAgent,
|
|
366
|
+
httpsAgent: proxyAgent
|
|
367
|
+
}
|
|
368
|
+
);
|
|
369
|
+
if (debug) {
|
|
370
|
+
console.log("OpenCode status:", res.status);
|
|
371
|
+
}
|
|
372
|
+
const filePath = (0, import_config.getTempPath)("logs", `opencode-api-check-${(0, import_hash.sha256)(apiKey)}.json`);
|
|
373
|
+
if (debug) {
|
|
374
|
+
(0, import_sbg_utility.writefile)(filePath, JSON.stringify(res.data, null, 2));
|
|
375
|
+
console.log(`OpenCode API check response dumped to: ${filePath}`);
|
|
376
|
+
}
|
|
377
|
+
const errorType = (_b = (_a = res.data) == null ? void 0 : _a.error) == null ? void 0 : _b.type;
|
|
378
|
+
if (res.status === 429 && errorType === "FreeUsageLimitError") {
|
|
379
|
+
if (debug) {
|
|
380
|
+
console.warn("OpenCode API rate limit exceeded. Skipping this key.");
|
|
381
|
+
}
|
|
382
|
+
return false;
|
|
383
|
+
}
|
|
384
|
+
if (res.status < 200 || res.status >= 300) {
|
|
385
|
+
if (debug) {
|
|
386
|
+
console.error("OpenCode API returned non-2xx response:", res.data);
|
|
387
|
+
}
|
|
388
|
+
return false;
|
|
389
|
+
}
|
|
390
|
+
const message = (_e = (_d = (_c = res.data) == null ? void 0 : _c.choices) == null ? void 0 : _d[0]) == null ? void 0 : _e.message;
|
|
391
|
+
const output = (message == null ? void 0 : message.content) || (message == null ? void 0 : message.reasoning_content);
|
|
392
|
+
return Boolean(output && output.trim().length > 0);
|
|
393
|
+
} catch (err) {
|
|
394
|
+
if (debug) {
|
|
395
|
+
console.error("OpenCode API check failed");
|
|
396
|
+
if (import_axios.default.isAxiosError(err)) {
|
|
397
|
+
console.error("Message:", err.message);
|
|
398
|
+
console.error("Code:", err.code);
|
|
399
|
+
console.error("Status:", (_f = err.response) == null ? void 0 : _f.status);
|
|
400
|
+
console.error("Response:", (_g = err.response) == null ? void 0 : _g.data);
|
|
401
|
+
} else {
|
|
402
|
+
console.error(err);
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
return false;
|
|
406
|
+
}
|
|
92
407
|
}
|
|
93
408
|
|
|
94
409
|
// src/opencode/cli/auth-rotate.ts
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
keys = await readJson(keysFile);
|
|
101
|
-
}
|
|
410
|
+
var import_config2 = __toESM(require_config(), 1);
|
|
411
|
+
async function handleAuthRotate(options) {
|
|
412
|
+
var _a;
|
|
413
|
+
const config = await (0, import_config2.getConfig)();
|
|
414
|
+
const keys = (_a = config == null ? void 0 : config.opencode) == null ? void 0 : _a.keys;
|
|
102
415
|
if (!keys || !Array.isArray(keys) || keys.length === 0) {
|
|
103
|
-
console.error(
|
|
416
|
+
console.error(
|
|
417
|
+
'No opencode.keys found in project config. Add an "opencode" section with a "keys" array to your binary-collections.config.{js,cjs,mjs} file.'
|
|
418
|
+
);
|
|
104
419
|
process.exit(1);
|
|
105
420
|
}
|
|
106
421
|
const auth = await getOpenCodeAuth();
|
|
@@ -121,7 +436,7 @@ async function handleAuthRotate() {
|
|
|
121
436
|
let chosen = null;
|
|
122
437
|
for (const candidate of candidates) {
|
|
123
438
|
try {
|
|
124
|
-
const ok = await checkOpenCodeApi("Hello", candidate.key);
|
|
439
|
+
const ok = await checkOpenCodeApi("Hello", candidate.key, "deepseek-v4-flash-free", options == null ? void 0 : options.proxy);
|
|
125
440
|
if (ok) {
|
|
126
441
|
chosen = candidate;
|
|
127
442
|
break;
|
|
@@ -8,25 +8,20 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
8
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
9
|
});
|
|
10
10
|
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
12
|
exports.handleAuthRotate = handleAuthRotate;
|
|
16
|
-
const upath_1 = __importDefault(require("upath"));
|
|
17
13
|
const storage_js_1 = require("../storage.js");
|
|
18
14
|
const check_api_js_1 = require("../utils/check-api.js");
|
|
19
|
-
|
|
15
|
+
const config_cjs_1 = require("../../binary-collections/config.cjs");
|
|
16
|
+
function handleAuthRotate(options) {
|
|
20
17
|
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
keysFile = upath_1.default.join(process.cwd(), '.opencode.keys.json');
|
|
26
|
-
keys = yield (0, storage_js_1.readJson)(keysFile);
|
|
27
|
-
}
|
|
18
|
+
var _a;
|
|
19
|
+
// Load keys from project config (binary-collections.config.{js,cjs,mjs} / package.json)
|
|
20
|
+
const config = yield (0, config_cjs_1.getConfig)();
|
|
21
|
+
const keys = (_a = config === null || config === void 0 ? void 0 : config.opencode) === null || _a === void 0 ? void 0 : _a.keys;
|
|
28
22
|
if (!keys || !Array.isArray(keys) || keys.length === 0) {
|
|
29
|
-
console.error('No
|
|
23
|
+
console.error('No opencode.keys found in project config. ' +
|
|
24
|
+
'Add an "opencode" section with a "keys" array to your binary-collections.config.{js,cjs,mjs} file.');
|
|
30
25
|
process.exit(1);
|
|
31
26
|
}
|
|
32
27
|
const auth = yield (0, storage_js_1.getOpenCodeAuth)();
|
|
@@ -49,13 +44,13 @@ function handleAuthRotate() {
|
|
|
49
44
|
let chosen = null;
|
|
50
45
|
for (const candidate of candidates) {
|
|
51
46
|
try {
|
|
52
|
-
const ok = yield (0, check_api_js_1.checkOpenCodeApi)('Hello', candidate.key);
|
|
47
|
+
const ok = yield (0, check_api_js_1.checkOpenCodeApi)('Hello', candidate.key, 'deepseek-v4-flash-free', options === null || options === void 0 ? void 0 : options.proxy);
|
|
53
48
|
if (ok) {
|
|
54
49
|
chosen = candidate;
|
|
55
50
|
break;
|
|
56
51
|
}
|
|
57
52
|
}
|
|
58
|
-
catch (
|
|
53
|
+
catch (_b) {
|
|
59
54
|
// Key failed or errored — skip to next
|
|
60
55
|
}
|
|
61
56
|
}
|
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
handleAuthRotate
|
|
4
|
-
} from "../../chunk-
|
|
5
|
-
import "../../chunk-
|
|
4
|
+
} from "../../chunk-KCJYREA2.mjs";
|
|
5
|
+
import "../../chunk-BPED62FN.mjs";
|
|
6
|
+
import "../../chunk-B77D3SR4.mjs";
|
|
6
7
|
import "../../chunk-XW5NZAKI.mjs";
|
|
8
|
+
import "../../chunk-V6PTSDW5.mjs";
|
|
9
|
+
import "../../chunk-3T6AMFI3.mjs";
|
|
10
|
+
import "../../chunk-J4M5EL5P.mjs";
|
|
7
11
|
import "../../chunk-QQ4A6DLD.mjs";
|
|
8
12
|
export {
|
|
9
13
|
handleAuthRotate
|