@pixelbyte-software/pixcode 1.30.2 → 1.31.0

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 (202) hide show
  1. package/LICENSE +718 -718
  2. package/README.de.md +248 -248
  3. package/README.ja.md +240 -240
  4. package/README.ko.md +240 -240
  5. package/README.md +295 -285
  6. package/README.ru.md +248 -248
  7. package/README.tr.md +250 -250
  8. package/README.zh-CN.md +240 -240
  9. package/dist/api-docs.html +879 -879
  10. package/dist/assets/index-BRRJ47XQ.css +32 -0
  11. package/dist/assets/index-EQohwyiC.js +837 -0
  12. package/dist/clear-cache.html +85 -85
  13. package/dist/convert-icons.md +52 -52
  14. package/dist/favicon.png +0 -0
  15. package/dist/favicon.svg +7 -8
  16. package/dist/generate-icons.js +48 -48
  17. package/dist/icons/codex-white.svg +3 -3
  18. package/dist/icons/codex.svg +3 -3
  19. package/dist/icons/cursor-white.svg +11 -11
  20. package/dist/icons/icon-128x128.png +0 -0
  21. package/dist/icons/icon-128x128.svg +9 -12
  22. package/dist/icons/icon-144x144.png +0 -0
  23. package/dist/icons/icon-144x144.svg +9 -12
  24. package/dist/icons/icon-152x152.png +0 -0
  25. package/dist/icons/icon-152x152.svg +9 -12
  26. package/dist/icons/icon-192x192.png +0 -0
  27. package/dist/icons/icon-192x192.svg +9 -12
  28. package/dist/icons/icon-384x384.png +0 -0
  29. package/dist/icons/icon-384x384.svg +9 -12
  30. package/dist/icons/icon-512x512.png +0 -0
  31. package/dist/icons/icon-512x512.svg +9 -12
  32. package/dist/icons/icon-72x72.png +0 -0
  33. package/dist/icons/icon-72x72.svg +9 -12
  34. package/dist/icons/icon-96x96.png +0 -0
  35. package/dist/icons/icon-96x96.svg +9 -12
  36. package/dist/icons/icon-template.svg +9 -12
  37. package/dist/icons/qwen-ai-icon.png +0 -0
  38. package/dist/index.html +59 -49
  39. package/dist/logo.png +0 -0
  40. package/dist/logo.svg +11 -16
  41. package/dist/manifest.json +60 -60
  42. package/dist/sw.js +124 -124
  43. package/dist-server/server/cli.js +100 -97
  44. package/dist-server/server/cli.js.map +1 -1
  45. package/dist-server/server/daemon/manager.js +33 -33
  46. package/dist-server/server/daemon-manager.js +62 -62
  47. package/dist-server/server/database/db.js +114 -22
  48. package/dist-server/server/database/db.js.map +1 -1
  49. package/dist-server/server/database/schema.js +122 -89
  50. package/dist-server/server/database/schema.js.map +1 -1
  51. package/dist-server/server/gemini-cli.js +6 -1
  52. package/dist-server/server/gemini-cli.js.map +1 -1
  53. package/dist-server/server/index.js +234 -64
  54. package/dist-server/server/index.js.map +1 -1
  55. package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js +29 -2
  56. package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js.map +1 -1
  57. package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js +22 -2
  58. package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js.map +1 -1
  59. package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js +2 -2
  60. package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js.map +1 -1
  61. package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js +14 -2
  62. package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js.map +1 -1
  63. package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js +132 -0
  64. package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js.map +1 -0
  65. package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js +87 -0
  66. package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js.map +1 -0
  67. package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js +201 -0
  68. package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js.map +1 -0
  69. package/dist-server/server/modules/providers/list/qwen/qwen.provider.js +19 -0
  70. package/dist-server/server/modules/providers/list/qwen/qwen.provider.js.map +1 -0
  71. package/dist-server/server/modules/providers/provider.registry.js +2 -0
  72. package/dist-server/server/modules/providers/provider.registry.js.map +1 -1
  73. package/dist-server/server/modules/providers/provider.routes.js +310 -1
  74. package/dist-server/server/modules/providers/provider.routes.js.map +1 -1
  75. package/dist-server/server/projects.js +197 -6
  76. package/dist-server/server/projects.js.map +1 -1
  77. package/dist-server/server/qwen-code-cli.js +350 -0
  78. package/dist-server/server/qwen-code-cli.js.map +1 -0
  79. package/dist-server/server/qwen-response-handler.js +70 -0
  80. package/dist-server/server/qwen-response-handler.js.map +1 -0
  81. package/dist-server/server/routes/commands.js +25 -25
  82. package/dist-server/server/routes/git.js +17 -17
  83. package/dist-server/server/routes/network.js +116 -0
  84. package/dist-server/server/routes/network.js.map +1 -0
  85. package/dist-server/server/routes/projects.js +43 -0
  86. package/dist-server/server/routes/projects.js.map +1 -1
  87. package/dist-server/server/routes/qwen.js +23 -0
  88. package/dist-server/server/routes/qwen.js.map +1 -0
  89. package/dist-server/server/routes/taskmaster.js +419 -419
  90. package/dist-server/server/routes/telegram.js +119 -0
  91. package/dist-server/server/routes/telegram.js.map +1 -0
  92. package/dist-server/server/services/external-access.js +228 -0
  93. package/dist-server/server/services/external-access.js.map +1 -0
  94. package/dist-server/server/services/install-jobs.js +394 -0
  95. package/dist-server/server/services/install-jobs.js.map +1 -0
  96. package/dist-server/server/services/notification-orchestrator.js +19 -5
  97. package/dist-server/server/services/notification-orchestrator.js.map +1 -1
  98. package/dist-server/server/services/provider-credentials.js +154 -0
  99. package/dist-server/server/services/provider-credentials.js.map +1 -0
  100. package/dist-server/server/services/provider-models.js +218 -0
  101. package/dist-server/server/services/provider-models.js.map +1 -0
  102. package/dist-server/server/services/telegram/bot.js +259 -0
  103. package/dist-server/server/services/telegram/bot.js.map +1 -0
  104. package/dist-server/server/services/telegram/translations.js +160 -0
  105. package/dist-server/server/services/telegram/translations.js.map +1 -0
  106. package/dist-server/server/utils/port-access.js +196 -0
  107. package/dist-server/server/utils/port-access.js.map +1 -0
  108. package/dist-server/shared/modelConstants.js +18 -0
  109. package/dist-server/shared/modelConstants.js.map +1 -1
  110. package/package.json +177 -168
  111. package/scripts/fix-node-pty.js +67 -67
  112. package/server/claude-sdk.js +834 -834
  113. package/server/cli.js +940 -937
  114. package/server/constants/config.js +4 -4
  115. package/server/cursor-cli.js +342 -342
  116. package/server/daemon/manager.js +564 -564
  117. package/server/daemon-manager.js +920 -920
  118. package/server/database/db.js +696 -593
  119. package/server/database/schema.js +138 -102
  120. package/server/gemini-cli.js +475 -469
  121. package/server/gemini-response-handler.js +79 -79
  122. package/server/index.js +2730 -2556
  123. package/server/load-env.js +34 -34
  124. package/server/middleware/auth.js +132 -132
  125. package/server/modules/providers/list/claude/claude-auth.provider.ts +145 -123
  126. package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
  127. package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
  128. package/server/modules/providers/list/claude/claude.provider.ts +15 -15
  129. package/server/modules/providers/list/codex/codex-auth.provider.ts +115 -100
  130. package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
  131. package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
  132. package/server/modules/providers/list/codex/codex.provider.ts +15 -15
  133. package/server/modules/providers/list/cursor/cursor-auth.provider.ts +143 -143
  134. package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
  135. package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
  136. package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
  137. package/server/modules/providers/list/gemini/gemini-auth.provider.ts +163 -151
  138. package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
  139. package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
  140. package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
  141. package/server/modules/providers/list/qwen/qwen-auth.provider.ts +145 -0
  142. package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -0
  143. package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +218 -0
  144. package/server/modules/providers/list/qwen/qwen.provider.ts +21 -0
  145. package/server/modules/providers/provider.registry.ts +38 -36
  146. package/server/modules/providers/provider.routes.ts +583 -217
  147. package/server/modules/providers/services/mcp.service.ts +94 -94
  148. package/server/modules/providers/services/provider-auth.service.ts +26 -26
  149. package/server/modules/providers/services/sessions.service.ts +45 -45
  150. package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
  151. package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
  152. package/server/modules/providers/tests/mcp.test.ts +293 -293
  153. package/server/openai-codex.js +426 -426
  154. package/server/projects.js +2993 -2792
  155. package/server/qwen-code-cli.js +392 -0
  156. package/server/qwen-response-handler.js +73 -0
  157. package/server/routes/agent.js +1245 -1245
  158. package/server/routes/auth.js +134 -134
  159. package/server/routes/codex.js +19 -19
  160. package/server/routes/commands.js +554 -554
  161. package/server/routes/cursor.js +52 -52
  162. package/server/routes/gemini.js +24 -24
  163. package/server/routes/git.js +1488 -1488
  164. package/server/routes/mcp-utils.js +31 -31
  165. package/server/routes/messages.js +61 -61
  166. package/server/routes/network.js +128 -0
  167. package/server/routes/plugins.js +307 -307
  168. package/server/routes/projects.js +675 -627
  169. package/server/routes/qwen.js +27 -0
  170. package/server/routes/settings.js +286 -286
  171. package/server/routes/taskmaster.js +1471 -1471
  172. package/server/routes/telegram.js +125 -0
  173. package/server/routes/user.js +123 -123
  174. package/server/services/external-access.js +240 -0
  175. package/server/services/install-jobs.js +410 -0
  176. package/server/services/notification-orchestrator.js +242 -227
  177. package/server/services/provider-credentials.js +151 -0
  178. package/server/services/provider-models.js +225 -0
  179. package/server/services/telegram/bot.js +280 -0
  180. package/server/services/telegram/translations.js +170 -0
  181. package/server/services/vapid-keys.js +35 -35
  182. package/server/sessionManager.js +225 -225
  183. package/server/shared/interfaces.ts +54 -54
  184. package/server/shared/types.ts +172 -172
  185. package/server/shared/utils.ts +193 -193
  186. package/server/tsconfig.json +36 -36
  187. package/server/utils/colors.js +21 -21
  188. package/server/utils/commandParser.js +303 -303
  189. package/server/utils/frontmatter.js +18 -18
  190. package/server/utils/gitConfig.js +34 -34
  191. package/server/utils/mcp-detector.js +147 -147
  192. package/server/utils/plugin-loader.js +457 -457
  193. package/server/utils/plugin-process-manager.js +184 -184
  194. package/server/utils/port-access.js +209 -0
  195. package/server/utils/runtime-paths.js +37 -37
  196. package/server/utils/taskmaster-websocket.js +128 -128
  197. package/server/utils/url-detection.js +71 -71
  198. package/server/vite-daemon.js +78 -78
  199. package/shared/modelConstants.js +117 -97
  200. package/shared/networkHosts.js +22 -22
  201. package/dist/assets/index-C2c9QNwK.css +0 -32
  202. package/dist/assets/index-DyXDZED-.js +0 -1277
