Commit Graph

709 Commits

Author SHA1 Message Date
tt-P607
fa8555aeb7 docs(prompt): 完善用户资料工具使用指南
加强了 `UserProfileTool` 文档字符串中的规则,以确保语言模型捕获的数据更高质量、更准确。

此更改引入了明确且严格的标准,规定什么构成有效的 `alias`(别名)、`preference`(偏好)和 `key_info`(关键信息)。目标是防止模型将对话噪音、主观解读或临时互动存储为真实用户数据。

- **别名(Alias):** 必须是明确说明的昵称,不得为临时或开玩笑的称呼。
- **偏好(Preference):** 限于现实世界的爱好和兴趣,不包括对话中的动态内容。
- **关键信息(Key Info):** 限于客观且可验证的事实,不包括主观感受或关系描述。
2025-12-05 02:58:59 +08:00
Windpicker-owo
63cb81aab6 fix: 更新配置文件,禁用身份压缩以提高回复性能
refactor: 移除日志信息以简化回复和响应动作
2025-12-04 22:49:56 +08:00
Windpicker-owo
43e25378c8 feat(napcat): 添加事件处理过滤机制,支持黑白名单功能 2025-12-04 21:33:50 +08:00
tt-P607
12e66a328c feat(chatter): 通过更严格、更抽象的规则增强用户印象生成
生成用户印象的提示已被大幅优化,以提高一致性、质量和情感深度。

之前的指导可能导致生成的印象过于字面化,更像聊天记录而非个性档案。同时也缺乏保留之前确认信息的强规则。

此次更新引入了几个关键变化:
- 增加了一条高优先级规则以保持已有确认的事实,例如性别,防止其被覆盖。
- 将核心任务重新定义为捕捉“抽象的感觉”和“个性轮廓”,而非详细的“肖像”。
- 明确禁止具体细节,如姓名、特定事件或行动,以强制实现更高层次的抽象。
- 鼓励采用更具印象派风格、诗意的写作方式,以更好地传达用户的气质和互动氛围。

这些变化旨在生成更稳定、情感共鸣且历久弥新的用户档案。
2025-12-04 19:23:32 +08:00
tt-P607
daf6b51763 feat(chatter): 改进用户资料管理和主动跟进
此提交对两个核心聊天组件进行了重大增强:用户资料工具和主动思维逻辑。

在用户资料工具(`affinity_flow_chatter`)中:
- 用基于操作的系统(添加、删除、替换)替换了对别名和偏好的简单字符串替换,以实现更精细的控制。
- 实现了动态分阶段关系评分模型,其变化幅度取决于当前的关系水平,使关系进展更为真实。
- 重新设计了印象生成提示,引导大语言模型生成更多叙述性、散文风格的用户描述。
- 添加了数据质量过滤器,以拒绝模糊的关键信息,并防止高质量的现有数据被低质量更新覆盖。

在主动聊天(`kokoro_flow_chatter`)中:
- 引入了新的 `followup_count` 来跟踪用户静默期间实际发送的消息数量。
- 这个计数现在用于超时提示中,以向大型语言模型提供更清晰的信号,显示它已经提示用户的次数,从而防止过度跟进。
2025-12-04 14:09:24 +08:00
tt-P607
22767ce234 feat(context): 为大语言模型提供过去网页搜索的上下文记忆
此更改使聊天机器人能够记住并引用过去网页搜索的相关信息,从而显著提高响应质量和连贯性。

系统不再将每个查询视为孤立事件,而是在生成新响应之前,对之前的 `web_search` 结果缓存进行向量相似度搜索。如果发现过去的相关信息,会自动作为“相关历史搜索结果”注入到大语言模型的提示中。

这使模型能够立即访问相关背景信息,避免对已经讨论过的主题重复搜索。

