agent-mp 0.4.11 → 0.4.12
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/dist/core/engine.js +24 -42
- package/package.json +1 -1
package/dist/core/engine.js
CHANGED
|
@@ -6,7 +6,7 @@ import { CLI_REGISTRY } from '../types.js';
|
|
|
6
6
|
import { writeJson, readJson, fileExists, writeFile, readFile } from '../utils/fs.js';
|
|
7
7
|
import { log } from '../utils/logger.js';
|
|
8
8
|
import chalk from 'chalk';
|
|
9
|
-
import {
|
|
9
|
+
import { callQwenAPIFromCreds } from '../utils/qwen-auth.js';
|
|
10
10
|
import * as fs from 'fs/promises';
|
|
11
11
|
/** Thrown when a slash command inside a conversation requests exit */
|
|
12
12
|
export class ExitError extends Error {
|
|
@@ -89,12 +89,9 @@ async function ask(prompt, rl, fi) {
|
|
|
89
89
|
return new Promise((resolve) => tempRl.question(prompt, (a) => { tempRl.close(); resolve(a); }));
|
|
90
90
|
}
|
|
91
91
|
function runCli(cmd, prompt, timeoutMs = 600000, envOverride, onData) {
|
|
92
|
-
// Si el comando es "qwen-direct",
|
|
92
|
+
// Si el comando es "qwen-direct", redirigir a qwen CLI subprocess
|
|
93
93
|
if (cmd.startsWith('qwen-direct')) {
|
|
94
|
-
|
|
95
|
-
return callQwenAPI(prompt, model)
|
|
96
|
-
.then(output => ({ output, exitCode: 0 }))
|
|
97
|
-
.catch(err => ({ output: `Error: ${err.message}`, exitCode: 1 }));
|
|
94
|
+
return runCli('qwen --yolo', prompt, timeoutMs, envOverride, onData);
|
|
98
95
|
}
|
|
99
96
|
return new Promise((resolve, reject) => {
|
|
100
97
|
const parts = cmd.trim().split(/\s+/);
|
|
@@ -300,24 +297,18 @@ INSTRUCCIONES:
|
|
|
300
297
|
const envOverride = {};
|
|
301
298
|
let res;
|
|
302
299
|
if (this.coordinatorCmd.startsWith('qwen')) {
|
|
303
|
-
// Use
|
|
304
|
-
|
|
305
|
-
const
|
|
306
|
-
const sp = this._startSpinner(`coordinador ${model}`);
|
|
300
|
+
// Use qwen CLI subprocess — direct API calls fail with 401 for OAuth tokens
|
|
301
|
+
const coCmd = this.coordinatorCmd.includes('--yolo') ? this.coordinatorCmd : `${this.coordinatorCmd} --yolo`;
|
|
302
|
+
const sp = this._startSpinner(`coordinador`);
|
|
307
303
|
try {
|
|
308
|
-
|
|
304
|
+
res = await runCli(coCmd, prompt, 600000, envOverride, (chunk) => {
|
|
305
|
+
this._parseChunk(chunk).forEach(l => sp.push(l));
|
|
306
|
+
});
|
|
309
307
|
sp.stop();
|
|
310
|
-
return result;
|
|
311
308
|
}
|
|
312
309
|
catch (err) {
|
|
313
310
|
sp.stop();
|
|
314
|
-
|
|
315
|
-
console.log(chalk.red('\n ✗ Sesión Qwen expirada.'));
|
|
316
|
-
console.log(chalk.yellow(' Ejecutá: /login para re-autenticarte.\n'));
|
|
317
|
-
}
|
|
318
|
-
else {
|
|
319
|
-
console.log(chalk.red(`\n ✗ Error Qwen: ${err.message}`));
|
|
320
|
-
}
|
|
311
|
+
console.log(chalk.red(`\n ✗ Error coordinador: ${err.message}`));
|
|
321
312
|
return '';
|
|
322
313
|
}
|
|
323
314
|
}
|
|
@@ -583,28 +574,19 @@ INSTRUCCIONES:
|
|
|
583
574
|
}
|
|
584
575
|
}
|
|
585
576
|
}
|
|
586
|
-
// Try global fallback — use
|
|
577
|
+
// Try global fallback — use CLI subprocess (direct API calls fail with 401 for OAuth tokens)
|
|
587
578
|
if (this.config.fallback_global) {
|
|
588
579
|
const fb = this.config.fallback_global;
|
|
589
580
|
log.warn(`Using global fallback: ${fb.cli} (${fb.model})`);
|
|
590
581
|
const sp = this._startSpinner(`${fb.cli} ${fb.model} (fallback)`);
|
|
591
|
-
let lineBuf = '';
|
|
592
|
-
const onChunk = (delta) => {
|
|
593
|
-
lineBuf += delta;
|
|
594
|
-
const lines = lineBuf.split('\n');
|
|
595
|
-
lineBuf = lines.pop() || '';
|
|
596
|
-
for (const l of lines) {
|
|
597
|
-
if (l.trim())
|
|
598
|
-
sp.push(l.trim());
|
|
599
|
-
}
|
|
600
|
-
};
|
|
601
582
|
try {
|
|
602
|
-
const
|
|
603
|
-
|
|
604
|
-
sp.push(
|
|
583
|
+
const fbCmd = fb.cli.includes('--yolo') ? fb.cli : `${fb.cli} --yolo`;
|
|
584
|
+
const globalResult = await runCli(fbCmd, rolePrompt, 600000, undefined, (chunk) => {
|
|
585
|
+
this._parseChunk(chunk).forEach(l => sp.push(l));
|
|
586
|
+
});
|
|
605
587
|
sp.stop();
|
|
606
|
-
trackTokens(globalResult, fb.cli, fb.model);
|
|
607
|
-
return globalResult;
|
|
588
|
+
trackTokens(globalResult.output, fb.cli, fb.model);
|
|
589
|
+
return globalResult.output;
|
|
608
590
|
}
|
|
609
591
|
catch (err) {
|
|
610
592
|
sp.stop();
|
|
@@ -1061,17 +1043,17 @@ REGLAS:
|
|
|
1061
1043
|
let result;
|
|
1062
1044
|
const sp = this._startSpinner(`agent-explorer ${role.model}`);
|
|
1063
1045
|
try {
|
|
1064
|
-
|
|
1046
|
+
// Use qwen CLI subprocess — direct API calls fail with 401 for OAuth tokens
|
|
1047
|
+
const explorerCliRes = await runCli('qwen --yolo', prompt, 600000, undefined, (chunk) => {
|
|
1048
|
+
this._parseChunk(chunk).forEach(l => sp.push(l));
|
|
1049
|
+
});
|
|
1050
|
+
result = explorerCliRes.output;
|
|
1065
1051
|
sp.stop();
|
|
1066
1052
|
}
|
|
1067
1053
|
catch (err) {
|
|
1068
1054
|
sp.stop();
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
console.log(chalk.yellow(' Ejecutá: agent-mp --login (o agent-explorer --login)\n'));
|
|
1072
|
-
return '';
|
|
1073
|
-
}
|
|
1074
|
-
throw err;
|
|
1055
|
+
console.log(chalk.red(`\n ✗ Error explorer: ${err.message}`));
|
|
1056
|
+
return '';
|
|
1075
1057
|
}
|
|
1076
1058
|
try {
|
|
1077
1059
|
await writeFile(path.join(contextDir, 'explorer-last.md'), `# Explorer Report\n\nTask: ${effectiveTask}\nDate: ${new Date().toISOString()}\n\n${result}\n`);
|