@@ -1,94 +1,94 @@
1
- import os from 'node:os';
2
-
3
- import { providerRegistry } from '@/modules/providers/provider.registry.js';
4
- import type { LLMProvider, McpScope, ProviderMcpServer, UpsertProviderMcpServerInput } from '@/shared/types.js';
5
- import { AppError } from '@/shared/utils.js';
6
-
7
- /** Cursor MCP is not supported on Windows hosts (no Cursor CLI integration). */
8
- function includeProviderInGlobalMcp(providerId: LLMProvider): boolean {
9
- if (providerId === 'cursor' && os.platform() === 'win32') {
10
- return false;
11
- }
12
-
13
- return true;
14
- }
15
-
16
-
17
- export const providerMcpService = {
18
- /**
19
- * Lists MCP servers for one provider grouped by supported scopes.
20
- */
21
- async listProviderMcpServers(
22
- providerName: string,
23
- options?: { workspacePath?: string },
24
- ): Promise<Record<McpScope, ProviderMcpServer[]>> {
25
- const provider = providerRegistry.resolveProvider(providerName);
26
- return provider.mcp.listServers(options);
27
- },
28
-
29
- /**
30
- * Lists MCP servers for one provider scope.
31
- */
32
- async listProviderMcpServersForScope(
33
- providerName: string,
34
- scope: McpScope,
35
- options?: { workspacePath?: string },
36
- ): Promise<ProviderMcpServer[]> {
37
- const provider = providerRegistry.resolveProvider(providerName);
38
- return provider.mcp.listServersForScope(scope, options);
39
- },
40
-
41
- /**
42
- * Adds or updates one provider MCP server.
43
- */
44
- async upsertProviderMcpServer(
45
- providerName: string,
46
- input: UpsertProviderMcpServerInput,
47
- ): Promise<ProviderMcpServer> {
48
- const provider = providerRegistry.resolveProvider(providerName);
49
- return provider.mcp.upsertServer(input);
50
- },
51
-
52
- /**
53
- * Removes one provider MCP server.
54
- */
55
- async removeProviderMcpServer(
56
- providerName: string,
57
- input: { name: string; scope?: McpScope; workspacePath?: string },
58
- ): Promise<{ removed: boolean; provider: LLMProvider; name: string; scope: McpScope }> {
59
- const provider = providerRegistry.resolveProvider(providerName);
60
- return provider.mcp.removeServer(input);
61
- },
62
-
63
- /**
64
- * Adds one HTTP/stdio MCP server to every provider.
65
- */
66
- async addMcpServerToAllProviders(
67
- input: Omit<UpsertProviderMcpServerInput, 'scope'> & { scope?: Exclude<McpScope, 'local'> },
68
- ): Promise<Array<{ provider: LLMProvider; created: boolean; error?: string }>> {
69
- if (input.transport !== 'stdio' && input.transport !== 'http') {
70
- throw new AppError('Global MCP add supports only "stdio" and "http".', {
71
- code: 'INVALID_GLOBAL_MCP_TRANSPORT',
72
- statusCode: 400,
73
- });
74
- }
75
-
76
- const scope = input.scope ?? 'project';
77
- const results: Array<{ provider: LLMProvider; created: boolean; error?: string }> = [];
78
- const providers = providerRegistry.listProviders().filter((p) => includeProviderInGlobalMcp(p.id));
79
- for (const provider of providers) {
80
- try {
81
- await provider.mcp.upsertServer({ ...input, scope });
82
- results.push({ provider: provider.id, created: true });
83
- } catch (error) {
84
- results.push({
85
- provider: provider.id,
86
- created: false,
87
- error: error instanceof Error ? error.message : 'Unknown error',
88
- });
89
- }
90
- }
91
-
92
- return results;
93
- },
94
- };
1
+ import os from 'node:os';
2
+
3
+ import { providerRegistry } from '@/modules/providers/provider.registry.js';
4
+ import type { LLMProvider, McpScope, ProviderMcpServer, UpsertProviderMcpServerInput } from '@/shared/types.js';
5
+ import { AppError } from '@/shared/utils.js';
6
+
7
+ /** Cursor MCP is not supported on Windows hosts (no Cursor CLI integration). */
8
+ function includeProviderInGlobalMcp(providerId: LLMProvider): boolean {
9
+ if (providerId === 'cursor' && os.platform() === 'win32') {
10
+ return false;
11
+ }
12
+
13
+ return true;
14
+ }
15
+
16
+
17
+ export const providerMcpService = {
18
+ /**
19
+ * Lists MCP servers for one provider grouped by supported scopes.
20
+ */
21
+ async listProviderMcpServers(
22
+ providerName: string,
23
+ options?: { workspacePath?: string },
24
+ ): Promise<Record<McpScope, ProviderMcpServer[]>> {
25
+ const provider = providerRegistry.resolveProvider(providerName);
26
+ return provider.mcp.listServers(options);
27
+ },
28
+
29
+ /**
30
+ * Lists MCP servers for one provider scope.
31
+ */
32
+ async listProviderMcpServersForScope(
33
+ providerName: string,
34
+ scope: McpScope,
35
+ options?: { workspacePath?: string },
36
+ ): Promise<ProviderMcpServer[]> {
37
+ const provider = providerRegistry.resolveProvider(providerName);
38
+ return provider.mcp.listServersForScope(scope, options);
39
+ },
40
+
41
+ /**
42
+ * Adds or updates one provider MCP server.
43
+ */
44
+ async upsertProviderMcpServer(
45
+ providerName: string,
46
+ input: UpsertProviderMcpServerInput,
47
+ ): Promise<ProviderMcpServer> {
48
+ const provider = providerRegistry.resolveProvider(providerName);
49
+ return provider.mcp.upsertServer(input);
50
+ },
51
+
52
+ /**
53
+ * Removes one provider MCP server.
54
+ */
55
+ async removeProviderMcpServer(
56
+ providerName: string,
57
+ input: { name: string; scope?: McpScope; workspacePath?: string },
58
+ ): Promise<{ removed: boolean; provider: LLMProvider; name: string; scope: McpScope }> {
59
+ const provider = providerRegistry.resolveProvider(providerName);
60
+ return provider.mcp.removeServer(input);
61
+ },
62
+
63
+ /**
64
+ * Adds one HTTP/stdio MCP server to every provider.
65
+ */
66
+ async addMcpServerToAllProviders(
67
+ input: Omit<UpsertProviderMcpServerInput, 'scope'> & { scope?: Exclude<McpScope, 'local'> },
68
+ ): Promise<Array<{ provider: LLMProvider; created: boolean; error?: string }>> {
69
+ if (input.transport !== 'stdio' && input.transport !== 'http') {
70
+ throw new AppError('Global MCP add supports only "stdio" and "http".', {
71
+ code: 'INVALID_GLOBAL_MCP_TRANSPORT',
72
+ statusCode: 400,
73
+ });
74
+ }
75
+
76
+ const scope = input.scope ?? 'project';
77
+ const results: Array<{ provider: LLMProvider; created: boolean; error?: string }> = [];
78
+ const providers = providerRegistry.listProviders().filter((p) => includeProviderInGlobalMcp(p.id));
79
+ for (const provider of providers) {
80
+ try {
81
+ await provider.mcp.upsertServer({ ...input, scope });
82
+ results.push({ provider: provider.id, created: true });
83
+ } catch (error) {
84
+ results.push({
85
+ provider: provider.id,
86
+ created: false,
87
+ error: error instanceof Error ? error.message : 'Unknown error',
88
+ });
89
+ }
90
+ }
91
+
92
+ return results;
93
+ },
94
+ };
@@ -1,26 +1,26 @@
1
- import { providerRegistry } from '@/modules/providers/provider.registry.js';
2
- import type { LLMProvider, ProviderAuthStatus } from '@/shared/types.js';
3
-
4
- export const providerAuthService = {
5
- /**
6
- * Resolves a provider and returns its installation/authentication status.
7
- */
8
- async getProviderAuthStatus(providerName: string): Promise<ProviderAuthStatus> {
9
- const provider = providerRegistry.resolveProvider(providerName);
10
- return provider.auth.getStatus();
11
- },
12
-
13
- /**
14
- * Returns whether a provider runtime appears installed.
15
- * Falls back to true if status lookup itself fails so callers preserve the
16
- * original runtime error instead of replacing it with a status-check failure.
17
- */
18
- async isProviderInstalled(providerName: LLMProvider): Promise<boolean> {
19
- try {
20
- const status = await this.getProviderAuthStatus(providerName);
21
- return status.installed;
22
- } catch {
23
- return true;
24
- }
25
- },
26
- };
1
+ import { providerRegistry } from '@/modules/providers/provider.registry.js';
2
+ import type { LLMProvider, ProviderAuthStatus } from '@/shared/types.js';
3
+
4
+ export const providerAuthService = {
5
+ /**
6
+ * Resolves a provider and returns its installation/authentication status.
7
+ */
8
+ async getProviderAuthStatus(providerName: string): Promise<ProviderAuthStatus> {
9
+ const provider = providerRegistry.resolveProvider(providerName);
10
+ return provider.auth.getStatus();
11
+ },
12
+
13
+ /**
14
+ * Returns whether a provider runtime appears installed.
15
+ * Falls back to true if status lookup itself fails so callers preserve the
16
+ * original runtime error instead of replacing it with a status-check failure.
17
+ */
18
+ async isProviderInstalled(providerName: LLMProvider): Promise<boolean> {
19
+ try {
20
+ const status = await this.getProviderAuthStatus(providerName);
21
+ return status.installed;
22
+ } catch {
23
+ return true;
24
+ }
25
+ },
26
+ };
@@ -1,45 +1,45 @@
1
- import { providerRegistry } from '@/modules/providers/provider.registry.js';
2
- import type {
3
- FetchHistoryOptions,
4
- FetchHistoryResult,
5
- LLMProvider,
6
- NormalizedMessage,
7
- } from '@/shared/types.js';
8
-
9
- /**
10
- * Application service for provider-backed session message operations.
11
- *
12
- * Callers pass a provider id and this service resolves the concrete provider
13
- * class, keeping normalization/history call sites decoupled from implementation
14
- * file layout.
15
- */
16
- export const sessionsService = {
17
- /**
18
- * Lists provider ids that can load session history and normalize live messages.
19
- */
20
- listProviderIds(): LLMProvider[] {
21
- return providerRegistry.listProviders().map((provider) => provider.id);
22
- },
23
-
24
- /**
25
- * Normalizes one provider-native event into frontend session message events.
26
- */
27
- normalizeMessage(
28
- providerName: string,
29
- raw: unknown,
30
- sessionId: string | null,
31
- ): NormalizedMessage[] {
32
- return providerRegistry.resolveProvider(providerName).sessions.normalizeMessage(raw, sessionId);
33
- },
34
-
35
- /**
36
- * Fetches normalized persisted session history for one provider/session pair.
37
- */
38
- fetchHistory(
39
- providerName: string,
40
- sessionId: string,
41
- options?: FetchHistoryOptions,
42
- ): Promise<FetchHistoryResult> {
43
- return providerRegistry.resolveProvider(providerName).sessions.fetchHistory(sessionId, options);
44
- },
45
- };
1
+ import { providerRegistry } from '@/modules/providers/provider.registry.js';
2
+ import type {
3
+ FetchHistoryOptions,
4
+ FetchHistoryResult,
5
+ LLMProvider,
6
+ NormalizedMessage,
7
+ } from '@/shared/types.js';
8
+
9
+ /**
10
+ * Application service for provider-backed session message operations.
11
+ *
12
+ * Callers pass a provider id and this service resolves the concrete provider
13
+ * class, keeping normalization/history call sites decoupled from implementation
14
+ * file layout.
15
+ */
16
+ export const sessionsService = {
17
+ /**
18
+ * Lists provider ids that can load session history and normalize live messages.
19
+ */
20
+ listProviderIds(): LLMProvider[] {
21
+ return providerRegistry.listProviders().map((provider) => provider.id);
22
+ },
23
+
24
+ /**
25
+ * Normalizes one provider-native event into frontend session message events.
26
+ */
27
+ normalizeMessage(
28
+ providerName: string,
29
+ raw: unknown,
30
+ sessionId: string | null,
31
+ ): NormalizedMessage[] {
32
+ return providerRegistry.resolveProvider(providerName).sessions.normalizeMessage(raw, sessionId);
33
+ },
34
+
35
+ /**
36
+ * Fetches normalized persisted session history for one provider/session pair.
37
+ */
38
+ fetchHistory(
39
+ providerName: string,
40
+ sessionId: string,
41
+ options?: FetchHistoryOptions,
42
+ ): Promise<FetchHistoryResult> {
43
+ return providerRegistry.resolveProvider(providerName).sessions.fetchHistory(sessionId, options);
44
+ },
45
+ };
@@ -1,20 +1,20 @@
1
- import type { IProvider, IProviderAuth, IProviderMcp, IProviderSessions } from '@/shared/interfaces.js';
2
- import type { LLMProvider } from '@/shared/types.js';
3
-
4
- /**
5
- * Shared provider base.
6
- *
7
- * Concrete providers must expose auth/MCP handlers and implement message
8
- * normalization/history loading because those behaviors depend on native
9
- * SDK/CLI formats.
10
- */
11
- export abstract class AbstractProvider implements IProvider {
12
- readonly id: LLMProvider;
13
- abstract readonly mcp: IProviderMcp;
14
- abstract readonly auth: IProviderAuth;
15
- abstract readonly sessions: IProviderSessions;
16
-
17
- protected constructor(id: LLMProvider) {
18
- this.id = id;
19
- }
20
- }
1
+ import type { IProvider, IProviderAuth, IProviderMcp, IProviderSessions } from '@/shared/interfaces.js';
2
+ import type { LLMProvider } from '@/shared/types.js';
3
+
4
+ /**
5
+ * Shared provider base.
6
+ *
7
+ * Concrete providers must expose auth/MCP handlers and implement message
8
+ * normalization/history loading because those behaviors depend on native
9
+ * SDK/CLI formats.
10
+ */
11
+ export abstract class AbstractProvider implements IProvider {
12
+ readonly id: LLMProvider;
13
+ abstract readonly mcp: IProviderMcp;
14
+ abstract readonly auth: IProviderAuth;
15
+ abstract readonly sessions: IProviderSessions;
16
+
17
+ protected constructor(id: LLMProvider) {
18
+ this.id = id;
19
+ }
20
+ }