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.
Files changed (145) hide show
  1. package/.opencode/plugins/opencode-request-logger/README.md +44 -0
  2. package/.venv/Lib/site-packages/pyarrow/tests/data/orc/README.md +22 -0
  3. package/docs-src/install-opencode-plugins.md +86 -0
  4. package/docs-src/opencode-cli.md +38 -10
  5. package/lib/binary-collections/config-types.cjs +17 -0
  6. package/lib/binary-collections/config-types.d.ts +12 -0
  7. package/lib/binary-collections/config-types.js +2 -0
  8. package/lib/binary-collections/config-types.mjs +7 -0
  9. package/lib/binary-collections/config.cjs +16 -8
  10. package/lib/binary-collections/config.d.cts +18 -10
  11. package/lib/binary-collections/config.mjs +1 -1
  12. package/lib/binary-collections/findScript.cjs +8 -6
  13. package/lib/binary-collections/findScript.mjs +2 -2
  14. package/lib/binary-collections/listScript.cjs +8 -6
  15. package/lib/binary-collections/listScript.mjs +2 -2
  16. package/lib/binary-collections.cjs +8 -6
  17. package/lib/binary-collections.mjs +3 -3
  18. package/lib/changelog.cjs +142 -4
  19. package/lib/changelog.mjs +9 -5
  20. package/lib/{chunk-SARIXFHP.mjs → chunk-3T6AMFI3.mjs} +16 -8
  21. package/lib/{chunk-3F6EIHYG.mjs → chunk-3ZF2QMDK.mjs} +3 -3
  22. package/lib/chunk-B77D3SR4.mjs +28 -0
  23. package/lib/chunk-BPED62FN.mjs +115 -0
  24. package/lib/{chunk-XI67TI46.mjs → chunk-DHFRWM2W.mjs} +1 -1
  25. package/lib/{chunk-2SJKVOTN.mjs → chunk-DPEE3FBB.mjs} +1 -1
  26. package/lib/{chunk-UYNBNLV5.mjs → chunk-H7AE4IO3.mjs} +1 -1
  27. package/lib/{chunk-YWSLMAQ7.mjs → chunk-KCJYREA2.mjs} +14 -12
  28. package/lib/{chunk-JK3MG2KF.mjs → chunk-NHD4HLSU.mjs} +1 -1
  29. package/lib/{chunk-I3O5ZRYU.mjs → chunk-OWNVMKAA.mjs} +1 -1
  30. package/lib/chunk-SKVF4TMD.mjs +59 -0
  31. package/lib/{chunk-SJYP66BO.mjs → chunk-TDUUOAQD.mjs} +1 -1
  32. package/lib/{chunk-D42YBRZW.mjs → chunk-UAEKSLAX.mjs} +1 -1
  33. package/lib/chunk-V6PTSDW5.mjs +82 -0
  34. package/lib/{chunk-AJ3OIYYP.mjs → chunk-WNUEY6VJ.mjs} +8 -6
  35. package/lib/{chunk-YLV4QATP.mjs → chunk-Z53IUBUN.mjs} +6 -5
  36. package/lib/{chunk-JMUFQSPE.mjs → chunk-Z7RM46Q4.mjs} +1 -1
  37. package/lib/cross-env/index.mjs +3 -3
  38. package/lib/git/git-diff-cli.cjs +16 -8
  39. package/lib/git/git-diff-cli.mjs +3 -3
  40. package/lib/git/git-diff.cjs +16 -8
  41. package/lib/git/git-diff.mjs +3 -3
  42. package/lib/git/git-fix.cjs +16 -8
  43. package/lib/git/git-fix.mjs +2 -2
  44. package/lib/git/user-config.cjs +16 -8
  45. package/lib/git/user-config.mjs +2 -2
  46. package/lib/github-workflows/clean-github-actions-caches-cli.cjs +16 -8
  47. package/lib/github-workflows/clean-github-actions-caches-cli.mjs +2 -2
  48. package/lib/github-workflows/clean-github-actions-caches.cjs +16 -8
  49. package/lib/github-workflows/clean-github-actions-caches.mjs +2 -2
  50. package/lib/github-workflows/get-latest-workflow-status-cli.cjs +16 -8
  51. package/lib/github-workflows/get-latest-workflow-status-cli.mjs +2 -2
  52. package/lib/github-workflows/utils.cjs +16 -8
  53. package/lib/github-workflows/utils.mjs +2 -2
  54. package/lib/github-workflows/workflow-badge-cli.cjs +16 -8
  55. package/lib/github-workflows/workflow-badge-cli.mjs +4 -4
  56. package/lib/node-cache-cleaner-cli.mjs +3 -3
  57. package/lib/opencode/cli/auth-rotate.cjs +343 -28
  58. package/lib/opencode/cli/auth-rotate.d.ts +3 -1
  59. package/lib/opencode/cli/auth-rotate.js +10 -15
  60. package/lib/opencode/cli/auth-rotate.mjs +6 -2
  61. package/lib/opencode/cli/auth-rotate.runner.cjs +454 -0
  62. package/lib/opencode/cli/auth-rotate.runner.d.ts +1 -0
  63. package/lib/opencode/cli/auth-rotate.runner.js +8 -0
  64. package/lib/opencode/cli/auth-rotate.runner.mjs +21 -0
  65. package/lib/opencode/install-opencode-plugins-cli.cjs +82 -0
  66. package/lib/opencode/install-opencode-plugins-cli.d.ts +1 -0
  67. package/lib/opencode/install-opencode-plugins-cli.js +78 -0
  68. package/lib/opencode/install-opencode-plugins-cli.mjs +65 -0
  69. package/lib/opencode/utils/check-api.cjs +332 -18
  70. package/lib/opencode/utils/check-api.d.ts +5 -1
  71. package/lib/opencode/utils/check-api.js +101 -15
  72. package/lib/opencode/utils/check-api.mjs +5 -1
  73. package/lib/opencode/utils/check-api.runner.cjs +0 -0
  74. package/lib/opencode/utils/check-api.runner.d.ts +0 -0
  75. package/lib/opencode/utils/check-api.runner.js +1 -0
  76. package/lib/opencode/utils/check-api.runner.mjs +7 -0
  77. package/lib/opencode-cli.cjs +352 -29
  78. package/lib/opencode-cli.js +3 -2
  79. package/lib/opencode-cli.mjs +11 -6
  80. package/lib/package-resolutions-updater-cli.cjs +16 -8
  81. package/lib/package-resolutions-updater-cli.mjs +2 -2
  82. package/lib/package-resolutions-updater.cjs +16 -8
  83. package/lib/package-resolutions-updater.mjs +2 -2
  84. package/lib/print-directory-tree.cjs +16 -8
  85. package/lib/print-directory-tree.mjs +1 -1
  86. package/lib/print-tarball-tree-cli.cjs +305 -0
  87. package/lib/print-tarball-tree-cli.d.mts +2 -0
  88. package/lib/print-tarball-tree-cli.mjs +54 -0
  89. package/lib/print-tarball-tree.cjs +43 -216
  90. package/lib/print-tarball-tree.d.mts +4 -1
  91. package/lib/print-tarball-tree.mjs +12 -66
  92. package/lib/rmpath-cli.cjs +16 -8
  93. package/lib/rmpath-cli.mjs +2 -2
  94. package/lib/rmpath.cjs +16 -8
  95. package/lib/rmpath.mjs +2 -2
  96. package/lib/run-by-checksum/hash.cjs +45 -67
  97. package/lib/run-by-checksum/{hash.d.ts → hash.d.cts} +9 -2
  98. package/lib/run-by-checksum/hash.mjs +3 -7
  99. package/lib/run-by-checksum/run.cjs +95 -58
  100. package/lib/run-by-checksum/run.js +3 -3
  101. package/lib/run-by-checksum/run.mjs +2 -2
  102. package/lib/run-by-checksum-cli.cjs +96 -74
  103. package/lib/run-by-checksum-cli.mjs +2 -2
  104. package/lib/submodule-install.cjs +16 -8
  105. package/lib/submodule-install.mjs +1 -1
  106. package/lib/submodule-remove-cli.cjs +16 -8
  107. package/lib/submodule-remove-cli.mjs +2 -2
  108. package/lib/submodule-remove.cjs +16 -8
  109. package/lib/submodule-remove.mjs +2 -2
  110. package/lib/utils/isDebug.cjs +13 -0
  111. package/lib/utils/isDebug.d.cts +9 -0
  112. package/lib/utils/isDebug.mjs +6 -0
  113. package/package.json +9 -7
  114. package/readme.md +63 -0
  115. package/releases/readme.md +1 -1
  116. package/lib/chunk-546KAIYT.mjs +0 -113
  117. package/lib/chunk-5WAOOOGZ.mjs +0 -77
  118. package/lib/chunk-72XTQ3CK.mjs +0 -45
  119. package/lib/chunk-7Q6YEUQF.mjs +0 -246
  120. package/lib/chunk-AQZ7LMFS.mjs +0 -100
  121. package/lib/chunk-BDCMTOZI.mjs +0 -246
  122. package/lib/chunk-BEUM4LH4.mjs +0 -184
  123. package/lib/chunk-BO4TZS4Q.mjs +0 -246
  124. package/lib/chunk-BZWVHODJ.mjs +0 -62
  125. package/lib/chunk-CM3IC5YC.mjs +0 -226
  126. package/lib/chunk-FR3DMHJC.mjs +0 -146
  127. package/lib/chunk-H44UWUFY.mjs +0 -105
  128. package/lib/chunk-JVMLKHD2.mjs +0 -62
  129. package/lib/chunk-KAT2JNLZ.mjs +0 -146
  130. package/lib/chunk-KRCPFWIF.mjs +0 -193
  131. package/lib/chunk-LVSPEFU2.mjs +0 -86
  132. package/lib/chunk-MCCMMZSM.mjs +0 -60
  133. package/lib/chunk-MGPYPKIE.mjs +0 -109
  134. package/lib/chunk-OA2RKEY3.mjs +0 -162
  135. package/lib/chunk-PAZH45HS.mjs +0 -41
  136. package/lib/chunk-QZMGBDSA.mjs +0 -32
  137. package/lib/chunk-RDGDLSPD.mjs +0 -76
  138. package/lib/chunk-RKPIBGKE.mjs +0 -61
  139. package/lib/chunk-SWUAEY4H.mjs +0 -44
  140. package/lib/chunk-UAIF5VIA.mjs +0 -89
  141. package/lib/chunk-UHPFLJXH.mjs +0 -227
  142. package/lib/chunk-WOC4FZ6F.mjs +0 -164
  143. package/lib/chunk-WSHVPGNM.mjs +0 -44
  144. package/lib/run-by-checksum/hash.js +0 -119
  145. 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
