Commit Graph

90 Commits

Author SHA1 Message Date
digua 1c46600988 feat: 模型第三方服务支持自选接口类型 2026-04-17 23:44:23 +08:00
digua 769b80e2b2 feat: AI服务商支持 Anthropic 2026-04-17 23:44:23 +08:00
digua 726396733a fix(llm): add runtime UA headers for openai-compatible requests 2026-04-15 00:10:28 +08:00
digua 65923982ac feat: AI日志文件写入文件原始路径 2026-04-15 00:10:28 +08:00
digua d7a02a10c2 fix: 第三方/本地服务编辑弹窗丢失多个自定义模型 2026-04-10 00:47:56 +08:00
digua 6103255815 feat: 重构模型配置逻辑 2026-04-08 23:07:48 +08:00
digua fa3282f625 feat: 移除旧版提示词 2026-04-07 23:43:01 +08:00
digua d49a094164 feat: 搜索工具自动携带上下文消息 2026-04-07 23:43:01 +08:00
digua 3189de3a6e style: 代码格式优化 2026-04-06 22:24:49 +08:00
digua 59e6bdb9cb feat: 精简部分工具的搜索参数以节省token 2026-04-06 14:04:31 +08:00
digua 0a81238a0a feat: 支持 FTS5 全文搜索,并新增快速搜索工具 2026-04-06 14:04:31 +08:00
digua da3d7bccb4 feat: 新增部分AI工具 2026-04-02 23:29:06 +08:00
digua 346a38da5a feat: 重构 AI 工具分类体系 2026-04-02 23:29:06 +08:00
digua e099dde435 feat: 新增获取聊天概览工具 2026-04-02 23:29:06 +08:00
digua bfca7ff133 fix: SQL Lab 和摘要生成的 AI 错误静默吞没问题
- llm:chatStream:正确处理 error/done 事件,防止终态重复发送
- llmComplete:检测 completeSimple 返回的 error stopReason 并抛出异常
- SessionTimeline:摘要生成失败时显示 toast 提示替代 console.log

