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
@@ -0,0 +1,65 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ init_esm_shims
4
+ } from "../chunk-QQ4A6DLD.mjs";
5
+
6
+ // src/opencode/install-opencode-plugins-cli.ts
7
+ init_esm_shims();
8
+ import fs from "fs-extra";
9
+ import path from "upath";
10
+ import spawn from "cross-spawn";
11
+ var gitCloneDest = ".opencode/plugins/opencode-request-logger";
12
+ var commands = [
13
+ {
14
+ cmd: "git",
15
+ args: ["clone", "https://github.com/Opencode-DCP/opencode-request-logger.git", gitCloneDest],
16
+ skipIfExists: gitCloneDest
17
+ },
18
+ {
19
+ // Run after clone (or if folder already exists) to register the local plugin
20
+ cmd: "opencode",
21
+ args: ["plugin", ".opencode/plugins/opencode-request-logger"]
22
+ },
23
+ {
24
+ cmd: "opencode",
25
+ args: [
26
+ "plugin",
27
+ "opencode-agent-memory@https://github.com/dimaslanjaka/opencode-file-memory/raw/refs/heads/main/release/opencode-agent-memory.tgz"
28
+ ]
29
+ },
30
+ { cmd: "opencode", args: ["plugin", "@tarquinen/opencode-smart-title@latest"] },
31
+ { cmd: "opencode", args: ["plugin", "oh-my-opencode-slim@latest"] },
32
+ { cmd: "opencode", args: ["plugin", "@tarquinen/opencode-dcp@latest"] },
33
+ { cmd: "opencode", args: ["plugin", "envsitter-guard@latest"] }
34
+ ];
35
+ async function runCommand({ cmd, args, skipIfExists }) {
36
+ if (skipIfExists) {
37
+ const folderPath = path.resolve(skipIfExists);
38
+ if (await fs.pathExists(folderPath)) {
39
+ console.log(`
40
+ Skipping: ${cmd} ${args.join(" ")} (folder exists: ${folderPath})`);
41
+ return;
42
+ }
43
+ }
44
+ console.log(`
45
+ Running: ${cmd} ${args.join(" ")}`);
46
+ await new Promise((resolve, reject) => {
47
+ const child = spawn(cmd, args, { stdio: "inherit", shell: true });
48
+ child.on("close", (code) => {
49
+ if (code === 0) resolve();
50
+ else reject(new Error(`${cmd} exited with code ${code}`));
51
+ });
52
+ });
53
+ }
54
+ async function main() {
55
+ try {
56
+ for (const command of commands) {
57
+ await runCommand(command);
58
+ }
59
+ console.log("\nAll commands executed successfully!");
60
+ } catch (err) {
61
+ console.error("\nError executing commands:", err);
62
+ process.exit(1);
63
+ }
64
+ }
65
+ main();
@@ -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,32 +32,340 @@ 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 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
+
29
269
  // src/opencode/utils/check-api.ts
30
270
  var check_api_exports = {};
31
271
  __export(check_api_exports, {
32
272
  checkOpenCodeApi: () => checkOpenCodeApi
33
273
  });
34
274
  module.exports = __toCommonJS(check_api_exports);
275
+ init_cjs_shims();
35
276
  var import_axios = __toESM(require("axios"), 1);
36
277
  var import_sbg_utility = require("sbg-utility");
37
- async function checkOpenCodeApi(prompt, apiKey, model = "deepseek-v4-flash-free") {
38
- const res = await import_axios.default.post(
39
- "https://opencode.ai/zen/v1/chat/completions",
40
- {
41
- model,
42
- messages: [{ role: "user", content: prompt }],
43
- max_tokens: 512
44
- },
45
- {
46
- headers: { Authorization: `Bearer ${apiKey}` }
47
- }
48
- );
49
- const filePath = `tmp/logs/opencode-api-check-${Date.now()}.json`;
50
- (0, import_sbg_utility.writefile)(filePath, JSON.stringify(res.data, null, 2));
51
- const message = res.data.choices[0].message;
52
- const output = message.content || message.reasoning_content;
53
- const notEmptyOutput = output && output.trim().length > 0;
54
- return notEmptyOutput;
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
+ }
55
369
  }
56
370
  // Annotate the CommonJS export names for ESM import in node:
57
371
  0 && (module.exports = {
@@ -7,6 +7,10 @@
7
7
  * @param prompt - The user message to send to the model.
8
8
  * @param apiKey - Bearer token for API authentication.
9
9
  * @param model - Model identifier (defaults to `'deepseek-v4-flash-free'`).
10
+ * @param proxyUrl - Optional proxy URL. e.g: `http://127.0.0.1:8080, https://127.0.0.1:8443, socks4://127.0.0.1:1080, socks5://127.0.0.1:1080, socks5://user:pass@127.0.0.1:1080`
10
11
  * @returns `true` if the response contains non-empty content, `false` otherwise.
12
+ *
13
+ * @example
14
+ * await checkOpenCodeApi('Hello', apiKey, 'deepseek-v4-flash-free', 'socks5://127.0.0.1:1080');
11
15
  */
12
- export declare function checkOpenCodeApi(prompt: string, apiKey: string, model?: string): Promise<boolean>;
16
+ export declare function checkOpenCodeApi(prompt: string, apiKey: string, model?: string, proxyUrl?: string): Promise<boolean>;
@@ -15,6 +15,33 @@ Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.checkOpenCodeApi = checkOpenCodeApi;
16
16
  const axios_1 = __importDefault(require("axios"));
17
17
  const sbg_utility_1 = require("sbg-utility");
18
+ const config_cjs_1 = require("../../binary-collections/config.cjs");
19
+ const isDebug_cjs_1 = require("../../utils/isDebug.cjs");
20
+ const hash_cjs_1 = require("../../run-by-checksum/hash.cjs");
21
+ const proxy_agent_1 = require("proxy-agent");
22
+ function getProxyUrl(proxyUrl) {
23
+ return (proxyUrl ||
24
+ process.env.OPENCODE_PROXY ||
25
+ process.env.ALL_PROXY ||
26
+ process.env.all_proxy ||
27
+ process.env.HTTPS_PROXY ||
28
+ process.env.https_proxy ||
29
+ process.env.HTTP_PROXY ||
30
+ process.env.http_proxy);
31
+ }
32
+ function maskProxyUrl(proxyUrl) {
33
+ try {
34
+ const url = new URL(proxyUrl);
35
+ if (url.username || url.password) {
36
+ url.username = '***';
37
+ url.password = '***';
38
+ }
39
+ return url.toString();
40
+ }
41
+ catch (_a) {
42
+ return proxyUrl.replace(/:\/\/.*@/, '://***@');
43
+ }
44
+ }
18
45
  /**
19
46
  * Checks whether the OpenCode API returns a non-empty response for a given prompt.
20
47
  *
@@ -24,23 +51,82 @@ const sbg_utility_1 = require("sbg-utility");
24
51
  * @param prompt - The user message to send to the model.
25
52
  * @param apiKey - Bearer token for API authentication.
26
53
  * @param model - Model identifier (defaults to `'deepseek-v4-flash-free'`).
54
+ * @param proxyUrl - Optional proxy URL. e.g: `http://127.0.0.1:8080, https://127.0.0.1:8443, socks4://127.0.0.1:1080, socks5://127.0.0.1:1080, socks5://user:pass@127.0.0.1:1080`
27
55
  * @returns `true` if the response contains non-empty content, `false` otherwise.
56
+ *
57
+ * @example
58
+ * await checkOpenCodeApi('Hello', apiKey, 'deepseek-v4-flash-free', 'socks5://127.0.0.1:1080');
28
59
  */
29
60
  function checkOpenCodeApi(prompt_1, apiKey_1) {
30
- return __awaiter(this, arguments, void 0, function* (prompt, apiKey, model = 'deepseek-v4-flash-free') {
31
- const res = yield axios_1.default.post('https://opencode.ai/zen/v1/chat/completions', {
32
- model,
33
- messages: [{ role: 'user', content: prompt }],
34
- max_tokens: 512
35
- }, {
36
- headers: { Authorization: `Bearer ${apiKey}` }
37
- });
38
- // dump the full response for debugging
39
- const filePath = `tmp/logs/opencode-api-check-${Date.now()}.json`;
40
- (0, sbg_utility_1.writefile)(filePath, JSON.stringify(res.data, null, 2));
41
- const message = res.data.choices[0].message;
42
- const output = message.content || message.reasoning_content;
43
- const notEmptyOutput = output && output.trim().length > 0;
44
- return notEmptyOutput;
61
+ return __awaiter(this, arguments, void 0, function* (prompt, apiKey, model = 'deepseek-v4-flash-free', proxyUrl) {
62
+ var _a, _b, _c, _d, _e, _f, _g;
63
+ const debug = (0, isDebug_cjs_1.isDebug)();
64
+ const resolvedProxyUrl = getProxyUrl(proxyUrl);
65
+ let proxyAgent;
66
+ if (resolvedProxyUrl) {
67
+ const proxyUrlValue = resolvedProxyUrl;
68
+ proxyAgent = new proxy_agent_1.ProxyAgent({
69
+ getProxyForUrl: () => proxyUrlValue
70
+ });
71
+ }
72
+ try {
73
+ if (debug && resolvedProxyUrl) {
74
+ console.log(`Using proxy: ${maskProxyUrl(resolvedProxyUrl)}`);
75
+ }
76
+ const res = yield axios_1.default.post('https://opencode.ai/zen/v1/chat/completions', {
77
+ model,
78
+ messages: [{ role: 'user', content: prompt }],
79
+ max_tokens: 512
80
+ }, {
81
+ headers: {
82
+ Authorization: `Bearer ${apiKey}`,
83
+ 'Content-Type': 'application/json'
84
+ },
85
+ validateStatus: () => true,
86
+ timeout: 30000,
87
+ proxy: false,
88
+ httpAgent: proxyAgent,
89
+ httpsAgent: proxyAgent
90
+ });
91
+ if (debug) {
92
+ console.log('OpenCode status:', res.status);
93
+ }
94
+ const filePath = (0, config_cjs_1.getTempPath)('logs', `opencode-api-check-${(0, hash_cjs_1.sha256)(apiKey)}.json`);
95
+ if (debug) {
96
+ (0, sbg_utility_1.writefile)(filePath, JSON.stringify(res.data, null, 2));
97
+ console.log(`OpenCode API check response dumped to: ${filePath}`);
98
+ }
99
+ const errorType = (_b = (_a = res.data) === null || _a === void 0 ? void 0 : _a.error) === null || _b === void 0 ? void 0 : _b.type;
100
+ if (res.status === 429 && errorType === 'FreeUsageLimitError') {
101
+ if (debug) {
102
+ console.warn('OpenCode API rate limit exceeded. Skipping this key.');
103
+ }
104
+ return false;
105
+ }
106
+ if (res.status < 200 || res.status >= 300) {
107
+ if (debug) {
108
+ console.error('OpenCode API returned non-2xx response:', res.data);
109
+ }
110
+ return false;
111
+ }
112
+ const message = (_e = (_d = (_c = res.data) === null || _c === void 0 ? void 0 : _c.choices) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.message;
113
+ const output = (message === null || message === void 0 ? void 0 : message.content) || (message === null || message === void 0 ? void 0 : message.reasoning_content);
114
+ return Boolean(output && output.trim().length > 0);
115
+ }
116
+ catch (err) {
117
+ if (debug) {
118
+ console.error('OpenCode API check failed');
119
+ if (axios_1.default.isAxiosError(err)) {
120
+ console.error('Message:', err.message);
121
+ console.error('Code:', err.code);
122
+ console.error('Status:', (_f = err.response) === null || _f === void 0 ? void 0 : _f.status);
123
+ console.error('Response:', (_g = err.response) === null || _g === void 0 ? void 0 : _g.data);
124
+ }
125
+ else {
126
+ console.error(err);
127
+ }
128
+ }
129
+ return false;
130
+ }
45
131
  });
46
132
  }
@@ -1,7 +1,11 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
2
  import {
3
3
  checkOpenCodeApi
4
- } from "../../chunk-QZMGBDSA.mjs";
4
+ } from "../../chunk-BPED62FN.mjs";
5
+ import "../../chunk-B77D3SR4.mjs";
6
+ import "../../chunk-V6PTSDW5.mjs";
7
+ import "../../chunk-3T6AMFI3.mjs";
8
+ import "../../chunk-J4M5EL5P.mjs";
5
9
  import "../../chunk-QQ4A6DLD.mjs";
6
10
  export {
7
11
  checkOpenCodeApi
File without changes
File without changes
@@ -0,0 +1 @@
1
+ "use strict";
@@ -0,0 +1,7 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ init_esm_shims
4
+ } from "../../chunk-QQ4A6DLD.mjs";
5
+
6
+ // src/opencode/utils/check-api.runner.ts
7
+ init_esm_shims();