- var import_upath2 = __toESM(require("upath"), 1);
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
- async function checkOpenCodeApi(prompt, apiKey, model = "deepseek-v4-flash-free") {
75
- const res = await import_axios.default.post(
76
- "https://opencode.ai/zen/v1/chat/completions",
77
- {
78
- model,
79
- messages: [{ role: "user", content: prompt }],
80
- max_tokens: 512
81
- },
82
- {
83
- headers: { Authorization: `Bearer ${apiKey}` }
84
- }
85
- );
86
- const filePath = `tmp/logs/opencode-api-check-${Date.now()}.json`;
87
- (0, import_sbg_utility.writefile)(filePath, JSON.stringify(res.data, null, 2));
88
- const message = res.data.choices[0].message;
89
- const output = message.content || message.reasoning_content;
90
- const notEmptyOutput = output && output.trim().length > 0;
91
- return notEmptyOutput;
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
- async function handleAuthRotate() {
96
- let keysFile = import_upath2.default.join(process.cwd(), ".opencode.keys.jsonc");
97
- let keys = await readJson(keysFile);
98
- if (!keys) {
99
- keysFile = import_upath2.default.join(process.cwd(), ".opencode.keys.json");
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("No valid .opencode.keys.json or .opencode.keys.jsonc found in current directory");
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;
@@ -1 +1,3 @@
1
- export declare function handleAuthRotate(): Promise<void>;
1
+ export declare function handleAuthRotate(options?: {
2
+ proxy?: string;
3
+ }): Promise<void>;
@@ -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
- function handleAuthRotate() {
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
- // Try reading .opencode.keys.jsonc first, fallback to .opencode.keys.json
22
- let keysFile = upath_1.default.join(process.cwd(), '.opencode.keys.jsonc');
23
- let keys = yield (0, storage_js_1.readJson)(keysFile);
24
- if (!keys) {
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 valid .opencode.keys.json or .opencode.keys.jsonc found in current directory');
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 (_a) {
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-YWSLMAQ7.mjs";
5
- import "../../chunk-QZMGBDSA.mjs";
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