为了支持这一新功能:
- 对 `web_search` 工具的提示进行了改写,以通过确保结果被高效缓存和调用,鼓励大语言模型更频繁地使用它。
- 重要工具结果(如网页搜索)的预览长度已增加
2025-12-04 04:12:36 +08:00
tt-P607
f519f87884 Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox-Core into dev 2025-12-04 03:19:59 +08:00
tt-P607
d466ddaec8 refactor(search): 将 Exa 引擎迁移到 search_and_contents API
此提交将 Exa 搜索引擎更新为使用 `search_and_contents` 方法,而不是之前的 `search` 方法。

`search_and_contents` 端点更高效,并且可以直接提供高亮片段。此更改用更具上下文感知的高亮替代了对摘要的依赖,从而显著提高了搜索结果的质量和相关性。
2025-12-04 03:19:52 +08:00
Windpicker-owo
4a75b3c0ea feat(notice): 增加消息摘要提取功能并优化表情回复处理 2025-12-03 23:35:59 +08:00
tt-P607
7c35c0a0f5 refactor(profile): 重构用户分析工具以实现更严格的现实分析
用户分析工具的内部逻辑和提示已显著优化,以生成更准确的长期用户印象并更真实地计算情感变化。

- 工具描述现在鼓励更频繁使用以实现实时更新,而不仅仅是重大事件。
- 印象生成提示增强以区分用户实际性格和讨论的虚构内容(如游戏剧情)。
- 写作指南严格要求创建长期抽象印象,避免短期对话记录。
- 情感变化规则变得极其严格,将变化范围缩小到±0.02,并强调大多数互动应导致零变化以反映关系建立的缓慢性。
- `history_ttl`减少为1,符合新理念的更频繁、轻量级更新。
2025-12-03 19:39:35 +08:00
tt-P607
cba6d34197 Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox-Core into dev 2025-12-03 17:02:39 +08:00
tt-P607
2671a6e7e5 feat(profile):对用户关系和分析系统进行重构,采用结构化数据和异步更新
此提交完全重写了用户关系和分析系统,创建了一个更强大、详细和响应式的框架。旧系统已被弃用,取而代之的是一个集中式的`UserRelationships`模型。

主要变更:

1.  ‌**增强数据库模型(`UserRelationships`):**‌
    - 添加`impression_text`用于长期、叙述式印象。
    - 引入`key_facts`(JSON)存储结构化数据如生日、工作和位置。
    - 添加`relationship_stage`跟踪关系进展(如陌生人、朋友、挚友)。
    - 添加`first_met_time`和`last_impression_update`的时间戳。

2.  ‌**重设计`UserProfileTool`:**‌
    - 工具的用途被限定为仅捕捉重要新信息,防止用于小聊。
    - 更新现在在后台异步处理,确保机器人回复不被延迟。
    - 引入`key_info_type`和`key_info_value`参数供LLM提交结构化事实。

3.  ‌**复杂的印象和情感逻辑:**‌
    - 关系追踪LLM现在分析最近聊天历史生成更丰富、更上下文的印象。
    - 用渐进的`affection_change`(最大±0.03)取代直接情感分数设置,使关系发展更真实。

4.  ‌**数据源整合:**‌
    - `RelationshipFetcher`重构为仅依赖`UserRelationships`表作为唯一数据源。
    - 简化`get_user_relationship` API并移除其缓存,确保分析的实时数据访问。

破坏性变更:`UserProfileTool`已重设计,新增参数(`key_info_type`、`key_info_value`)并改变用途。移除`affection_score`参数。此外,`get_user_relationship`数据库API签名简化为仅接受`user_id`。
2025-12-03 16:53:40 +08:00
Windpicker-owo
55919f90db feat(context_builder): 更新记忆块构建逻辑,添加查询文本获取策略以提升记忆检索效果
feat(prompt_builder): 扩展上下文数据构建,支持会话和情况类型参数以优化提示词生成
2025-12-03 14:30:40 +08:00
tt-P607
39c52490d9 feat(chatter): 整合工具使用并增强主聊天流程中的上下文
此提交为聊天系统引入了若干重大增强,以提高回应质量、上下文感知能力和角色一致性。

