@huyooo/ai-chat-core 0.2.44 → 0.3.2
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/adapter/index.d.ts +11 -0
- package/dist/adapter/index.d.ts.map +1 -0
- package/dist/adapter/model-adapter.d.ts +25 -0
- package/dist/adapter/model-adapter.d.ts.map +1 -0
- package/dist/adapter/model-options.d.ts +53 -0
- package/dist/adapter/model-options.d.ts.map +1 -0
- package/dist/adapter/types.d.ts +28 -0
- package/dist/adapter/types.d.ts.map +1 -0
- package/dist/chat-runtime.d.ts +96 -0
- package/dist/chat-runtime.d.ts.map +1 -0
- package/dist/constants.d.ts +12 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/events.d.ts +605 -1
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +1 -1
- package/dist/extension/index.d.ts +9 -0
- package/dist/extension/index.d.ts.map +1 -0
- package/dist/extension/types.d.ts +46 -0
- package/dist/extension/types.d.ts.map +1 -0
- package/dist/families/index.d.ts +11 -0
- package/dist/families/index.d.ts.map +1 -0
- package/dist/families/presets.d.ts +31 -0
- package/dist/families/presets.d.ts.map +1 -0
- package/dist/families/resolver.d.ts +11 -0
- package/dist/families/resolver.d.ts.map +1 -0
- package/dist/families/types.d.ts +29 -0
- package/dist/families/types.d.ts.map +1 -0
- package/dist/governance/command-safety.d.ts +34 -0
- package/dist/governance/command-safety.d.ts.map +1 -0
- package/dist/governance/governance.d.ts +19 -0
- package/dist/governance/governance.d.ts.map +1 -0
- package/dist/governance/index.d.ts +12 -0
- package/dist/governance/index.d.ts.map +1 -0
- package/dist/governance/types.d.ts +29 -0
- package/dist/governance/types.d.ts.map +1 -0
- package/dist/index.d.ts +72 -804
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +51 -1
- package/dist/internal/management-args.d.ts +13 -0
- package/dist/internal/management-args.d.ts.map +1 -0
- package/dist/internal/management-results.d.ts +21 -0
- package/dist/internal/management-results.d.ts.map +1 -0
- package/dist/llm-config.d.ts +108 -0
- package/dist/llm-config.d.ts.map +1 -0
- package/dist/logger/core.d.ts +31 -0
- package/dist/logger/core.d.ts.map +1 -0
- package/dist/logger/index.d.ts +9 -0
- package/dist/logger/index.d.ts.map +1 -0
- package/dist/orchestrator/compression-handler.d.ts +29 -0
- package/dist/orchestrator/compression-handler.d.ts.map +1 -0
- package/dist/orchestrator/context-compressor.d.ts +51 -0
- package/dist/orchestrator/context-compressor.d.ts.map +1 -0
- package/dist/orchestrator/context-summarizer.d.ts +41 -0
- package/dist/orchestrator/context-summarizer.d.ts.map +1 -0
- package/dist/orchestrator/index.d.ts +12 -0
- package/dist/orchestrator/index.d.ts.map +1 -0
- package/dist/orchestrator/orchestrator.d.ts +46 -0
- package/dist/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator/types.d.ts +58 -0
- package/dist/orchestrator/types.d.ts.map +1 -0
- package/dist/parts/index.d.ts +13 -0
- package/dist/parts/index.d.ts.map +1 -0
- package/dist/parts/registry.d.ts +11 -0
- package/dist/parts/registry.d.ts.map +1 -0
- package/dist/parts/summaries.d.ts +9 -0
- package/dist/parts/summaries.d.ts.map +1 -0
- package/dist/parts/types.d.ts +61 -0
- package/dist/parts/types.d.ts.map +1 -0
- package/dist/platform.d.ts +17 -0
- package/dist/platform.d.ts.map +1 -0
- package/dist/platform.js +1 -0
- package/dist/protocols/anthropic.d.ts +20 -0
- package/dist/protocols/anthropic.d.ts.map +1 -0
- package/dist/protocols/ark.d.ts +36 -0
- package/dist/protocols/ark.d.ts.map +1 -0
- package/dist/protocols/deepseek.d.ts +24 -0
- package/dist/protocols/deepseek.d.ts.map +1 -0
- package/dist/protocols/error-utils.d.ts +14 -0
- package/dist/protocols/error-utils.d.ts.map +1 -0
- package/dist/protocols/gemini.d.ts +24 -0
- package/dist/protocols/gemini.d.ts.map +1 -0
- package/dist/protocols/glm.d.ts +20 -0
- package/dist/protocols/glm.d.ts.map +1 -0
- package/dist/protocols/grok.d.ts +20 -0
- package/dist/protocols/grok.d.ts.map +1 -0
- package/dist/protocols/index.d.ts +31 -0
- package/dist/protocols/index.d.ts.map +1 -0
- package/dist/protocols/minimax.d.ts +38 -0
- package/dist/protocols/minimax.d.ts.map +1 -0
- package/dist/protocols/moonshot.d.ts +20 -0
- package/dist/protocols/moonshot.d.ts.map +1 -0
- package/dist/protocols/openai-sse.d.ts +33 -0
- package/dist/protocols/openai-sse.d.ts.map +1 -0
- package/dist/protocols/openai.d.ts +19 -0
- package/dist/protocols/openai.d.ts.map +1 -0
- package/dist/protocols/qwen.d.ts +26 -0
- package/dist/protocols/qwen.d.ts.map +1 -0
- package/dist/protocols/responses-sse.d.ts +30 -0
- package/dist/protocols/responses-sse.d.ts.map +1 -0
- package/dist/protocols/sse-reader.d.ts +23 -0
- package/dist/protocols/sse-reader.d.ts.map +1 -0
- package/dist/protocols/tool-arguments.d.ts +8 -0
- package/dist/protocols/tool-arguments.d.ts.map +1 -0
- package/dist/protocols/types.d.ts +148 -0
- package/dist/protocols/types.d.ts.map +1 -0
- package/dist/protocols/vercel-gateway.d.ts +15 -0
- package/dist/protocols/vercel-gateway.d.ts.map +1 -0
- package/dist/runtime.d.ts +151 -0
- package/dist/runtime.d.ts.map +1 -0
- package/dist/runtime.js +1 -0
- package/dist/skills/index.d.ts +14 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/management/admin.d.ts +10 -0
- package/dist/skills/management/admin.d.ts.map +1 -0
- package/dist/skills/management/index.d.ts +11 -0
- package/dist/skills/management/index.d.ts.map +1 -0
- package/dist/skills/management/inputs.d.ts +44 -0
- package/dist/skills/management/inputs.d.ts.map +1 -0
- package/dist/skills/management/operations.d.ts +78 -0
- package/dist/skills/management/operations.d.ts.map +1 -0
- package/dist/skills/management/types.d.ts +70 -0
- package/dist/skills/management/types.d.ts.map +1 -0
- package/dist/skills/registry.d.ts +37 -0
- package/dist/skills/registry.d.ts.map +1 -0
- package/dist/skills/summaries.d.ts +9 -0
- package/dist/skills/summaries.d.ts.map +1 -0
- package/dist/skills/types.d.ts +61 -0
- package/dist/skills/types.d.ts.map +1 -0
- package/dist/test-utils/mock-sse.d.ts +13 -0
- package/dist/test-utils/mock-sse.d.ts.map +1 -0
- package/dist/tool-manager/define-tool.d.ts +35 -0
- package/dist/tool-manager/define-tool.d.ts.map +1 -0
- package/dist/tool-manager/formats.d.ts +46 -0
- package/dist/tool-manager/formats.d.ts.map +1 -0
- package/dist/tool-manager/identity.d.ts +18 -0
- package/dist/tool-manager/identity.d.ts.map +1 -0
- package/dist/tool-manager/in-process-provider.d.ts +15 -0
- package/dist/tool-manager/in-process-provider.d.ts.map +1 -0
- package/dist/tool-manager/index.d.ts +18 -0
- package/dist/tool-manager/index.d.ts.map +1 -0
- package/dist/tool-manager/manager.d.ts +18 -0
- package/dist/tool-manager/manager.d.ts.map +1 -0
- package/dist/tool-manager/mcp-provider.d.ts +21 -0
- package/dist/tool-manager/mcp-provider.d.ts.map +1 -0
- package/dist/tool-manager/summaries.d.ts +39 -0
- package/dist/tool-manager/summaries.d.ts.map +1 -0
- package/dist/tool-manager/types.d.ts +314 -0
- package/dist/tool-manager/types.d.ts.map +1 -0
- package/dist/types.d.ts +663 -0
- package/dist/types.d.ts.map +1 -0
- package/package.json +26 -15
- package/src/adapter/index.ts +25 -0
- package/src/adapter/model-adapter.ts +196 -0
- package/src/adapter/model-options.ts +143 -0
- package/src/adapter/types.ts +41 -0
- package/src/chat-runtime.ts +515 -0
- package/src/constants.ts +9 -102
- package/src/events.ts +364 -150
- package/src/extension/index.ts +24 -0
- package/src/extension/types.ts +49 -0
- package/src/families/index.ts +28 -0
- package/src/families/presets.ts +124 -0
- package/src/families/resolver.ts +22 -0
- package/src/families/types.ts +55 -0
- package/src/governance/command-safety.ts +224 -0
- package/src/governance/governance.ts +125 -0
- package/src/governance/index.ts +38 -0
- package/src/governance/types.ts +44 -0
- package/src/index.ts +250 -145
- package/src/internal/management-args.ts +39 -0
- package/src/internal/management-results.ts +60 -0
- package/src/llm-config.ts +137 -0
- package/src/logger/core.ts +96 -0
- package/src/logger/index.ts +8 -0
- package/src/orchestrator/compression-handler.ts +137 -0
- package/src/{providers → orchestrator}/context-compressor.ts +79 -47
- package/src/orchestrator/context-summarizer.ts +123 -0
- package/src/orchestrator/index.ts +20 -0
- package/src/orchestrator/orchestrator.ts +1002 -0
- package/src/orchestrator/types.ts +70 -0
- package/src/parts/index.ts +20 -0
- package/src/parts/registry.ts +95 -0
- package/src/parts/summaries.ts +40 -0
- package/src/parts/types.ts +63 -0
- package/src/platform.ts +73 -0
- package/src/protocols/anthropic.ts +377 -0
- package/src/protocols/ark.ts +300 -0
- package/src/protocols/deepseek.ts +192 -0
- package/src/{providers/protocols → protocols}/error-utils.ts +17 -20
- package/src/protocols/gemini.ts +352 -0
- package/src/protocols/glm.ts +212 -0
- package/src/protocols/grok.ts +98 -0
- package/src/protocols/index.ts +48 -0
- package/src/protocols/minimax.ts +308 -0
- package/src/protocols/moonshot.ts +186 -0
- package/src/protocols/openai-sse.ts +156 -0
- package/src/protocols/openai.ts +97 -0
- package/src/protocols/qwen.ts +358 -0
- package/src/protocols/responses-sse.ts +224 -0
- package/src/protocols/sse-reader.ts +54 -0
- package/src/protocols/tool-arguments.ts +32 -0
- package/src/{providers/protocols → protocols}/types.ts +46 -37
- package/src/protocols/vercel-gateway.ts +391 -0
- package/src/runtime.ts +167 -0
- package/src/skills/index.ts +29 -0
- package/src/skills/management/admin.ts +170 -0
- package/src/skills/management/index.ts +27 -0
- package/src/skills/management/inputs.ts +79 -0
- package/src/skills/management/operations.ts +256 -0
- package/src/skills/management/types.ts +57 -0
- package/src/skills/registry.ts +120 -0
- package/src/skills/summaries.ts +48 -0
- package/src/skills/types.ts +65 -0
- package/src/test-utils/mock-sse.ts +3 -3
- package/src/tool-manager/define-tool.ts +201 -0
- package/src/tool-manager/formats.ts +146 -0
- package/src/tool-manager/identity.ts +80 -0
- package/src/tool-manager/in-process-provider.ts +164 -0
- package/src/tool-manager/index.ts +63 -0
- package/src/tool-manager/manager.ts +562 -0
- package/src/tool-manager/mcp-provider.ts +509 -0
- package/src/tool-manager/summaries.ts +136 -0
- package/src/tool-manager/types.ts +389 -0
- package/src/types.ts +750 -191
- package/dist/events-CU5D5ray.d.ts +0 -1128
- package/src/agent.ts +0 -409
- package/src/internal/update-plan.ts +0 -2
- package/src/internal/web-search.ts +0 -77
- package/src/mcp/client-manager.ts +0 -302
- package/src/mcp/index.ts +0 -2
- package/src/mcp/types.ts +0 -43
- package/src/providers/context-summarizer.ts +0 -70
- package/src/providers/index.ts +0 -125
- package/src/providers/model-registry.ts +0 -466
- package/src/providers/orchestrator.ts +0 -839
- package/src/providers/protocols/anthropic.ts +0 -406
- package/src/providers/protocols/ark.ts +0 -362
- package/src/providers/protocols/deepseek.ts +0 -344
- package/src/providers/protocols/gemini.ts +0 -350
- package/src/providers/protocols/index.ts +0 -36
- package/src/providers/protocols/openai.ts +0 -420
- package/src/providers/protocols/qwen.ts +0 -315
- package/src/providers/types.ts +0 -264
- package/src/providers/unified-adapter.ts +0 -367
- package/src/router.ts +0 -72
- package/src/tools.ts +0 -162
- package/src/utils.ts +0 -86
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Context Summarizer — 专用上下文总结模块
|
|
3
|
+
*
|
|
4
|
+
* 当对话历史超过当前模型的 context window 时,通过外部注入的 summarize 回调执行 AI 总结。
|
|
5
|
+
* 回调由宿主提供(如 SuperX 走 ai-server 的 toolAI),ai-chat-core 不关心具体调用方式。
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import type { ProtocolMessage } from '../protocols';
|
|
9
|
+
import {
|
|
10
|
+
buildSummarizeRequest,
|
|
11
|
+
applySummary,
|
|
12
|
+
estimateTotalTokens,
|
|
13
|
+
estimateStringTokens,
|
|
14
|
+
buildSingleMessageSummarizeRequest,
|
|
15
|
+
type CompactConfig,
|
|
16
|
+
} from './context-compressor';
|
|
17
|
+
import { createModuleLogger } from '../logger';
|
|
18
|
+
|
|
19
|
+
const logger = createModuleLogger('ContextSummarizer');
|
|
20
|
+
|
|
21
|
+
// ==================== 类型 ====================
|
|
22
|
+
|
|
23
|
+
/** 外部注入的 AI 总结函数,model 由 orchestrator 根据场景传入 */
|
|
24
|
+
export type SummarizeFn = (systemPrompt: string, userPrompt: string, model: string) => Promise<string>;
|
|
25
|
+
|
|
26
|
+
export interface SummarizeResult {
|
|
27
|
+
messages: ProtocolMessage[];
|
|
28
|
+
success: boolean;
|
|
29
|
+
/** AI 生成的原始摘要文本,前端持久化时需加 [对话历史摘要] 前缀 */
|
|
30
|
+
summaryContent?: string;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// ==================== 核心函数 ====================
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* 使用 AI 总结对话历史
|
|
37
|
+
*
|
|
38
|
+
* 1. 用 buildSummarizeRequest 分离「待总结的中间历史」和「保留的最近消息」
|
|
39
|
+
* 2. 调用外部注入的 summarizeFn 执行总结(走 ai-server 等)
|
|
40
|
+
* 3. 用 applySummary 组装压缩后的消息列表
|
|
41
|
+
*/
|
|
42
|
+
export async function summarizeHistory(
|
|
43
|
+
summarizeFn: SummarizeFn,
|
|
44
|
+
messages: ProtocolMessage[],
|
|
45
|
+
config: CompactConfig,
|
|
46
|
+
model: string,
|
|
47
|
+
): Promise<SummarizeResult> {
|
|
48
|
+
const { summarizeMessages, keepMessages } = buildSummarizeRequest(messages, config);
|
|
49
|
+
|
|
50
|
+
if (summarizeMessages.length === 0) {
|
|
51
|
+
logger.info('中间历史太短,跳过 AI 总结');
|
|
52
|
+
return { messages, success: true };
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const systemPrompt = summarizeMessages[0].content;
|
|
56
|
+
const userPrompt = summarizeMessages[1].content;
|
|
57
|
+
|
|
58
|
+
logger.info({ model, tokens: estimateTotalTokens(summarizeMessages), messageCount: messages.length }, `开始 AI 总结 (${model}): ~${estimateTotalTokens(summarizeMessages)} tokens, ${messages.length} 条消息`);
|
|
59
|
+
|
|
60
|
+
try {
|
|
61
|
+
const summaryContent = await summarizeFn(systemPrompt, userPrompt, model);
|
|
62
|
+
|
|
63
|
+
if (!summaryContent.trim()) {
|
|
64
|
+
logger.warn('AI 总结返回空内容');
|
|
65
|
+
return { messages, success: false };
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
const compressed = applySummary(messages, summaryContent, keepMessages);
|
|
69
|
+
logger.info({ originalCount: messages.length, compressedCount: compressed.length, tokens: estimateTotalTokens(compressed) }, `AI 总结完成: ${messages.length} → ${compressed.length} 条消息, ~${estimateTotalTokens(compressed)} tokens`);
|
|
70
|
+
return { messages: compressed, success: true, summaryContent };
|
|
71
|
+
} catch (err) {
|
|
72
|
+
logger.error({ err }, 'AI 总结异常');
|
|
73
|
+
return { messages, success: false };
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// ==================== 单条消息内容压缩 ====================
|
|
78
|
+
|
|
79
|
+
export interface ContentCompressResult {
|
|
80
|
+
/** 压缩后的摘要,替换原消息 content 发给目标模型 */
|
|
81
|
+
summary: string;
|
|
82
|
+
success: boolean;
|
|
83
|
+
/** 原文估算 token 数 */
|
|
84
|
+
originalTokens: number;
|
|
85
|
+
/** 摘要估算 token 数 */
|
|
86
|
+
compressedTokens: number;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* 使用 AI 压缩单条超长用户消息
|
|
91
|
+
*
|
|
92
|
+
* 直接调用 qwen-long(10M 窗口)总结用户贴的超长文档,
|
|
93
|
+
* 返回摘要文本,由 orchestrator 替换消息 content 发给目标模型。
|
|
94
|
+
*/
|
|
95
|
+
export async function compressSingleMessage(
|
|
96
|
+
summarizeFn: SummarizeFn,
|
|
97
|
+
message: ProtocolMessage,
|
|
98
|
+
model: string,
|
|
99
|
+
): Promise<ContentCompressResult> {
|
|
100
|
+
const { summarizeMessages } = buildSingleMessageSummarizeRequest(message);
|
|
101
|
+
const systemPrompt = summarizeMessages[0].content;
|
|
102
|
+
const userPrompt = summarizeMessages[1].content;
|
|
103
|
+
const originalTokens = estimateStringTokens(message.content);
|
|
104
|
+
|
|
105
|
+
logger.info({ model, originalTokens }, `开始单条消息压缩 (${model}): ~${originalTokens} tokens`);
|
|
106
|
+
|
|
107
|
+
try {
|
|
108
|
+
const summary = await summarizeFn(systemPrompt, userPrompt, model);
|
|
109
|
+
|
|
110
|
+
if (!summary.trim()) {
|
|
111
|
+
logger.warn('单条消息压缩返回空内容');
|
|
112
|
+
return { summary: '', success: false, originalTokens, compressedTokens: 0 };
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
const compressedTokens = estimateStringTokens(summary);
|
|
116
|
+
const suffixed = `${summary}\n\n(原文约 ${originalTokens} tokens,已由 AI 压缩提取要点)`;
|
|
117
|
+
logger.info({ originalTokens, compressedTokens }, `单条消息压缩完成: ~${originalTokens} → ~${compressedTokens} tokens`);
|
|
118
|
+
return { summary: suffixed, success: true, originalTokens, compressedTokens };
|
|
119
|
+
} catch (err) {
|
|
120
|
+
logger.error({ err }, '单条消息压缩异常');
|
|
121
|
+
return { summary: '', success: false, originalTokens, compressedTokens: 0 };
|
|
122
|
+
}
|
|
123
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Orchestrator 模块导出(barrel)
|
|
3
|
+
*
|
|
4
|
+
* - ChatOrchestrator:RawEvent → ChatEvent 循环、工具调用与压缩编排
|
|
5
|
+
* - context-summarizer:超长历史外部总结入口
|
|
6
|
+
* - types:编排配置与钩子类型
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
export { ChatOrchestrator, createOrchestrator } from './orchestrator';
|
|
10
|
+
export { summarizeHistory } from './context-summarizer';
|
|
11
|
+
export type { SummarizeFn, SummarizeResult } from './context-summarizer';
|
|
12
|
+
|
|
13
|
+
export type {
|
|
14
|
+
ToolExecutionHooks,
|
|
15
|
+
OrchestratorToolExecutor,
|
|
16
|
+
GetAutoRunConfigCallback,
|
|
17
|
+
OrchestratorConfig,
|
|
18
|
+
OrchestratorContext,
|
|
19
|
+
OrchestratorOptions,
|
|
20
|
+
} from './types';
|