@pixelbyte-software/pixcode 1.30.2 → 1.31.1
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/LICENSE +718 -718
- package/README.de.md +248 -248
- package/README.ja.md +240 -240
- package/README.ko.md +240 -240
- package/README.md +295 -285
- package/README.ru.md +248 -248
- package/README.tr.md +250 -250
- package/README.zh-CN.md +240 -240
- package/dist/api-docs.html +879 -879
- package/dist/assets/index-BtOeB3cE.js +837 -0
- package/dist/assets/index-CDpePeIN.css +32 -0
- package/dist/assets/vendor-codemirror-CzYAOTxS.js +41 -0
- package/dist/clear-cache.html +85 -85
- package/dist/convert-icons.md +52 -52
- package/dist/favicon.png +0 -0
- package/dist/favicon.svg +7 -8
- package/dist/generate-icons.js +48 -48
- package/dist/icons/codex-white.svg +3 -3
- package/dist/icons/codex.svg +3 -3
- package/dist/icons/cursor-white.svg +11 -11
- package/dist/icons/icon-128x128.png +0 -0
- package/dist/icons/icon-128x128.svg +9 -12
- package/dist/icons/icon-144x144.png +0 -0
- package/dist/icons/icon-144x144.svg +9 -12
- package/dist/icons/icon-152x152.png +0 -0
- package/dist/icons/icon-152x152.svg +9 -12
- package/dist/icons/icon-192x192.png +0 -0
- package/dist/icons/icon-192x192.svg +9 -12
- package/dist/icons/icon-384x384.png +0 -0
- package/dist/icons/icon-384x384.svg +9 -12
- package/dist/icons/icon-512x512.png +0 -0
- package/dist/icons/icon-512x512.svg +9 -12
- package/dist/icons/icon-72x72.png +0 -0
- package/dist/icons/icon-72x72.svg +9 -12
- package/dist/icons/icon-96x96.png +0 -0
- package/dist/icons/icon-96x96.svg +9 -12
- package/dist/icons/icon-template.svg +9 -12
- package/dist/icons/qwen-ai-icon.png +0 -0
- package/dist/index.html +60 -50
- package/dist/logo.png +0 -0
- package/dist/logo.svg +11 -16
- package/dist/manifest.json +60 -60
- package/dist/sw.js +124 -124
- package/dist-server/server/claude-sdk.js +28 -5
- package/dist-server/server/claude-sdk.js.map +1 -1
- package/dist-server/server/cli.js +100 -97
- package/dist-server/server/cli.js.map +1 -1
- package/dist-server/server/daemon/manager.js +33 -33
- package/dist-server/server/daemon-manager.js +62 -62
- package/dist-server/server/database/db.js +114 -22
- package/dist-server/server/database/db.js.map +1 -1
- package/dist-server/server/database/schema.js +122 -89
- package/dist-server/server/database/schema.js.map +1 -1
- package/dist-server/server/gemini-cli.js +6 -1
- package/dist-server/server/gemini-cli.js.map +1 -1
- package/dist-server/server/index.js +346 -61
- package/dist-server/server/index.js.map +1 -1
- package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js +29 -2
- package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js.map +1 -1
- package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js +22 -2
- package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js.map +1 -1
- package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js +2 -2
- package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js.map +1 -1
- package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js +14 -2
- package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js.map +1 -1
- package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js +132 -0
- package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js.map +1 -0
- package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js +87 -0
- package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js.map +1 -0
- package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js +201 -0
- package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js.map +1 -0
- package/dist-server/server/modules/providers/list/qwen/qwen.provider.js +19 -0
- package/dist-server/server/modules/providers/list/qwen/qwen.provider.js.map +1 -0
- package/dist-server/server/modules/providers/provider.registry.js +2 -0
- package/dist-server/server/modules/providers/provider.registry.js.map +1 -1
- package/dist-server/server/modules/providers/provider.routes.js +478 -1
- package/dist-server/server/modules/providers/provider.routes.js.map +1 -1
- package/dist-server/server/modules/providers/shared/provider-configs.js +105 -0
- package/dist-server/server/modules/providers/shared/provider-configs.js.map +1 -0
- package/dist-server/server/projects.js +197 -6
- package/dist-server/server/projects.js.map +1 -1
- package/dist-server/server/qwen-code-cli.js +350 -0
- package/dist-server/server/qwen-code-cli.js.map +1 -0
- package/dist-server/server/qwen-response-handler.js +70 -0
- package/dist-server/server/qwen-response-handler.js.map +1 -0
- package/dist-server/server/routes/commands.js +25 -25
- package/dist-server/server/routes/git.js +17 -17
- package/dist-server/server/routes/network.js +116 -0
- package/dist-server/server/routes/network.js.map +1 -0
- package/dist-server/server/routes/projects.js +166 -1
- package/dist-server/server/routes/projects.js.map +1 -1
- package/dist-server/server/routes/qwen.js +23 -0
- package/dist-server/server/routes/qwen.js.map +1 -0
- package/dist-server/server/routes/taskmaster.js +419 -419
- package/dist-server/server/routes/telegram.js +119 -0
- package/dist-server/server/routes/telegram.js.map +1 -0
- package/dist-server/server/services/external-access.js +228 -0
- package/dist-server/server/services/external-access.js.map +1 -0
- package/dist-server/server/services/install-jobs.js +552 -0
- package/dist-server/server/services/install-jobs.js.map +1 -0
- package/dist-server/server/services/notification-orchestrator.js +19 -5
- package/dist-server/server/services/notification-orchestrator.js.map +1 -1
- package/dist-server/server/services/provider-credentials.js +154 -0
- package/dist-server/server/services/provider-credentials.js.map +1 -0
- package/dist-server/server/services/provider-models.js +218 -0
- package/dist-server/server/services/provider-models.js.map +1 -0
- package/dist-server/server/services/telegram/bot.js +259 -0
- package/dist-server/server/services/telegram/bot.js.map +1 -0
- package/dist-server/server/services/telegram/translations.js +160 -0
- package/dist-server/server/services/telegram/translations.js.map +1 -0
- package/dist-server/server/utils/port-access.js +196 -0
- package/dist-server/server/utils/port-access.js.map +1 -0
- package/dist-server/shared/modelConstants.js +18 -0
- package/dist-server/shared/modelConstants.js.map +1 -1
- package/package.json +177 -168
- package/scripts/fix-node-pty.js +67 -67
- package/server/claude-sdk.js +857 -834
- package/server/cli.js +940 -937
- package/server/constants/config.js +4 -4
- package/server/cursor-cli.js +342 -342
- package/server/daemon/manager.js +564 -564
- package/server/daemon-manager.js +920 -920
- package/server/database/db.js +696 -593
- package/server/database/schema.js +138 -102
- package/server/gemini-cli.js +475 -469
- package/server/gemini-response-handler.js +79 -79
- package/server/index.js +2854 -2556
- package/server/load-env.js +34 -34
- package/server/middleware/auth.js +132 -132
- package/server/modules/providers/list/claude/claude-auth.provider.ts +145 -123
- package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
- package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
- package/server/modules/providers/list/claude/claude.provider.ts +15 -15
- package/server/modules/providers/list/codex/codex-auth.provider.ts +115 -100
- package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
- package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
- package/server/modules/providers/list/codex/codex.provider.ts +15 -15
- package/server/modules/providers/list/cursor/cursor-auth.provider.ts +143 -143
- package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
- package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
- package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
- package/server/modules/providers/list/gemini/gemini-auth.provider.ts +163 -151
- package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
- package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
- package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
- package/server/modules/providers/list/qwen/qwen-auth.provider.ts +145 -0
- package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -0
- package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +218 -0
- package/server/modules/providers/list/qwen/qwen.provider.ts +21 -0
- package/server/modules/providers/provider.registry.ts +38 -36
- package/server/modules/providers/provider.routes.ts +781 -217
- package/server/modules/providers/services/mcp.service.ts +94 -94
- package/server/modules/providers/services/provider-auth.service.ts +26 -26
- package/server/modules/providers/services/sessions.service.ts +45 -45
- package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
- package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
- package/server/modules/providers/shared/provider-configs.ts +118 -0
- package/server/modules/providers/tests/mcp.test.ts +293 -293
- package/server/openai-codex.js +426 -426
- package/server/projects.js +2993 -2792
- package/server/qwen-code-cli.js +392 -0
- package/server/qwen-response-handler.js +73 -0
- package/server/routes/agent.js +1245 -1245
- package/server/routes/auth.js +134 -134
- package/server/routes/codex.js +19 -19
- package/server/routes/commands.js +554 -554
- package/server/routes/cursor.js +52 -52
- package/server/routes/gemini.js +24 -24
- package/server/routes/git.js +1488 -1488
- package/server/routes/mcp-utils.js +31 -31
- package/server/routes/messages.js +61 -61
- package/server/routes/network.js +128 -0
- package/server/routes/plugins.js +307 -307
- package/server/routes/projects.js +795 -627
- package/server/routes/qwen.js +27 -0
- package/server/routes/settings.js +286 -286
- package/server/routes/taskmaster.js +1471 -1471
- package/server/routes/telegram.js +125 -0
- package/server/routes/user.js +123 -123
- package/server/services/external-access.js +240 -0
- package/server/services/install-jobs.js +569 -0
- package/server/services/notification-orchestrator.js +242 -227
- package/server/services/provider-credentials.js +151 -0
- package/server/services/provider-models.js +225 -0
- package/server/services/telegram/bot.js +280 -0
- package/server/services/telegram/translations.js +170 -0
- package/server/services/vapid-keys.js +35 -35
- package/server/sessionManager.js +225 -225
- package/server/shared/interfaces.ts +54 -54
- package/server/shared/types.ts +172 -172
- package/server/shared/utils.ts +193 -193
- package/server/tsconfig.json +36 -36
- package/server/utils/colors.js +21 -21
- package/server/utils/commandParser.js +303 -303
- package/server/utils/frontmatter.js +18 -18
- package/server/utils/gitConfig.js +34 -34
- package/server/utils/mcp-detector.js +147 -147
- package/server/utils/plugin-loader.js +457 -457
- package/server/utils/plugin-process-manager.js +184 -184
- package/server/utils/port-access.js +209 -0
- package/server/utils/runtime-paths.js +37 -37
- package/server/utils/taskmaster-websocket.js +128 -128
- package/server/utils/url-detection.js +71 -71
- package/server/vite-daemon.js +78 -78
- package/shared/modelConstants.js +117 -97
- package/shared/networkHosts.js +22 -22
- package/dist/assets/index-C2c9QNwK.css +0 -32
- package/dist/assets/index-DyXDZED-.js +0 -1277
- package/dist/assets/vendor-codemirror-NA4v81it.js +0 -41
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-configs.js","sourceRoot":"","sources":["../../../../../server/modules/providers/shared/provider-configs.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAaH,MAAM,CAAC,MAAM,qBAAqB,GAAyC;IACzE,MAAM,EAAE;QACN;YACE,EAAE,EAAE,UAAU;YACd,KAAK,EAAE,eAAe;YACtB,YAAY,EAAE,uBAAuB;YACrC,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,wEAAwE;SACtF;QACD;YACE,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,cAAc;YAC5B,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,yEAAyE;SACvF;KACF;IACD,KAAK,EAAE;QACL;YACE,EAAE,EAAE,QAAQ;YACZ,KAAK,EAAE,aAAa;YACpB,YAAY,EAAE,oBAAoB;YAClC,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,6EAA6E;SAC3F;QACD;YACE,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,aAAa;YAC3B,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,6DAA6D;SAC3E;QACD;YACE,EAAE,EAAE,MAAM;YACV,KAAK,EAAE,WAAW;YAClB,YAAY,EAAE,kBAAkB;YAChC,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,IAAI;YACd,WAAW,EAAE,2FAA2F;SACzG;KACF;IACD,MAAM,EAAE;QACN;YACE,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,cAAc;YAC5B,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,mCAAmC;SACjD;KACF;IACD,MAAM,EAAE;QACN;YACE,EAAE,EAAE,UAAU;YACd,KAAK,EAAE,eAAe;YACtB,YAAY,EAAE,uBAAuB;YACrC,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,6EAA6E;SAC3F;QACD;YACE,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,cAAc;YAC5B,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,4DAA4D;SAC1E;KACF;IACD,IAAI,EAAE;QACJ;YACE,EAAE,EAAE,UAAU;YACd,KAAK,EAAE,eAAe;YACtB,YAAY,EAAE,qBAAqB;YACnC,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,uEAAuE;SACrF;QACD;YACE,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,YAAY;YAC1B,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,4FAA4F;SAC1G;KACF;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;AAE7E,uEAAuE;AACvE,0EAA0E;AAC1E,oCAAoC;AACpC,MAAM,CAAC,MAAM,0BAA0B,GAAG,SAAS,CAAC,CAAC,OAAO"}
|
|
@@ -240,6 +240,47 @@ function areStringArraysEqual(first, second) {
|
|
|
240
240
|
}
|
|
241
241
|
return first.every((value, index) => value === second[index]);
|
|
242
242
|
}
|
|
243
|
+
// Qwen Code mirrors Gemini CLI's on-disk layout (~/.qwen/tmp/<projectDir>/
|
|
244
|
+
// with a `.project_root` file + `chats/*.json`), because Qwen is a fork of
|
|
245
|
+
// Gemini CLI. The listing / session / message helpers below duplicate the
|
|
246
|
+
// Gemini ones rather than sharing a parametric implementation, keeping
|
|
247
|
+
// provider-specific logic discoverable in one place.
|
|
248
|
+
async function listQwenCliProjectEntries() {
|
|
249
|
+
const qwenTmpDir = path.join(os.homedir(), '.qwen', 'tmp');
|
|
250
|
+
try {
|
|
251
|
+
await fs.access(qwenTmpDir);
|
|
252
|
+
}
|
|
253
|
+
catch {
|
|
254
|
+
return [];
|
|
255
|
+
}
|
|
256
|
+
let projectDirs;
|
|
257
|
+
try {
|
|
258
|
+
projectDirs = await fs.readdir(qwenTmpDir);
|
|
259
|
+
}
|
|
260
|
+
catch {
|
|
261
|
+
return [];
|
|
262
|
+
}
|
|
263
|
+
const entries = [];
|
|
264
|
+
for (const projectDir of projectDirs) {
|
|
265
|
+
const projectRootFile = path.join(qwenTmpDir, projectDir, '.project_root');
|
|
266
|
+
let projectRoot;
|
|
267
|
+
try {
|
|
268
|
+
projectRoot = (await fs.readFile(projectRootFile, 'utf8')).trim();
|
|
269
|
+
}
|
|
270
|
+
catch {
|
|
271
|
+
continue;
|
|
272
|
+
}
|
|
273
|
+
const normalizedProjectRoot = normalizeComparablePath(projectRoot);
|
|
274
|
+
if (!normalizedProjectRoot)
|
|
275
|
+
continue;
|
|
276
|
+
entries.push({
|
|
277
|
+
projectDir,
|
|
278
|
+
projectRoot: path.resolve(projectRoot),
|
|
279
|
+
normalizedProjectRoot,
|
|
280
|
+
});
|
|
281
|
+
}
|
|
282
|
+
return entries;
|
|
283
|
+
}
|
|
243
284
|
async function listGeminiCliProjectEntries() {
|
|
244
285
|
const geminiTmpDir = path.join(os.homedir(), '.gemini', 'tmp');
|
|
245
286
|
try {
|
|
@@ -294,7 +335,7 @@ function addDiscoveredProject(discoveredProjectsByPath, projectPath, provider) {
|
|
|
294
335
|
}
|
|
295
336
|
discoveredProjectsByPath.get(normalizedProjectPath).providers.add(provider);
|
|
296
337
|
}
|
|
297
|
-
async function discoverProjectsFromHistory(codexSessionsIndexRef = null, geminiCliProjectsRef = null) {
|
|
338
|
+
async function discoverProjectsFromHistory(codexSessionsIndexRef = null, geminiCliProjectsRef = null, qwenCliProjectsRef = null) {
|
|
298
339
|
const discoveredProjectsByPath = new Map();
|
|
299
340
|
if (codexSessionsIndexRef && !codexSessionsIndexRef.sessionsByProject) {
|
|
300
341
|
codexSessionsIndexRef.sessionsByProject = await buildCodexSessionsIndex();
|
|
@@ -314,6 +355,13 @@ async function discoverProjectsFromHistory(codexSessionsIndexRef = null, geminiC
|
|
|
314
355
|
for (const entry of geminiCliEntries) {
|
|
315
356
|
addDiscoveredProject(discoveredProjectsByPath, entry.projectRoot, 'gemini');
|
|
316
357
|
}
|
|
358
|
+
if (qwenCliProjectsRef && !qwenCliProjectsRef.entries) {
|
|
359
|
+
qwenCliProjectsRef.entries = await listQwenCliProjectEntries();
|
|
360
|
+
}
|
|
361
|
+
const qwenCliEntries = qwenCliProjectsRef?.entries || await listQwenCliProjectEntries();
|
|
362
|
+
for (const entry of qwenCliEntries) {
|
|
363
|
+
addDiscoveredProject(discoveredProjectsByPath, entry.projectRoot, 'qwen');
|
|
364
|
+
}
|
|
317
365
|
for (const session of sessionManager.sessions.values()) {
|
|
318
366
|
if (session?.projectPath) {
|
|
319
367
|
addDiscoveredProject(discoveredProjectsByPath, session.projectPath, 'gemini');
|
|
@@ -355,8 +403,8 @@ function mergeDiscoveredProjectsIntoConfig(config, discoveredProjects) {
|
|
|
355
403
|
}
|
|
356
404
|
return { config: nextConfig, changed };
|
|
357
405
|
}
|
|
358
|
-
async function syncAutoDiscoveredProjects(config, codexSessionsIndexRef = null, geminiCliProjectsRef = null) {
|
|
359
|
-
const discoveredProjects = await discoverProjectsFromHistory(codexSessionsIndexRef, geminiCliProjectsRef);
|
|
406
|
+
async function syncAutoDiscoveredProjects(config, codexSessionsIndexRef = null, geminiCliProjectsRef = null, qwenCliProjectsRef = null) {
|
|
407
|
+
const discoveredProjects = await discoverProjectsFromHistory(codexSessionsIndexRef, geminiCliProjectsRef, qwenCliProjectsRef);
|
|
360
408
|
if (discoveredProjects.length === 0) {
|
|
361
409
|
return config;
|
|
362
410
|
}
|
|
@@ -518,11 +566,12 @@ async function getProjects(progressCallback = null) {
|
|
|
518
566
|
const existingProjects = new Set();
|
|
519
567
|
const codexSessionsIndexRef = { sessionsByProject: null };
|
|
520
568
|
const geminiCliProjectsRef = { entries: null };
|
|
569
|
+
const qwenCliProjectsRef = { entries: null };
|
|
521
570
|
let totalProjects = 0;
|
|
522
571
|
let processedProjects = 0;
|
|
523
572
|
let directories = [];
|
|
524
573
|
try {
|
|
525
|
-
config = await syncAutoDiscoveredProjects(config, codexSessionsIndexRef, geminiCliProjectsRef);
|
|
574
|
+
config = await syncAutoDiscoveredProjects(config, codexSessionsIndexRef, geminiCliProjectsRef, qwenCliProjectsRef);
|
|
526
575
|
}
|
|
527
576
|
catch (error) {
|
|
528
577
|
console.warn('Failed to sync auto-discovered projects:', error.message);
|
|
@@ -576,6 +625,7 @@ async function getProjects(progressCallback = null) {
|
|
|
576
625
|
detectedAt: projectConfig.detectedAt || null,
|
|
577
626
|
sessions: [],
|
|
578
627
|
geminiSessions: [],
|
|
628
|
+
qwenSessions: [],
|
|
579
629
|
sessionMeta: {
|
|
580
630
|
hasMore: false,
|
|
581
631
|
total: 0
|
|
@@ -629,6 +679,21 @@ async function getProjects(progressCallback = null) {
|
|
|
629
679
|
project.geminiSessions = [];
|
|
630
680
|
}
|
|
631
681
|
applyCustomSessionNames(project.geminiSessions, 'gemini');
|
|
682
|
+
try {
|
|
683
|
+
// Qwen Code sessions — sourced purely from ~/.qwen/tmp since the adapter
|
|
684
|
+
// uses its own session IDs. Mirrors the Gemini branch above; sessionManager
|
|
685
|
+
// handles both Gemini and Qwen live sessions so UI continuations land in
|
|
686
|
+
// the right place regardless of provider.
|
|
687
|
+
const qwenCliSessions = await getQwenCliSessions(actualProjectDir, {
|
|
688
|
+
qwenCliProjectsRef,
|
|
689
|
+
});
|
|
690
|
+
project.qwenSessions = qwenCliSessions;
|
|
691
|
+
}
|
|
692
|
+
catch (e) {
|
|
693
|
+
console.warn(`Could not load Qwen Code sessions for project ${entry.name}:`, e.message);
|
|
694
|
+
project.qwenSessions = [];
|
|
695
|
+
}
|
|
696
|
+
applyCustomSessionNames(project.qwenSessions, 'qwen');
|
|
632
697
|
try {
|
|
633
698
|
const taskMasterResult = await detectTaskMasterFolder(actualProjectDir);
|
|
634
699
|
project.taskmaster = {
|
|
@@ -687,6 +752,7 @@ async function getProjects(progressCallback = null) {
|
|
|
687
752
|
detectedAt: projectConfig.detectedAt || null,
|
|
688
753
|
sessions: [],
|
|
689
754
|
geminiSessions: [],
|
|
755
|
+
qwenSessions: [],
|
|
690
756
|
sessionMeta: {
|
|
691
757
|
hasMore: false,
|
|
692
758
|
total: 0
|
|
@@ -710,6 +776,15 @@ async function getProjects(progressCallback = null) {
|
|
|
710
776
|
console.warn(`Could not load Codex sessions for tracked project ${projectName}:`, e.message);
|
|
711
777
|
}
|
|
712
778
|
applyCustomSessionNames(project.codexSessions, 'codex');
|
|
779
|
+
try {
|
|
780
|
+
project.qwenSessions = await getQwenCliSessions(actualProjectDir, {
|
|
781
|
+
qwenCliProjectsRef,
|
|
782
|
+
});
|
|
783
|
+
}
|
|
784
|
+
catch (e) {
|
|
785
|
+
console.warn(`Could not load Qwen Code sessions for tracked project ${projectName}:`, e.message);
|
|
786
|
+
}
|
|
787
|
+
applyCustomSessionNames(project.qwenSessions, 'qwen');
|
|
713
788
|
try {
|
|
714
789
|
const uiSessions = sessionManager.getProjectSessions(actualProjectDir) || [];
|
|
715
790
|
const cliSessions = await getGeminiCliSessions(actualProjectDir, {
|
|
@@ -1866,6 +1941,7 @@ async function searchConversations(query, limit = 50, onProjectResult = null, si
|
|
|
1866
1941
|
let config = await loadProjectConfig();
|
|
1867
1942
|
const codexSessionsIndexRef = { sessionsByProject: null };
|
|
1868
1943
|
const geminiCliProjectsRef = { entries: null };
|
|
1944
|
+
const qwenCliProjectsRef = { entries: null };
|
|
1869
1945
|
const results = [];
|
|
1870
1946
|
let totalMatches = 0;
|
|
1871
1947
|
const words = safeQuery.toLowerCase().split(/\s+/).filter(w => w.length > 0);
|
|
@@ -1944,7 +2020,7 @@ async function searchConversations(query, limit = 50, onProjectResult = null, si
|
|
|
1944
2020
|
return { snippet, highlights: merged };
|
|
1945
2021
|
};
|
|
1946
2022
|
try {
|
|
1947
|
-
config = await syncAutoDiscoveredProjects(config, codexSessionsIndexRef, geminiCliProjectsRef);
|
|
2023
|
+
config = await syncAutoDiscoveredProjects(config, codexSessionsIndexRef, geminiCliProjectsRef, qwenCliProjectsRef);
|
|
1948
2024
|
}
|
|
1949
2025
|
catch (error) {
|
|
1950
2026
|
console.warn('Failed to sync auto-discovered projects for search:', error.message);
|
|
@@ -2377,6 +2453,121 @@ async function searchGeminiSessionsForProject(projectPath, projectResult, allWor
|
|
|
2377
2453
|
}
|
|
2378
2454
|
}
|
|
2379
2455
|
}
|
|
2456
|
+
// Qwen Code session listing — same chats/*.json payload Gemini emits since
|
|
2457
|
+
// Qwen is a Gemini CLI fork. Kept as its own function (instead of a shared
|
|
2458
|
+
// parametric helper) so future Qwen-specific protocol drift has one
|
|
2459
|
+
// obvious place to land.
|
|
2460
|
+
async function getQwenCliSessions(projectPath, options = {}) {
|
|
2461
|
+
const { qwenCliProjectsRef = null } = options;
|
|
2462
|
+
const normalizedProjectPath = normalizeComparablePath(projectPath);
|
|
2463
|
+
if (!normalizedProjectPath)
|
|
2464
|
+
return [];
|
|
2465
|
+
const sessions = [];
|
|
2466
|
+
const qwenTmpDir = path.join(os.homedir(), '.qwen', 'tmp');
|
|
2467
|
+
if (qwenCliProjectsRef && !qwenCliProjectsRef.entries) {
|
|
2468
|
+
qwenCliProjectsRef.entries = await listQwenCliProjectEntries();
|
|
2469
|
+
}
|
|
2470
|
+
const qwenCliEntries = qwenCliProjectsRef?.entries || await listQwenCliProjectEntries();
|
|
2471
|
+
for (const entry of qwenCliEntries) {
|
|
2472
|
+
if (entry.normalizedProjectRoot !== normalizedProjectPath)
|
|
2473
|
+
continue;
|
|
2474
|
+
const projectDir = entry.projectDir;
|
|
2475
|
+
const chatsDir = path.join(qwenTmpDir, projectDir, 'chats');
|
|
2476
|
+
let chatFiles;
|
|
2477
|
+
try {
|
|
2478
|
+
chatFiles = await fs.readdir(chatsDir);
|
|
2479
|
+
}
|
|
2480
|
+
catch {
|
|
2481
|
+
continue;
|
|
2482
|
+
}
|
|
2483
|
+
for (const chatFile of chatFiles) {
|
|
2484
|
+
if (!chatFile.endsWith('.json'))
|
|
2485
|
+
continue;
|
|
2486
|
+
try {
|
|
2487
|
+
const filePath = path.join(chatsDir, chatFile);
|
|
2488
|
+
const data = await fs.readFile(filePath, 'utf8');
|
|
2489
|
+
const session = JSON.parse(data);
|
|
2490
|
+
if (!session.messages || !Array.isArray(session.messages))
|
|
2491
|
+
continue;
|
|
2492
|
+
const sessionId = session.sessionId || chatFile.replace('.json', '');
|
|
2493
|
+
const firstUserMsg = session.messages.find(m => m.type === 'user');
|
|
2494
|
+
let summary = 'Qwen Code Session';
|
|
2495
|
+
if (firstUserMsg) {
|
|
2496
|
+
const text = Array.isArray(firstUserMsg.content)
|
|
2497
|
+
? firstUserMsg.content.filter(p => p.text).map(p => p.text).join(' ')
|
|
2498
|
+
: (typeof firstUserMsg.content === 'string' ? firstUserMsg.content : '');
|
|
2499
|
+
if (text) {
|
|
2500
|
+
summary = text.length > 50 ? text.substring(0, 50) + '...' : text;
|
|
2501
|
+
}
|
|
2502
|
+
}
|
|
2503
|
+
sessions.push({
|
|
2504
|
+
id: sessionId,
|
|
2505
|
+
summary,
|
|
2506
|
+
messageCount: session.messages.length,
|
|
2507
|
+
lastActivity: session.lastUpdated || session.startTime || null,
|
|
2508
|
+
provider: 'qwen'
|
|
2509
|
+
});
|
|
2510
|
+
}
|
|
2511
|
+
catch {
|
|
2512
|
+
continue;
|
|
2513
|
+
}
|
|
2514
|
+
}
|
|
2515
|
+
}
|
|
2516
|
+
return sessions.sort((a, b) => new Date(b.lastActivity || 0) - new Date(a.lastActivity || 0));
|
|
2517
|
+
}
|
|
2518
|
+
async function getQwenCliSessionMessages(sessionId) {
|
|
2519
|
+
const qwenTmpDir = path.join(os.homedir(), '.qwen', 'tmp');
|
|
2520
|
+
let projectDirs;
|
|
2521
|
+
try {
|
|
2522
|
+
projectDirs = await fs.readdir(qwenTmpDir);
|
|
2523
|
+
}
|
|
2524
|
+
catch {
|
|
2525
|
+
return [];
|
|
2526
|
+
}
|
|
2527
|
+
for (const projectDir of projectDirs) {
|
|
2528
|
+
const chatsDir = path.join(qwenTmpDir, projectDir, 'chats');
|
|
2529
|
+
let chatFiles;
|
|
2530
|
+
try {
|
|
2531
|
+
chatFiles = await fs.readdir(chatsDir);
|
|
2532
|
+
}
|
|
2533
|
+
catch {
|
|
2534
|
+
continue;
|
|
2535
|
+
}
|
|
2536
|
+
for (const chatFile of chatFiles) {
|
|
2537
|
+
if (!chatFile.endsWith('.json'))
|
|
2538
|
+
continue;
|
|
2539
|
+
try {
|
|
2540
|
+
const filePath = path.join(chatsDir, chatFile);
|
|
2541
|
+
const data = await fs.readFile(filePath, 'utf8');
|
|
2542
|
+
const session = JSON.parse(data);
|
|
2543
|
+
const fileSessionId = session.sessionId || chatFile.replace('.json', '');
|
|
2544
|
+
if (fileSessionId !== sessionId)
|
|
2545
|
+
continue;
|
|
2546
|
+
return (session.messages || []).map(msg => {
|
|
2547
|
+
const role = msg.type === 'user' ? 'user'
|
|
2548
|
+
: (msg.type === 'qwen' || msg.type === 'assistant') ? 'assistant'
|
|
2549
|
+
: msg.type;
|
|
2550
|
+
let content = '';
|
|
2551
|
+
if (typeof msg.content === 'string') {
|
|
2552
|
+
content = msg.content;
|
|
2553
|
+
}
|
|
2554
|
+
else if (Array.isArray(msg.content)) {
|
|
2555
|
+
content = msg.content.filter(p => p.text).map(p => p.text).join('\n');
|
|
2556
|
+
}
|
|
2557
|
+
return {
|
|
2558
|
+
type: 'message',
|
|
2559
|
+
message: { role, content },
|
|
2560
|
+
timestamp: msg.timestamp || null
|
|
2561
|
+
};
|
|
2562
|
+
});
|
|
2563
|
+
}
|
|
2564
|
+
catch {
|
|
2565
|
+
continue;
|
|
2566
|
+
}
|
|
2567
|
+
}
|
|
2568
|
+
}
|
|
2569
|
+
return [];
|
|
2570
|
+
}
|
|
2380
2571
|
async function getGeminiCliSessions(projectPath, options = {}) {
|
|
2381
2572
|
const { geminiCliProjectsRef = null } = options;
|
|
2382
2573
|
const normalizedProjectPath = normalizeComparablePath(projectPath);
|
|
@@ -2488,5 +2679,5 @@ async function getGeminiCliSessionMessages(sessionId) {
|
|
|
2488
2679
|
}
|
|
2489
2680
|
return [];
|
|
2490
2681
|
}
|
|
2491
|
-
export { getProjects, getSessions, getSessionMessages, parseJsonlSessions, renameProject, deleteSession, isProjectEmpty, deleteProject, addProjectManually, loadProjectConfig, saveProjectConfig, extractProjectDirectory, clearProjectDirectoryCache, getCodexSessions, getCodexSessionMessages, deleteCodexSession, getGeminiCliSessions, getGeminiCliSessionMessages, searchConversations };
|
|
2682
|
+
export { getProjects, getSessions, getSessionMessages, parseJsonlSessions, renameProject, deleteSession, isProjectEmpty, deleteProject, addProjectManually, loadProjectConfig, saveProjectConfig, extractProjectDirectory, clearProjectDirectoryCache, getCodexSessions, getCodexSessionMessages, deleteCodexSession, getGeminiCliSessions, getGeminiCliSessionMessages, getQwenCliSessions, getQwenCliSessionMessages, searchConversations };
|
|
2492
2683
|
//# sourceMappingURL=projects.js.map
|