**Kokoro 流程中的工具整合:**
- 在主聊天提示中新增了一个 `tool_info` 上下文块。
- `KFCContextBuilder` 现在通过 `ToolExecutor` 执行工具后再生成回复,使聊天模型能够感知实时信息和操作。

**以角色为驱动的用户画像:**
- `update_user_profile` 工具被重构为两阶段过程。工具使用模型提供一个简单的“印象提示”,专门的 `relationship_tracker` 模型将其扩展为丰富且符合角色的一致印象。
- 工具使用提示已更新,明确指示模型在生成工具参数时保持机器人的角色。

**记忆系统改进:**
- 记忆检索判定提示已更新,更加主动地获取长期记忆,目标是为了提供更丰富的上下文。- 记忆查询现在从最近的一组消息中生成,而不是单条消息,从而提高检索的相关性。**其他更改:** - 在上下文构建过程中添加了性能时间日志,以识别瓶颈。- 在响应过滤中进行了小修复,以清理特定前缀,如“,说:”。
2025-12-03 14:04:29 +08:00
Windpicker-owo
a36e2fdf92 feat(set_emoji_like): 添加群聊检查,确保表情回应动作仅在群聊中有效 2025-12-03 13:55:37 +08:00
Windpicker-owo
6233e27d46 fix(message_handler): 修复全局封禁用户列表的用户ID处理方式,确保ID为字符串格式 2025-12-03 13:48:15 +08:00
Windpicker-owo
fe48b8cc71 feat(prompt): 添加安全互动准则块以增强用户交互安全性 2025-12-03 13:33:43 +08:00
tt-P607
9a5ae357b5 fix(chatter): 防止 Chatter 和 ProactiveThinker 之间的竞争条件
可能会发生竞争条件,即 ProactiveThinker 在用户发送消息的同时选择一个会话进行主动操作。这将导致 Chatter 和 ProactiveThinker 同时处理该会话,从而产生重复或冲突的响应。

该提交引入了两部分修复:
1. Chatter 现在在接收到消息后会立即更新会话的 `last_activity_at`。这相当于一个软锁,表明该会话正在被主动处理。
2. ProactiveThinker 会在执行操作前对会话状态进行最终检查。如果会话不再处于 `WAITING` 状态,它会中止操作,让位给 Chatter。
2025-12-02 16:38:42 +08:00
tt-P607
1027c5abf7 feat(chat): 添加群组静音功能并提升私聊响应速度
此提交引入了消息处理的两个主要增强功能:

1. **群组静音功能**:
新增的 `mute_group_list` 配置允许指定机器人默认保持沉默的群组。仅在被明确提及(通过@、回复或使用其名称/别名)时,它才会在这些群组中响应,从而减少繁忙频道的噪音。

2. **私聊响应能力**:
消息分发循环现在会动态调整轮询间隔。对于私聊,它使用更短的间隔,从而实现显著更快、接近实时的响应。

此外,此次提交还包括 Kokoro Flow 聊天器的若干改进:
- refactor(kokoro-flow):系统提示进行了大幅修订,以强制执行单个 `kfc_reply` 动作,引导 LLM 生成更可靠且格式正确的输出。
- fix(kokoro-flow):在执行动作时使用 `action.params.copy()`,以防止潜在的副作用来自下游的修改。
2025-12-02 01:40:39 +08:00
Windpicker-owo
aa1afc093b Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox-Core into dev 2025-12-01 20:21:25 +08:00
tt-P607
6b3d185742 Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox-Core into dev 2025-12-01 20:14:39 +08:00
tt-P607
8bb7f39641 feat(kokoro-flow): 添加 PyYAML 依赖并增强 kfc_reply 提示
添加 PyYAML 作为依赖,以支持未来在 Kokoro Flow Chatter 插件中基于 YAML 的配置和功能。

