雅诺狐
10bb3a45b9
feat(logger): 增强日志系统,支持动态配置和文件压缩
...
- 添加动态logger元数据注册表,支持颜色和别名的运行时配置
- 实现日志文件自动压缩为tar.gz格式,节省存储空间
- 增强文件保留策略,支持配置保留天数(0=禁用,-1=永不删除,N>0=保留N天)
- 优化日志清理任务调度,改为每天午夜执行
- 改进TimestampedFileHandler的轮转逻辑和错误处理
- 更新配置模板,版本升级至7.1.7
2025-10-04 19:01:07 +08:00
minecraft1024a
46d6acfdcc
feat(api): 新增机器人消息统计接口
...
新增 `/messages/bot_stats_by_chat` 端点,用于统计机器人在指定天数内按聊天会话(群聊或私聊)发送的消息数量。
该接口支持以下功能:
- 通过 `days` 参数指定查询的时间范围。
- 通过 `format` 参数选择是否在结果中包含会话名称,以提高可读性。
2025-10-04 13:18:07 +08:00
minecraft1024a
b4dffde3f0
refactor(api): 简化消息统计和会话名称获取逻辑
...
- 移除 `get_message_stats_by_chat` 中冗余的 `sent` 和 `received` 统计,只保留 `total` 计数,简化了统计逻辑。
- 优化了获取会话名称的方式,直接从 `chat_manager` 的 `streams` 中查找,统一了群聊和私聊的处理流程,提高了代码的可读性和效率。
- 删除了一个不再需要的测试日志。
2025-10-04 13:14:15 +08:00
minecraft1024a
346353670d
feat(api): 增强消息统计接口,支持格式化输出
...
为 `/messages/stats/by_chat` 端点添加了一个新的 `format` 查询参数。当 `format=True` 时,API 响应将包含更友好的信息,如群聊名称和用户昵称,而不仅仅是 ID。
这通过集成 `chat_api` 和 `person_api` 来获取相应的会话和用户信息,从而提高了接口的可用性和数据可读性。
2025-10-04 13:09:48 +08:00
minecraft1024a
7d9bfb7fca
feat(api): 新增按聊天流统计消息的API端点
...
新增了一个API端点 `/messages/stats_by_chat`,用于根据指定的天数统计消息数据。该端点支持按聊天流进行分组,并提供了按用户进一步分组以及过滤机器人自身消息的选项。
主要功能包括:
- 按指定天数范围查询消息。
- 按聊天流(chat_id)聚合统计数据,包括总消息数、发送数和接收数。
- 可选地按用户(user_id)在每个聊天流内进行分组统计。
- 可选地过滤掉机器人自身发送的消息。
2025-10-04 12:57:43 +08:00
Windpicker-owo
49025a4973
fix(main): 修复主程序的异步初始化逻辑
2025-10-04 12:45:11 +08:00
Windpicker-owo
43724a4d6d
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-04 12:39:37 +08:00
Windpicker-owo
675caca04b
fix(memory): 修复定时清理任务的异步执行问题
2025-10-04 12:39:26 +08:00
minecraft1024a
a1afbbb4dc
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-04 12:10:11 +08:00
minecraft1024a
2a7c2772d0
fix(express): 修复异步会话中错误的删除操作
...
在 `ExpressionLearner` 的 `decay` 方法中,`session.delete(expr)` 操作是同步的,但在异步会话(`AsyncSession`)上下文中应该使用 `await`。此更改修复了该问题,确保表达式能被正确地异步删除。
2025-10-04 12:07:39 +08:00
Windpicker-owo
b1eb831d68
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-04 01:38:47 +08:00
Windpicker-owo
04e7776a45
refactor(memory): 移除废弃的记忆系统备份文件,优化消息管理器架构
...
移除了deprecated_backup目录下的所有废弃记忆系统文件,包括增强记忆适配器、钩子、集成层、重排序器、元数据索引、多阶段检索和向量存储等模块。同时优化了消息管理器,集成了批量数据库写入器、流缓存管理器和自适应流管理器,提升了系统性能和可维护性。
2025-10-04 01:38:41 +08:00
tt-P607
df5a4c717b
refactor(proactive_thinker): 优化决策提示词,避免在仅有自身消息时刷屏
...
为了防止在没有其他人回复的情况下出现自言自语或刷屏的现象,为主动思考模块的决策提示词增加了一条新规则。
该规则指示模型在判断是否主动发言时,如果上下文中仅存在自身发送的消息,则倾向于不回复,以提升交互的自然性和用户体验。
2025-10-03 22:14:58 +08:00
tt-P607
089107a271
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-03 22:14:30 +08:00
tt-P607
a8a42694f5
refactor(proactive_thinker): 优化决策提示词,增加日程与历史记录上下文
...
为了让主动思考的决策更加贴近当前情境,对决策提示词(Prompt)进行了重构。
- **增强情境感知**:在提示词中增加了日程安排、最近聊天摘要和近期动作历史,为 AI 提供更全面的决策依据。
- **优化结构**:将所有上下文信息整合到“情境分析”部分,使提示词结构更清晰,便于模型理解。
- 修复了获取最近消息时参数传递的错误。
2025-10-03 22:11:49 +08:00
Windpicker-owo
1eb41f8372
refactor(memory): 重构记忆系统架构,引入可配置的采样策略
...
将记忆系统从单一构建模式重构为多策略可配置架构,支持灵活的采样行为控制:
核心架构改进:
- 重构记忆构建流程,分离采样策略与核心逻辑
- 引入MemorySamplingMode枚举,标准化采样模式定义
- 设计插件化采样器接口,支持海马体后台定时采样
- 优化记忆处理管道,添加bypass_interval机制支持后台采样
配置系统增强:
- 新增memory_sampling_mode配置项,支持hippocampus/immediate/all三种模式
- 添加海马体双峰采样参数配置,支持自定义采样间隔和分布
- 引入自适应采样阈值控制,动态调整记忆构建频率
- 完善精准记忆配置,支持基于价值评分的触发机制
兼容性与性能优化:
- 修复Python 3.9兼容性问题,替换strict=False参数
- 优化记忆检索逻辑,统一使用filters参数替代scope_id
- 改进错误处理机制,增强系统稳定性
BREAKING CHANGE: 新增memory_sampling_mode配置项,默认值从adaptive改为immediate
2025-10-03 22:00:53 +08:00
tt-P607
bb4ff48e26
refactor(proactive_thinker): 优化主动思考的决策与交互,使其更自然且避免打扰
...
本次提交对主动思考插件进行了多项核心优化,旨在提升其交互的自然度和人性化,并引入了关键的防打扰机制。
主要变更包括:
1. **重构冷启动任务 (`ColdStartTask`)**:
- 任务逻辑从一个长期运行的周期性任务,重构为在机器人启动时执行一次的“唤醒”任务。
- 新逻辑不仅能为白名单中的全新用户发起首次问候,还能智能地“唤醒”那些因机器人重启而“沉睡”的聊天流,确保了主动思考功能的连续性。
2. **增强决策提示词 (`_build_plan_prompt`)**:
- 引入了更精细的决策原则,核心是增加了防打扰机制。现在模型在决策时会检查上一条消息是否为自己发送,如果对方尚未回复,则倾向于不发起新对话,以表现出耐心和体贴。
- 优化了示例,引导模型优先利用上下文信息,并在无切入点时使用简单的问候,避免创造生硬抽象的话题。
3. **改善回复生成逻辑 (`_build_*_reply_prompt`)**:
- 在生成回复的指令中,明确要求模型必须先用一句通用的礼貌问候语(如“在吗?”、“下午好!”)作为开场白,然后再衔接具体话题。这使得主动发起的对话更加自然、流畅,符合人类的沟通习惯。
4. **模型调整**:
- 将决策规划阶段的 LLM 模型从 `utils` 调整为 `replyer`,以更好地适应生成对话策略的任务。
2025-10-03 21:44:31 +08:00
minecraft1024a
c46a31a7c4
refactor(express): 优化目录创建的异常处理逻辑
...
将 `try-except` 块移至循环外部,以减少重复的异常处理代码。这样可以更清晰地处理在创建多个目录过程中可能发生的任何错误,同时保持代码的简洁性。
2025-10-03 21:17:50 +08:00
minecraft1024a
0e2182efa6
动一下manifest以防加载的时候被用户看笑话()
2025-10-03 21:05:59 +08:00
minecraft1024a
46478d7c14
feat(proactive_thinker): 增加防刷屏决策原则
...
在主动思考的决策原则中增加了一条新规则。
如果群聊的上下文中只有AI自己的消息而没有其他人的回应,AI也许将选择不回复,以避免刷屏。
2025-10-03 20:47:02 +08:00
minecraft1024a
19c37280d4
feat(api): 新增消息统计API端点
...
将原有的获取最近消息的API替换为功能更强大的消息统计API。
新的 `/messages/recent` 端点允许按天数和消息类型(发送、接收或全部)查询机器人的消息数量统计。
- 支持 `days` 和 `message_type` 查询参数。
- 实现统计逻辑,区分机器人发送和接收的消息。
- 增加异常处理,提高API的健壮性。
2025-10-03 20:43:07 +08:00
ikun-11451
09a17e5c12
增加了后端api喵~
2025-10-03 20:21:56 +08:00
minecraft1024a
135909449c
refactor(proactive_thinker): 优化唤醒逻辑并增加防打扰机制
...
重构了日常唤醒任务(ProactiveThinkingTask)的逻辑,将其拆分为私聊和群聊的独立处理流程。
- 私聊现在直接遍历白名单,确保能覆盖到所有配置的用户,即使他们当前不在内存中。
- 群聊则继续遍历内存中的活跃流。
这个改动修复了之前版本中,只有当用户发送消息后,bot才有可能对其进行主动唤醒的问题。
同时,在决策模块中引入了防打扰机制:
- 在决策提示词中加入了最近的决策历史记录作为上下文。
- 增加了新的决策原则,明确指示模型在近期已主动发起过对话的情况下,应倾向于保持沉默,以避免过度打扰用户。
此外,对冷启动任务(ColdStartTask)进行了微调,将初始的等待时间移至循环的开始,以确保插件加载后能先等待一段时间再开始工作。
2025-10-03 19:39:37 +08:00
minecraft1024a
4089e714b7
fix:(proactive_thinker)这beyond的孩子忘了加mood_state,导致主动思考提示词里的情绪输出了一堆乱码()
2025-10-03 18:21:21 +08:00
minecraft1024a
62fe589c8f
fix(proactive_thinker): 修复情绪模块关闭时主动思考报错的问题
...
当全局情绪模块被禁用时,尝试获取情绪状态会导致`AttributeError`或`KeyError`,从而中断主动思考任务。
本次提交通过以下方式修复了此问题:
1. 在获取情绪状态前,增加对`global_config.mood.enable_mood`的判断。
2. 在情绪获取逻辑中加入`try...except`块,捕获潜在的异常,并在失败时提供一个默认的情绪状态,增强了代码的鲁棒性。
3. 在日常唤醒任务的异常处理中,增加了`traceback.print_exc()`,以便在出现错误时打印完整的堆栈跟踪,方便快速定位问题。
2025-10-03 18:19:18 +08:00
minecraft1024a
f4079f10fe
feat(proactive_thinker): 在主动思考中融入情绪状态
...
将情绪状态整合到主动思考的上下文和提示词中。这使得AI在主动发起对话时,其语气和内容能够更好地反映当前的情绪,使交互更加生动和人性化。
主要变更:
- 在上下文收集中增加当前的情绪状态。
- 将情绪状态变量加入到私聊和群聊的提示词模板中,引导模型生成符合情绪的回复。
- 优化了最终的输出指令,使其更清晰、更严格,以提高生成内容的质量。
2025-10-03 17:41:58 +08:00
minecraft1024a
923b989657
docs(proactive_thinker): 为执行器模块添加详细的中文文档字符串
...
为 `ProactiveThinkerExecutor` 类及其所有公共和私有方法添加了详细的 Docstrings。这包括对类、方法功能、参数和返回值的清晰描述,以提高代码的可读性和可维护性。
2025-10-03 17:17:36 +08:00
minecraft1024a
275157c58a
refactor(proactive_thinker): 重构上下文收集与提示词构建逻辑以支持群聊
...
将原有的上下文收集函数 `_gather_context` 和提示词构建函数 `_make_decision`, `_build_plan_prompt` 拆分为更细粒度的模块,以分别处理私聊和群聊场景。
主要变更:
- `_gather_context`: 现在能根据聊天流是群聊还是私聊,收集不同的上下文信息,并添加 `chat_type` 字段以作区分。
- `_build_decision_prompt`: 新增函数,根据 `chat_type` 构建不同的决策提示词,使决策更贴合场景。
- `_build_plan_prompt`: 重构为调度函数,内部调用新增的 `_build_private_plan_prompt` 和 `_build_group_plan_prompt` 来生成特定场景的规划提示词。
- 整体逻辑更加清晰,增强了代码的可读性和可扩展性,为未来支持更多聊天类型奠定了基础。
2025-10-03 17:15:34 +08:00
Windpicker-owo
a2bbb8041a
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-03 16:15:58 +08:00
Windpicker-owo
5c0e94cf4c
refactor(logging): 将信息日志级别更改为调试级别以减少输出噪声
2025-10-03 16:15:32 +08:00
minecraft1024a
9b7077e773
feat(proactive_thinker): 启用并优化主动思考插件
...
- 默认启用主动思考插件,并进行多项功能增强和修复。
- 修复了日常唤醒任务中 `stream_id` 的格式问题,确保能正确调用执行器。
- 调整了冷启动任务的初始等待时间,以更好地适应系统启动流程。
- 优化了执行器中获取日程和聊天流的逻辑,使其更加健壮。
- 简化了部分日志输出,使其更清晰。
- 增加了在调试模式下打印 Planner 和 Responder 提示词的功能,便于调试。
2025-10-03 15:15:21 +08:00
Windpicker-owo
7617f85b92
feat(chat): 增强任务管理和取消机制
...
添加新的任务管理方法来更好地处理异步任务的生命周期:
- 新增 cancel_processing_task、remove_processing_task 等方法
- 在流循环清理时自动取消关联的 chatter 处理任务
- 添加活跃任务统计信息到管理器统计中
- 改进 prompt 构建时的任务类型检查和错误处理
2025-10-03 14:17:29 +08:00
Windpicker-owo
73aa29c4d5
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-03 14:16:31 +08:00
Windpicker-owo
9e1baa7e61
refactor(chat): 优化流循环管理和数据库性能
...
移除StreamLoopManager中的锁机制,简化并发流处理逻辑
- 删除loop_lock,减少锁竞争和超时问题
- 优化流启动、停止和清理流程
- 增强错误处理和日志记录
增强数据库操作性能
- 集成数据库批量调度器和连接池管理器
- 优化ChatStream保存机制,支持批量更新
- 改进数据库会话管理,提高并发性能
清理和优化代码结构
- 移除affinity_chatter中的重复方法
- 改进prompt表达习惯格式化
- 完善系统启动和清理流程
2025-10-03 13:56:58 +08:00
minecraft1024a
e9fbd749d8
ruff
2025-10-03 12:55:45 +08:00
tt-P607
d5c8bde3a2
fix(chat): 修复能量调整计算中的负数幂错误
...
当能量值非常接近高能量阈值(0.7)时,由于浮点数精度问题,`energy - 0.7` 的结果可能为一个极小的负数,这会导致 `ValueError` (negative number cannot be raised to a fractional power)。
通过使用 `max(0, ...)` 来确保幂运算的基数始终为非负数,从而解决了这个潜在的运行时错误,增强了系统的健壮性。
2025-10-03 10:39:21 +08:00
tt-P607
b24eaba7ff
fix(chat): 确保在流取消时正确取消chatter处理任务
...
先前,当一个流循环(stream loop)被取消时,为其创建的 chatter 处理任务(`process_stream_context`)不会被一并取消。
这可能导致任务泄露,即“孤儿”任务在后台继续运行,消耗资源并可能引发意外行为。
本次修改引入了一个任务跟踪机制:
- `ChatterManager`现在会记录每个流正在运行的处理任务。
- 当流循环捕获到 `CancelledError` 时,它会主动取消关联的 chatter 任务。
这确保了在流停止时,相关的计算资源能够被正确、及时地释放,提高了系统的健壮性。
2025-10-03 10:15:24 +08:00
Windpicker-owo
fa9f14388a
refactor(chat): 优化异步任务处理和参数传递机制
...
- 重构ExpressionSelector初始化,添加chat_id参数支持
- 优化StreamLoopManager中异步任务的创建和管理方式
- 简化MessageManager中的消息添加流程
- 调整Prompt中表情选择器的参数传递结构
2025-10-03 02:32:02 +08:00
Windpicker-owo
67154ca78c
perf(chat): 使用asyncio.create_task优化异步任务处理
2025-10-03 01:55:21 +08:00
Windpicker-owo
31d03de33a
refactor(chat): 优化流循环管理器的并发性能和健壮性
...
改进StreamLoopManager的锁机制和任务管理,添加超时控制避免死锁,使用并发操作提升性能,增强异常处理和日志记录确保系统稳定性。
2025-10-03 01:14:53 +08:00
tt-P607
844d4f3362
fix(chat): 增强回复生成的健壮性,增加超时和类型检查
...
在 `DefaultReplyer` 的提示词构建流程中,为并行的子任务(如记忆、工具、关系等)增加了15秒的超时机制。这可以防止因某个子任务耗时过长或卡死而导致整个回复生成过程停滞。
同时,在能量系统中增加了对计算器分数和兴趣值的类型检查,确保它们是数值类型,避免了潜在的 `TypeError` 异常,提高了系统的稳定性。
2025-10-02 23:22:00 +08:00
minecraft1024a
58688c5e49
refactor(social_toolkit): 优化戳一戳动作的描述和参数
...
将 `poke_user` 动作的激活类型更改为 `ALWAYS`,并简化了其描述和判断条件,使其更加清晰明确,专注于核心规则。同时,将动作参数 `user_id` 修正为 `qq_id` 以符合实际实现。
2025-10-02 22:03:01 +08:00
minecraft1024a
fa3b0464df
Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox_Bot into dev
2025-10-02 21:58:10 +08:00
minecraft1024a
56a75afadf
fix(adapter): 修复表情回应命令并移除废弃的emoji映射
...
- 修复了`napcat_adapter`中表情回应命令名称不一致的问题,将`set_emoji_like`统一为`set_msg_emoji_like`。
- 修正了`SendHandler`中`set_like`参数的类型转换,从`str`改为`bool`,以符合API要求。
- 移除了`social_toolkit_plugin`中已废弃且不准确的Unicode emoji到QQ表情文本的映射。
- 更新了配置文件模板的版本号至`7.1.5`。
2025-10-02 21:58:07 +08:00
minecraft1024a
15fdb67ef7
fix(LLM_Client):修复了API 密钥的动态轮询机制
2025-10-02 21:24:30 +08:00
John Richard
5ec08fc7d2
Merge pull request #9 from JohnRichard4096/dev
...
Begin: 重置代码格式,修复少量类型问题
2025-10-02 21:16:37 +08:00
John Richard
047105e5e8
更改部分类型注解
2025-10-02 21:10:36 +08:00
John Richard
7923eafef3
re-style: 格式化代码
2025-10-02 20:26:01 +08:00
John Richard
ecb02cae31
style: 格式化代码
2025-10-02 19:38:39 +08:00
minecraft1024a
d5627b0661
refactor(chat): 将消息获取相关函数重构为异步
...
将 `chat_message_builder` 中的多个同步消息获取函数(如 `get_raw_msg_by_timestamp`)及其调用全部修改为异步函数。这统一了数据库查询的异步模式,提高了代码一致性和可维护性。
主要改动包括:
- 将 `chat_message_builder.py` 中的数据库查询函数标记为 `async` 并使用 `await`。
- 更新了 `message_api.py`、`mood_manager.py` 和 `qzone_service.py` 中对这些函数的调用,以适应异步接口。
- 调整了 `message_api.py` 中的函数签名和返回类型提示,以反映异步特性。
2025-10-02 17:32:02 +08:00