minecraft1024a
5702dd8a9f
refactor(server): 将记忆可视化工具和统计功能整合进主服务
...
将原先独立的记忆可视化工具(Memory Visualizer)和LLM使用统计逻辑深度整合到项目主服务中。
主要变更包括:
- **移除独立的可视化工具**: 删除了 `tools/memory_visualizer` 目录下的所有独立服务器、脚本和文档,清理了项目结构。
- **API路由整合**: 在主 FastAPI 应用中注册了记忆可视化工具的路由,使其成为核心功能的一部分,可通过 `/visualizer` 访问。
- **统计逻辑重构**: 将LLM使用统计的计算逻辑从API路由层 `statistic_router.py` 中剥离,迁移到 `src/chat/utils/statistic.py` 中,实现了逻辑的解耦和复用。API路由现在直接调用重构后的统计任务。
- **依赖清理与添加**: 添加了 `jinja2` 作为模板渲染的依赖,并清除了与独立可视化工具相关的旧依赖。
此次重构简化了项目的维护和部署,将原本分散的功能统一管理,提升了代码的内聚性和可维护性。
2025-11-19 23:35:41 +08:00
minecraft1024a
dad6a3fc6f
feat(search): 添加 Serper 搜索引擎支持
...
本次更新为 WebSearch 模块集成了新的搜索引擎 Serper。
- 在 `WebSearchConfig` 中增加了 `serper_api_keys` 配置项。
- 更新了配置文件模板,加入了 `serper_api_keys` 选项,并在 `enabled_engines` 的可选列表中添加了 "serper"。
- 相应地更新了配置文件版本号。
2025-11-19 23:35:40 +08:00
minecraft1024a
0e77219db2
ruff
2025-11-19 23:35:39 +08:00
Windpicker-owo
44d5a9fe73
refactor(scheduler): 移除不必要的 schedule 锁管理代码
2025-11-19 23:35:39 +08:00
Windpicker-owo
a5481121b8
feat: 添加向量数据清理脚本,确保向量数据仅存储在专门的向量数据库中
2025-11-19 23:35:39 +08:00
minecraft1024a
5e3b058162
refactor(chatter): 移除冗余的私聊/群聊总开关检查
...
主动思考功能的启用/禁用逻辑现在完全由黑白名单机制控制。移除原有的全局开关可以简化配置项,并使调度器中的判断逻辑更加清晰。
2025-11-19 23:35:39 +08:00
SolenmeChiara
45f0ba97ef
chore: 应用maintainer的日志优化建议
...
- 将maizone调试日志级别从info改为debug
- 删除无用的f-string (sourcery-ai建议)
- 删除冗余的debug日志
- 优化send_handler日志级别
Co-authored-by: minecraft1024a <140055845+minecraft1024a@users.noreply.github.com >
2025-11-19 23:35:38 +08:00
SolenmeChiara
649f4a9953
chore: 删除content_service中过于个人化的存在主义prompt
...
- 保留所有功能性bug修复(enable_splitter, 模型fallback等)
- 删除第343-354行的哲学独白
- 保留合理的说说生成指导
🤖 Generated with [Claude Code](https://claude.com/claude-code )
Co-Authored-By: Claude <noreply@anthropic.com >
2025-11-19 23:35:38 +08:00
SolenmeChiara
8df7babacb
fix(bot): 修复adapter_response被echo检查拦截的严重bug
...
问题:
- Napcat发送adapter_response时同时设置了echo=True
- 原逻辑先检查echo,导致adapter_response消息被提前return
- Maizone获取Cookie等功能完全失效(超时40秒)
修复:
- 将adapter_response检查移到echo检查之前
- 确保adapter_response消息优先处理
- 移除重复的adapter_response检查逻辑
影响:
- Maizone插件现在可以正确获取QQ空间Cookie
- 所有adapter命令响应都能正常工作
🤖 Generated with [Claude Code](https://claude.com/claude-code )
Co-Authored-By: Claude <noreply@anthropic.com >
2025-11-19 23:35:37 +08:00
SolenmeChiara
258186865a
chore: 恢复PR改动并适配官方最新版本
...
在官方更新到4936a6d后,选择性恢复PR中的功能改动:
Maizone插件修复(6个文件):
- 优化成功/失败反馈机制(直接反馈,不使用AI生成)
- 实现QQ空间Cookie失效自动重试机制
- 修复评论回复被分割导致标点符号丢失的问题
- 修复QQ空间转发内容提取错误
- 改进maizone图片识别模型配置,支持自动fallback
- 优化maizone说说生成规则
适配器响应处理(bot.py):
- 添加adapter_response消息处理逻辑
- 适配新的DatabaseMessages架构
- 在message_process早期阶段优先处理adapter_response
Web搜索引擎扩展:
- 添加Serper搜索引擎支持
LLM成本计算修复:
- 修复LLM使用统计中成本计算错误的bug
- 调整LLM相关日志级别为DEBUG
其他优化:
- 优化NapCat adapter响应处理
- 优化person_info关系推理逻辑
注:本次恢复已跳过与官方冲突的部分,保留官方的新架构改进
🤖 Generated with [Claude Code](https://claude.com/claude-code )
Co-Authored-By: Claude <noreply@anthropic.com >
2025-11-19 23:35:37 +08:00
Windpicker-owo
b02c0e561d
fix: 等待最多3秒以确保取消正在执行的任务,避免潜在的阻塞
2025-11-19 23:35:36 +08:00
Windpicker-owo
2caaa5e533
refactor: 优化嵌入生成逻辑,失败时返回 None,简化错误处理;更新调度器任务管理逻辑
2025-11-19 23:35:36 +08:00
Windpicker-owo
d199c0986c
fix: 等待取消正在执行的任务以确保任务正确终止
2025-11-19 23:35:36 +08:00
Windpicker-owo
47865c5ff7
chore: 更新项目版本至0.12.0,添加aiofiles依赖;优化调度器任务执行逻辑,避免重复触发
2025-11-19 23:35:36 +08:00
Windpicker-owo
c4a9c8a44a
refactor: 移除多查询生成方法,简化记忆检索逻辑;在工具接口中添加当前时间信息
2025-11-19 23:35:35 +08:00
copilot-swe-agent[bot]
3b0b18de9c
refactor: 消除重复代码并优化记忆系统结构
...
- 提取共享工具函数到 utils 模块
- 创建 utils/similarity.py: 统一余弦相似度计算
- 创建 utils/graph_expansion.py: 统一图扩展算法
- 删除重复实现
- manager.py: 删除 _cosine_similarity 和 _fast_cosine_similarity (60行)
- tools/memory_tools.py: 删除 _expand_with_semantic_filter 和 _cosine_similarity (150行)
- 清理废弃代码
- 删除 tools/memory_tools.py 中10行注释掉的旧代码
- 删除空的 retrieval/ 模块
- 净减少 ~150行重复代码
Co-authored-by: Windpicker-owo <221029311+Windpicker-owo@users.noreply.github.com >
2025-11-19 23:35:35 +08:00
copilot-swe-agent[bot]
f8e58ef229
fix: 修复代码质量问题 - 更正异常处理和导入语句
...
Co-authored-by: Windpicker-owo <221029311+Windpicker-owo@users.noreply.github.com >
2025-11-19 23:35:35 +08:00
copilot-swe-agent[bot]
ea724eb5d4
Initial plan
2025-11-19 23:35:34 +08:00
tt-P607
dcf4912a7d
feat(napcat): 修复JSON消息处理并优化依赖
...
- **修复(bug)**: 解决了在处理 `json` 类型的消息段时,因未导入 `json` 模块而导致的 `NameError` 运行时错误。
- **优化(refactor)**: 根据项目规范,将 `json` 模块的调用全部替换为性能更优的 `orjson`,并移除了多余的 `import` 语句,提升了代码质量和运行效率。
2025-11-19 23:35:34 +08:00
Windpicker-owo
30e43c8a28
fix(CreateMemoryTool): 更新属性字段说明,增加时间精确度至小时分钟
2025-11-19 23:35:31 +08:00
Windpicker-owo
5c40fe50c9
feat(memory): 更新记忆管理和配置,优化整合逻辑,添加语义相似度阈值
2025-11-19 23:35:31 +08:00
Windpicker-owo
2dbe615057
feat(memory-graph): 添加记忆图系统配置,整合节点去重合并器与记忆管理器
2025-11-19 23:35:30 +08:00
Windpicker-owo
16be633dc2
feat(deduplicate_memories): 添加记忆去重工具,支持预览模式和相似度阈值设置
2025-11-19 23:35:30 +08:00
Windpicker-owo
5c2b7bc5ba
fix(manager): 优化记忆整合逻辑,添加批量处理限制,提升性能和稳定性
...
fix(config): 更新配置文件版本,调整记忆整合阈值和时间窗口设置
2025-11-19 23:35:30 +08:00
Windpicker-owo
264462b977
fix(vector_store): 修复 ids 列表检查逻辑,避免 numpy 数组歧义
...
fix(memory_tools): 优化邻居节点数据检查逻辑,确保嵌入数据有效
fix(manager): 更新配置项名称为 search_max_expand_depth
2025-11-19 23:35:29 +08:00
tt-P607
16148cd700
fix(llm): correct boolean parameter type to 'boolean'
...
The enum value for `ToolParamType.BOOLEAN` is updated from 'bool' to 'boolean'. This change aligns the type definition with the standard JSON Schema specification, which is used by most LLM tool-calling APIs. This ensures correct validation and functionality for tools with boolean parameters.
BREAKING CHANGE: The value of `ToolParamType.BOOLEAN` has been changed from 'bool' to 'boolean'. Any part of the system that generates or consumes tool definitions must be updated to use the new value.
2025-11-19 23:35:29 +08:00
Windpicker-owo
ca237e7d59
fix(storage): 修复 get_node_by_id 函数中的 ids 列表检查逻辑,避免 numpy 数组歧义
2025-11-19 23:35:29 +08:00
tt-P607
b2367fa6b0
fix(storage): 修复了Bot/src/memory_graph/storage/vector_store.py 中 get_node_by_id 函数的逻辑问题。通过将 if result["ids"]: 修改为 if result and result["ids"]:,解决了当 chromadb 返回 numpy 数组时可能引发的 ValueError,确保了程序在处理节点查询时的健壮性。
2025-11-19 23:35:29 +08:00
Windpicker-owo
7fda218291
fix(memory): 移除生成多查询时的优化查询参数
2025-11-19 23:35:28 +08:00
Windpicker-owo
57b42512bb
feat: 增强聊天回复生成器,添加参与者信息和聊天历史处理逻辑
2025-11-19 23:35:28 +08:00
Windpicker-owo
35899c8aa0
fix(memory): 更新复杂查询示例以提高检索准确率
2025-11-19 23:35:28 +08:00
Windpicker-owo
2bb7e6294e
feat(memory): 优化记忆检索助手的查询生成逻辑,更新示例以提高准确性
2025-11-19 23:35:27 +08:00
Windpicker-owo
e6f3dfc1e7
feat(tool_history): 实现流工具历史管理器,以增强工具调用跟踪和缓存- 添加了 StreamToolHistoryManager,用于管理聊天流级别的工具调用历史。- 引入了 ToolCallRecord,用于详细记录工具调用,包括执行时间和缓存命中情况。- 集成了内存缓存和全局缓存系统,以高效检索结果。- 更新了 ToolExecutor,以使用新的历史管理器记录和获取工具调用。- 增强了 ExaSearchEngine,以限制返回结果数量并提升答案质量。- 重构了 CacheManager 中的缓存管理,以包括工具调用统计和性能指标。
2025-11-19 23:35:27 +08:00
Windpicker-owo
ec51277539
feat(web_search): 添加答案模式支持,优化Exa搜索引擎的结果处理
2025-11-19 23:35:24 +08:00
Windpicker-owo
de24580dec
feat: 将 JSON 处理库从 json 更改为 orjson,以提高性能和兼容性
2025-11-19 23:35:23 +08:00
Windpicker-owo
cbe94f3fa8
feat(memory): 添加图扩展功能,支持语义相似度过滤与深度探索
2025-11-19 23:35:22 +08:00
Windpicker-owo
60cecbcd58
feat: 实现多查询生成与融合搜索,简化记忆检索逻辑
2025-11-19 23:35:22 +08:00
Windpicker-owo
c77273e0dd
feat: 添加具有服务器和简单模式的内存图可视化工具
...
-实现了用于启动内存图可视化工具的PowerShell脚本(visualizer.ps1)。
-开发了一个完整的服务器(visualizer_server.py),为可视化内存图数据提供了web API。
-创建了一个简单的独立版本(visualizer_simple.py),可以直接从存储的数据文件生成可视化。
-添加了用于获取完整图形数据、内存详细信息、搜索内存和检索统计信息的端点。
-包括列出可用数据文件和选择特定文件进行可视化的功能。
-在整个服务器和简单的可视化脚本中增强错误处理和日志记录。
2025-11-19 23:35:22 +08:00
Windpicker-owo
59081848e2
feat(memory): 移除传统内存系统并优化内存图谱
...
- 移除整个传统内存系统,包括内存系统模块及所有相关组件
- 删除弃用的内存组件:增强型内存激活器、海马体采样器、内存构建器、内存块、内存遗忘引擎、内存格式器、内存融合器、内存管理器、内存元数据索引、内存查询规划器、内存系统、消息集合处理器、消息集合存储、向量内存存储_v2
- 更新内存图配置,采用增强型检索设置
- 优化内存管理器查询功能,以分析完整对话上下文
- 更新机器人配置模板版本至7.6.1,新增内存图表检索参数
重大变更:旧版内存系统已被完全移除。所有内存功能现依赖于内存图系统。请更新配置以包含新的内存图检索参数。
2025-11-19 23:34:57 +08:00
Windpicker-owo
b6a693895b
feat: 重构聊天系统的内存处理与格式化功能
...
- 更新了DefaultReplyer,采用新的内存格式化工具以提供更优质的内存描述。
- 已移除 Config 类中已弃用的内存配置。
- 在主系统中增强内存系统初始化检查,确保配置正确。
- 优化了MemoryManager,使其可直接使用全局配置进行内存设置。
- 新增了一个内存格式化工具,用于将内存对象转换为自然语言描述。
- 更新了内存工具,提供了更清晰的内存创建与管理指南。
- 精炼插件工具与使用提示,提升用户交互体验与记忆准确性。
- 根据内存系统结构的变化调整了机器人配置模板。
2025-11-19 23:32:11 +08:00
Windpicker-owo
7bb0248ca2
feat(memory): 添加自动关联功能及相关配置支持
2025-11-19 23:32:10 +08:00
Windpicker-owo
f23f146d28
docs(memory-graph): 添加完整的使用文档
...
- 创建memory_graph_guide.md (完整使用指南)
- 创建memory_graph_README.md (快速开始)
- 更新TODO.md (标记记忆图系统完成)
文档内容:
- 系统概述和核心特性
- 配置说明 (35+配置项)
- LLM工具使用示例
- 代码使用示例
- 最佳实践建议
- 故障排除指南
- 迁移指南
- API参考
完成状态:
Step 1-5 全部完成
所有集成测试通过 (5/5)
文档完整
2025-11-19 23:32:09 +08:00
Windpicker-owo
5439e3bd82
fix(memory-graph): 修复集成测试问题
...
- 修复Config类memory字段验证问题 (改为Optional)
- 为Memory模型添加activation属性
- 修复CreateMemoryTool返回值 (添加memory_id)
- 为GraphStore添加remove_memory方法
- 修复integration测试脚本
- 所有集成测试通过 (5/5)
Changes:
- src/config/config.py: memory字段改为Optional
- src/memory_graph/models.py: 添加activation属性
- src/memory_graph/plugin_tools/memory_plugin_tools.py: 返回memory_id
- src/memory_graph/storage/graph_store.py: 添加remove_memory方法
- tests/test_memory_graph_integration.py: 修复工具返回值检查
Tests:
基本记忆操作 (CRUD + 检索)
LLM工具集成 (创建记忆)
记忆生命周期 (激活/整合/遗忘)
维护任务 (调度+手动执行)
配置系统 (默认/自定义/bot_config)
2025-11-19 23:32:09 +08:00
Windpicker-owo
1239b26e6c
fix(config): 更新配置模板版本号 7.5.8 -> 7.6.0
...
变更说明:
- 移除旧 [memory] 配置段
- 新增 [memory_graph] 配置段
- 新增 [memory_legacy] 向后兼容标注
这是一个次版本号更新(配置文件内容大更新)
2025-11-19 23:32:09 +08:00
Windpicker-owo
9deb778e8f
feat(memory): 添加配置系统支持,移除旧memory配置
...
重大改进:
- 在 bot_config_template.toml 添加 [memory_graph] 配置段
- 移除旧的 [memory] 配置段(~85行)
- 更新 MemoryGraphConfig 支持从 bot_config 加载
- 更新 MemoryManager 使用配置参数
- 更新 manager_singleton 支持配置初始化
配置系统:
- enable: 启用/禁用记忆图系统
- data_dir: 数据存储目录
- 向量存储: collection_name, db_path
- 检索: top_k, min_importance, similarity_threshold
- 智能查询优化: enable_query_optimization
- 整合: enabled, interval_hours, similarity_threshold, time_window
- 遗忘: enabled, activation_threshold, min_importance
- 激活: decay_rate, propagation_strength, propagation_depth
- 性能: max_nodes_per_memory, max_related_memories
配置加载流程:
1. MemoryGraphConfig.from_bot_config(global_config)
2. 使用 getattr 安全获取配置值
3. 提供默认值作为后备
使用配置:
- MemoryManager 从 config 读取所有参数
- maintenance 使用 consolidation_* 参数
- auto_forget_memories 使用 forgetting_* 参数
- activate_memory 使用 activation_* 参数
向后兼容:
- [memory_legacy] 保留旧配置供参考
- [vector_db] 保留给其他系统使用
- 新系统使用独立 chromadb 实例
完成 Step 4: 添加配置支持
2025-11-19 23:32:08 +08:00
Windpicker-owo
75951e8732
feat(memory): 集成 unified_scheduler 实现定期记忆维护
...
重大改进:
- 在 MemoryManager 中添加调度器集成
- 使用 unified_scheduler 定期执行维护任务
- 实现 consolidate_memories 记忆整合方法
- 优化 shutdown 流程,确保调度任务正确停止
技术实现:
- start_maintenance_scheduler: 创建定期维护任务
- stop_maintenance_scheduler: 停止调度任务
- maintenance: 整合、遗忘、保存数据
- consolidate_memories: 合并相似记忆
调度配置:
- 触发类型: TriggerType.TIME
- 默认间隔: 1小时 (3600秒)
- 任务类型: 循环任务 (is_recurring=True)
- 任务名称: memory_maintenance
维护流程:
1. 记忆整理: 合并相似度0.85的记忆
2. 自动遗忘: 遗忘激活度<0.1的记忆
3. 数据保存: 持久化图存储
4. 统计报告: 返回维护结果
测试验证:
- 调度任务成功注册
- 任务信息正确 (循环、TIME类型)
- 初始化时自动启动
- shutdown时自动停止
完成 Step 3: 实现定期记忆整理
2025-11-19 23:32:08 +08:00
Windpicker-owo
c4d8a132cc
feat(memory): 添加智能查询优化,移除瞬时记忆处理
...
重大改进:
- 在 MemoryManager 中添加 optimize_search_query 方法
- 使用小模型优化搜索查询,提高检索精确度
- search_memories 新增 optimize_query 和 context 参数
- 移除瞬时记忆处理(由其他系统负责)
技术实现:
- 使用 utils_small 模型优化查询语句
- 自动提取查询核心意图和关键信息
- 支持上下文感知(聊天历史、发言人)
- 失败时自动降级到原始查询
查询优化流程:
1. 提取聊天历史和发言人信息
2. 构建查询上下文
3. 调用小模型生成优化查询
4. 使用优化查询进行语义搜索
5. 返回相关记忆
default_generator.py 调整:
- 移除瞬时记忆处理逻辑
- 调用 manager.search_memories 时传入 context
- 启用 optimize_query 参数
2025-11-19 23:32:08 +08:00
Windpicker-owo
c764b076ca
refactor(memory): 完全移除旧记忆系统,全面切换到新记忆图系统
...
重大变更:
- 移除 default_generator.py 中对旧增强记忆系统的所有调用
- 移除 prompt.py 中的记忆构建函数
- 记忆检索全面使用新记忆图系统
- 禁用旧记忆系统的自动存储逻辑
记忆构建流程:
- 记忆创建: LLM 通过 create_memory 工具主动创建
- 记忆检索: default_generator.py 自动检索
- 记忆传递: 通过 pre_built_params 传入 prompt
工具可用性:
- CreateMemoryTool: available_for_llm = True
- LinkMemoriesTool: available_for_llm = False
- SearchMemoriesTool: available_for_llm = False
技术细节:
- 提高记忆检索数量 top_k=10
- 降低重要性阈值 min_importance=0.3
- 修复类型错误和警告
2025-11-19 23:32:07 +08:00
Windpicker-owo
44ddd294c2
feat(memory-graph): Step 2 - 集成记忆检索到提示词生成
...
- 修改 build_memory_block 方法,添加记忆图系统检索
- 在提示词构建时自动从记忆图系统中检索相关记忆
- 合并增强记忆系统和记忆图系统的检索结果
- 更新记忆格式化代码以使用合并后的记忆列表
技术细节:
- 使用 manager_singleton 获取全局记忆管理器
- 调用 search_memories 检索相关记忆 (top_k=5, min_importance=0.5)
- 将记忆格式化为兼容的数据结构并合并到 all_memories
- 保持与现有增强记忆系统的兼容性
测试验证:
- 成功创建测试记忆并检索
- 不同查询能找到相应的相关记忆
- 记忆图系统可正常被提示词生成器调用
2025-11-19 23:32:07 +08:00
Windpicker-owo
01d754d5f9
feat(memory-graph): Step 1 - 集成记忆工具到插件系统
...
完成记忆系统工具的插件化集成:
1. 创建记忆工具适配器 (memory_plugin_tools.py)
- CreateMemoryTool: 创建新记忆
- LinkMemoriesTool: 关联两条记忆
- SearchMemoriesTool: 搜索相关记忆
- 适配 BaseTool 接口,支持 LLM 调用
2. 创建全局 MemoryManager 单例 (manager_singleton.py)
- initialize_memory_manager(): 初始化全局实例
- get_memory_manager(): 获取单例实例
- shutdown_memory_manager(): 关闭管理器
- 线程安全的单例模式
3. 创建记忆系统插件 (plugins/memory_graph_plugin/)
- MemoryGraphPlugin: 插件主类
- 自动注册3个记忆工具到系统
- on_plugin_loaded(): 初始化 MemoryManager
- on_unload(): 清理资源
4. 修复类型问题
- ToolParamType.OBJECT STRING (JSON格式)
- ToolParamType.NUMBER FLOAT
- attributes 参数支持 JSON 字符串解析
- 修复 min_importance None 比较错误
5. 添加集成测试 (test_plugin_integration.py)
- 测试工具导入和定义
- 测试 MemoryManager 初始化
- 测试工具执行(创建、搜索记忆)
- 测试单例模式
测试结果: 所有测试通过
LLM 现在可以通过工具调用主动管理记忆!
2025-11-19 23:32:07 +08:00