`kfc_reply` 动作的提示已更新,明确指示模型将其完整响应整合为单个动作调用,防止出现分散或多条回复。
2025-12-01 20:14:33 +08:00
Windpicker-owo
943c2a6566 feat(data-models): 使用 __slots__ 优化内存占用和属性访问性能,更新多个数据模型 2025-12-01 19:57:33 +08:00
Windpicker-owo
e72f39c42b Merge branch 'dev' of https://github.com/MoFox-Studio/MoFox-Core into dev 2025-12-01 18:44:41 +08:00
Windpicker-owo
b46ad71d20 feat(emoji): 添加提取精炼描述的辅助函数并优化表情包发送信息 2025-12-01 18:44:31 +08:00
tt-P607
048ce37c63 refactor(kokoro-flow): 增强对 max_wait_seconds 和超时决策的提示指导
此提交重构了 Kokoro Flow Chatter 插件中的提示,以提供更清晰、更接近人类的指导,帮助设置 `max_wait_seconds` 并处理对话超时问题。目标是改善 LLM 的决策能力,使对话节奏更自然。

主要更改包括:
- 在所有相关提示中统一并详细说明 `max_wait_seconds` 的使用,鼓励根据上下文设置,而不是默认使用 0。
- 重新设计了超时决策提示 (`kfc_SITUATION_TIMEOUT`),提供结构化的“决策指导”和“决策选项”,帮助 LLM 在等待、重新参与或结束等待之间做出更细致的选择。
- 在 NapCat 适配器中添加修复,确保 `reply` 消息段始终优先位于消息列表开头,防止潜在的发送错误。
- 对日志输出进行了小幅格式调整,以提高可读性。
2025-12-01 18:20:53 +08:00
拾风
28c54dbec6 Merge branch 'dev' into feature/kfc 2025-12-01 16:06:47 +08:00
tt-P607
5ceef537d0 Merge branch 'feature/kfc' of https://github.com/MoFox-Studio/MoFox-Core into feature/kfc 2025-12-01 14:45:46 +08:00
tt-P607
127d0e039e refactor(kfc): 移除 kfc_reply 回复分段逻辑及相关提示
移除 `kfc_reply` 动作的 `enable_splitter` 强制禁用逻辑,并简化了统一模式下的提示词,不再指导模型如何进行消息分段。