Made-with: Cursor
2026-04-02 23:29:06 +08:00
digua b3d1171f71 feat: 废弃部分AI工具 2026-04-02 23:29:06 +08:00
digua 792cb0e1ee feat: API服务 UI优化 2026-03-28 00:10:29 +08:00
digua 7eaba396ec refactor: 清理 parser worker rag merger 的历史类型问题 2026-03-25 22:43:12 +08:00
digua b6fdc3887e fix: 修复 AI 会话链路与前端 type-check 错误 2026-03-25 22:42:31 +08:00
digua 39b06523d4 fix: 增加默认assistant兜底 2026-03-25 22:10:44 +08:00
digua 8f080910d4 fix: 修复Gemini API配置问题 (fix #97) 2026-03-16 23:39:49 +08:00
digua 9e8f9e8678 feat: 完成助手市场和技能市场 2026-03-16 23:39:49 +08:00
digua 4b10cf21dd feat: 移除旧版提示词系统 2026-03-16 00:27:55 +08:00
digua c26594d8af feat: 调用模型的时候,切换页面不再终止进程 resolve #14 2026-03-16 00:27:55 +08:00
digua db9b67071c feat: 支持@选择成员 2026-03-16 00:27:55 +08:00
digua 7a1a9fc2b1 feat: 聊天对话支持使用技能 2026-03-16 00:27:55 +08:00
digua a633b4f326 feat: 支持繁体中文和日语国际化 2026-03-16 00:27:55 +08:00
digua e7f2ee7db7 style: format and lint codebase 2026-03-16 00:27:55 +08:00
digua 6edb3e3b95 feat: 优化助手逻辑 2026-03-10 21:35:53 +08:00
digua 60be78b767 feat: 完善助手功能,新增分析tools 2026-03-10 20:42:25 +08:00
digua f36623d72e feat: 完成助手模式初版 2026-03-02 01:19:54 +08:00
digua 9ce333afe3 feat(ai): 增加 DEBUG 模式与 AI 日志增强
- 设置>关于 新增 DEBUG 模式开关,开启后日志记录完整消息不截断
- aiLogger 支持 debugMode 控制截断行为
- Agent 执行前在 DEBUG 模式下记录完整 System Prompt 和消息历史
- INFO 日志增强:记录模型/Provider/API地址、上下文配置、预处理开关
- 工具调用日志升级:记录完整参数(tool_start)
- 预处理管道统计提升至 INFO 级别
2026-02-28 00:02:12 +08:00
digua c36878c58d feat(ai): 实现聊天记录预处理管道
- 新增 preprocessor 模块:数据清洗(XML卡片)、黑名单过滤、智能去噪、连续发言合并、数据脱敏
- 内置多国脱敏规则(中国手机号/身份证、美国SSN、日韩号码等)+ 自定义规则支持
- 工具层统一 wrapWithPreprocessing 包装,自动对 rawMessages 执行预处理+格式化
- 昵称匿名化:用 U{id} 替代真实昵称,跨工具调用一致
- SQL 查询补充 senderId/senderPlatformId
- PreprocessConfig 类型定义(preload + 主进程)
2026-02-28 00:02:08 +08:00
digua 1823042fad style: auto-format code (eslint --fix)
Formatting-only changes from ESLint auto-fix, no logic changes.

Made-with: Cursor
2026-02-27 20:22:18 +08:00
digua 07fffb0112 refactor: data flow inversion, IPC contract fixes, and frontend adaptation
Data flow inversion:
- Add getHistoryForAgent() in conversations.ts — Agent now reads
  history directly from SQLite instead of receiving it from frontend
- Remove historyMessages parameter from agent:runStream IPC chain,
  add maxHistoryRounds for configurable context window
- Frontend (useAIChat.ts) pre-creates conversation before Agent call,
  removes history message collection logic

IPC fixes:
- Restore llm:chat and llm:chatStream handlers using pi-ai's
  completeSimple/streamSimple (P0-1: SQLLab compatibility)
- Send agent:complete with aborted flag in all abort paths to prevent
  hanging Promises in renderer (P0-2)
- Fix createConversation parameter order to match preload/data layer
  contract: (sessionId, title?) instead of (title, sessionId?) (P1)

Preload/frontend:
- Update preload API signatures and type declarations
- Use shared types for TokenUsage and AgentRuntimeStatus
2026-02-26 21:06:27 +08:00
digua e6849af698 refactor(agent): split monolithic Agent into modular architecture
- Delete monolithic agent.ts (−1464 lines)
- Add agent/index.ts: Agent orchestrator class with runAgent/runAgentStream
- Add agent/types.ts: AgentConfig, AgentStreamChunk, AgentResult, PromptConfig
- Add agent/prompt-builder.ts: system prompt construction with i18n
- Add agent/content-parser.ts: thinking tag and tool call tag parsing
- Add agent/event-handler.ts: runtime state, event mapping, token estimation
2026-02-26 21:05:50 +08:00
digua f7c427df50 refactor(tools): modularize tool system with AgentTool + TypeBox + i18n
- Delete monolithic registry.ts (−1185 lines)
- Add tools/definitions/ with 12 individual tool files + index.ts,
  each using AgentTool interface and TypeBox schemas
- Add tools/utils/ with shared helpers (format.ts, schemas.ts, time-params.ts)
- Rewrite tools/index.ts to provide getAllTools() factory
- Clean up tools/types.ts, keep only ToolContext and OwnerInfo
- Use i18n keys for tool descriptions, preserve Chinese as comments
2026-02-26 21:05:39 +08:00
digua 90afe5f087 refactor(llm): unify LLM access layer via pi-ai
- Refactor llm/index.ts: remove chat()/chatStream() wrappers, inline
  provider info from deleted service files, add buildPiModel() for
  direct pi-ai model construction
- Migrate summary/index.ts to use pi-ai's completeSimple directly
- Migrate rag/pipeline/semantic.ts to use pi-ai's completeSimple directly
2026-02-26 21:05:28 +08:00
digua da3d2531f5 chore: remove over-engineered sessionLog module
Delete sessionLog.ts and its test — this module was never used in production
and added unnecessary complexity to the context system.
2026-02-26 21:05:17 +08:00
digua b9daae8cb4 chore: remove @ai-sdk dependencies and legacy LLM service implementations
- Remove @ai-sdk/google, @ai-sdk/openai, ai packages from dependencies
- Delete SDK-based service files: gemini.ts, openai-compatible.ts, sdkUtils.ts
- Clean up unused types from llm/types.ts (ChatMessage, ChatOptions, LLMConfig, ILLMService, etc.)
2026-02-26 21:05:08 +08:00
n-WN 284118ca21 feat(agent): add session-based context timeline and runtime status 2026-02-23 19:17:25 +08:00
digua 8a12aa5c1b refactor: 重构部分图表为插件形式 2026-02-19 22:56:41 +08:00
digua ab1778a6d6 feat: 管理页面支持显示聊天对话的 摘要数量和AI对话数量 2026-02-13 17:11:55 +08:00
digua d52769ce46 feat: 日志国际化 2026-02-13 14:15:38 +08:00
digua 1b8bbb6e49 feat: 主进程配置国际化 2026-02-13 14:15:38 +08:00
digua f3ba043140 refactor: format with eslint & prettier 2026-02-13 14:15:38 +08:00
digua b1bf4ff8f9 feat: 对于API key进行本地加密 2026-02-04 23:20:25 +08:00
digua 6506eafd77 fix: 修复部分第三方中转API调用tool_call导致对话异常结束的问题 #67 2026-02-03 00:25:09 +08:00
xuncha 574e286f27 feat: 设置内新增可选目录位置 2026-02-03 00:25:09 +08:00
digua 889ec4341a feat: 对推理模型进行优化 2026-02-01 12:35:07 +08:00