此次重构旨在将消息分段的决策权完全交还给大语言模型,使其能够根据对话上下文和自身判断,更自然地决定回复的格式(单条或多条消息)。这简化了处理逻辑,并有望提升模型回复的流畅度和拟人化程度。
2025-12-01 14:45:41 +08:00
Windpicker-owo
cef52ce963 Merge branch 'feature/kfc' of https://github.com/MoFox-Studio/MoFox-Core into feature/kfc 2025-12-01 10:27:57 +08:00
Windpicker-owo
0154c8fedd feat: 增加连续超时计数和用户最后回复时间,优化超时决策上下文信息 2025-12-01 09:20:03 +08:00
tt-P607
5d14bab259 feat: 为Kokoro Flow Chatter实现统一模式,支持模块化提示生成
新增统一模式:通过单次LLM调用同时处理推理与响应生成
采用模块化提示组件:系统提示与用户提示分离,提升灵活性和可维护性
日志更新:更清晰地记录生成响应与执行动作
版本更新:在机器人配置模板中递增版本号以反映变更
上下文处理优化:改进用户交互与记忆管理
2025-12-01 01:32:56 +08:00
ikun-11451
9b915c4dd2 feat: 添加私聊必回功能喵~ (Private Chat Inevitable Reply) 2025-11-30 22:16:56 +08:00
ikun-11451
46359a8933 应该是把私聊必回加回来了喵? 2025-11-30 21:51:09 +08:00
Windpicker-owo
35c4937068 feat: 优化 KFC 主提示词模板,调整结构和字段说明,增强可读性 2025-11-30 21:35:17 +08:00
Windpicker-owo
9d0488ef5a feat: 重构 KFC 回复动作,优化回复生成流程和上下文注入 2025-11-30 21:01:02 +08:00
Windpicker-owo
1288fd6cf7 feat: 添加主动思考配置选项,优化问候功能和触发概率设置 2025-11-30 20:41:30 +08:00
Windpicker-owo
6330faa793 feat: 移除戳一戳动作的显示消息,简化发送逻辑 2025-11-30 20:33:49 +08:00
Windpicker-owo
b148463f66 feat: 优化主动思考器和提示词构建逻辑,新增用户关系和等待思考提示词模板 2025-11-30 20:20:23 +08:00
Windpicker-owo
c45f0e9cea feat: 添加获取用户名称的方法,优化超时决策和主动思考中的用户名处理 2025-11-30 19:54:36 +08:00
Windpicker-owo
8e26a5f58c feat: 重构Kokoro Flow Chatter,新增规划器和回复生成器,优化提示词构建逻辑 2025-11-30 18:50:21 +08:00
Windpicker-owo
673da5cc8b feat: 更新提示词构建逻辑,增强说话风格提示信息 2025-11-30 17:48:05 +08:00
Windpicker-owo
7eb784f137 feat: 实施Kokoro Flow Chatter提示管理系统
- 在Kokoro Flow Chatter中添加提示模块以管理提示信息。
引入PromptBuilder,用于根据会话上下文构建提示。
- 为各种场景创建提示模板,包括用户消息、机器人规划和等待更新。
- 开发一个回复模块,使用LLM API生成回复。
- 建立会话管理机制,以处理用户交互并维护会话状态。
- 实现日志记录功能,以便更好地追踪操作和错误。
2025-11-30 17:17:14 +08:00
Windpicker-owo
109468a808 feat: 更新KFC V2配置和提示词构建逻辑,支持多种配置项和上下文数据整合 2025-11-30 16:50:15 +08:00
Windpicker-owo
252e8620e1 feat: 重命名Kokoro Flow Chatter V2为Kokoro Flow Chatter,更新相关模块和配置 2025-11-30 16:16:22 +08:00
Windpicker-owo
c6f34992d1 feat(KFC): 更新聊天处理器和回复模块,优化动作名称及上下文构建逻辑 2025-11-30 15:52:01 +08:00
Windpicker-owo
fc85338d0b feat: 更新消息管理和数据库操作日志,增强调试信息 2025-11-30 15:13:01 +08:00
Windpicker-owo
1750004ffa feat: 添加KFC V2专属动作模块及相关功能,优化回复机制 2025-11-30 15:04:00 +08:00
Windpicker-owo
c68bf4ad4f 重构Kokoro Flow Chatter:移除已弃用的响应后处理器和会话管理器
- 删除了`response_post_processor.py`和`session_manager.py`,因为它们已不再需要。
- 更新了`__init__.py`文件,移除了对`ActionExecutor`的引用。
- 删除了`action_executor.py`,并将动作执行直接集成到`chatter.py`和`proactive_thinker.py`中。
- 在`KokoroFlowChatterV2`中重构了动作执行逻辑,以直接使用`ChatterActionManager`。
- 增强了主动思考逻辑,以简化操作执行,而无需依赖已移除的`ActionExecutor`。
2025-11-30 13:40:59 +08:00
Windpicker-owo
0fe15dac52 feat: 使用提示管理和会话处理来实现Kokoro Flow Chatter V2
- 在Kokoro Flow Chatter V2中添加提示模块以管理提示信息。
- 创建一个构建器,用于根据用户交互和会话上下文构建提示。
- 为不同场景(新消息、及时回复等)注册各种提示模板。
- 开发一个回复模块,使用LLM API生成回复。
- 实现会话管理以处理用户交互并维护状态。
- 引入心理日志条目以追踪用户与机器人的交互情况。
- 确保各模块中都有适当的日志记录和错误处理。
2025-11-30 13:05:26 +08:00