liuwei
|
96f50d929b
|
关键调整:
social_short 从“1句 + 1条”改成“最多2句 + 最多2条”,允许续发,避免戛然而止。
qa_fast / qa_with_context 也改为允许分条续发,避免中间硬断。
smart_clip 的弱标点回看窗口从 4 提高到 12,更容易切在自然停顿处(逗号/顿号等)。
同步更新了长度规则文案:明确“必要时可拆两条,保证语义完整”。
你给的这句原文在新逻辑下会优先拆成两条,而不是第一条被截到“我听着怎么这”这种半句。
|
2026-04-15 10:52:33 +08:00 |
|
liuwei
|
5ce60cbd95
|
我已经把群总结这块从“前 120 字硬砍”改成了“关键句提炼 + 更高上限”。
已改文件:
context_builder.py
具体优化:
原来:
group_memory_summary 超过 120 字就直接 summary[:117] + "...",很容易把后面的关键结论截掉。
现在:
新增 _compact_group_summary(...)。
先按句拆分,再给句子打分,优先保留包含“结论/风险/报错/配置/策略/优化”等关键词的句子。
同时保留首句和末句,避免上下文断裂。
最终摘要上限提高到 420 字、最多 6 句,再做兜底截断。
prompt 字段名也改成 群长期摘要关键句,让模型更明确这是提炼后的重点。
|
2026-04-15 10:37:27 +08:00 |
|
liuwei
|
265f3835b4
|
已按你说的改成“命中即跳出 + 后台入队处理”,插件调度仍然是独占策略,没有做并行插件处理。
主要改动在 main.py:
process_message(...) 现在只做入队,立刻返回 True, "queued",主链路立即释放。
原来的完整处理逻辑迁到 _process_message_impl(...),由后台 worker 消费队列执行。
新增队列 worker 循环 _message_worker_loop(...),并在 start()/stop() 管理生命周期。
增加 _ensure_workers_started(),避免插件在无事件循环阶段 create_task 报错(延迟到有 loop 时启动)。
保留了之前的 LLM 防阻塞措施:to_thread + semaphore + timeout。
配置也加在 config.toml 的 [runtime]:
llm_max_concurrency = 3
llm_call_timeout_sec = 120
queue_worker_count = 2
queue_maxsize = 500
已做语法校验:py_compile 通过。
|
2026-04-15 10:23:05 +08:00 |
|
liuwei
|
e2b19c0614
|
refactor(ai_auto_response): relax short reply truncation
|
2026-04-13 09:55:23 +08:00 |
|
liuwei
|
0e3eda8865
|
tune(ai_auto_response): shorten llm replies
|
2026-04-13 09:05:41 +08:00 |
|
liuwei
|
4e7a8e6798
|
fix(ai_auto_response): clean think noise from parsed fields
|
2026-04-10 17:06:13 +08:00 |
|
liuwei
|
52392edcc0
|
fix(ai_auto_response): sanitize dify wrapped think output
|
2026-04-10 16:59:18 +08:00 |
|
liuwei
|
f3354d39a8
|
fix(ai_auto_response): keep complete social short replies
|
2026-04-10 16:54:12 +08:00 |
|
liuwei
|
0c90c5d74f
|
fix(ai_auto_response): avoid forced split of single short replies
|
2026-04-10 16:51:11 +08:00 |
|
liuwei
|
5e80287530
|
切换到dify,还是不要直连,dify更方便
|
2026-04-10 16:41:14 +08:00 |
|
liuwei
|
f96e891ad9
|
tune(ai_auto_response): loosen short reply limits for persona flavor
|
2026-04-10 13:45:50 +08:00 |
|
liuwei
|
a1aa05e3b9
|
feat(ai_auto_response): add admin-controlled persona switching
|
2026-04-10 13:15:35 +08:00 |
|
liuwei
|
c280fa8dab
|
rebalance ai_auto_response participation tuning
|
2026-04-10 10:44:10 +08:00 |
|
liuwei
|
3f9ae6442d
|
tighten ai_auto_response participation and spam guard
|
2026-04-10 09:56:34 +08:00 |
|
liuwei
|
d2856bee2e
|
soften ai_auto_response group domain steering
|
2026-04-10 09:45:39 +08:00 |
|
liuwei
|
ef283c1818
|
tune ai_auto_response short reply and followup gating
|
2026-04-10 09:39:33 +08:00 |
|
liuwei
|
42b2014f12
|
unify plugin llm clients on shared utils layer
|
2026-04-10 09:13:42 +08:00 |
|
liuwei
|
a99bbcca39
|
add ai_auto_response llm client compatibility shim
|
2026-04-10 09:06:53 +08:00 |
|
liuwei
|
c0620e6cee
|
shrink ai_auto_response prompt pipeline
|
2026-04-10 09:04:22 +08:00 |
|
liuwei
|
f580c69736
|
refactor ai_auto_response plugin architecture
|
2026-04-09 17:46:30 +08:00 |
|
liuwei
|
cc65378544
|
feat(ai_auto_response): handle image follow-up more safely
|
2026-04-09 10:06:39 +08:00 |
|
liuwei
|
aecb62cb4d
|
refactor: centralize llm backend configuration
|
2026-04-08 13:43:41 +08:00 |
|
liuwei
|
6401ec02de
|
Refine member context profiling detail
|
2026-04-08 10:27:14 +08:00 |
|
liuwei
|
fa98c9e6a5
|
tune xiaoniu config
|
2026-04-08 09:43:55 +08:00 |
|
liuwei
|
f4715f104a
|
adjust xiaoniu runtime config
|
2026-04-08 09:38:21 +08:00 |
|
liuwei
|
67eec32f7f
|
unify xiaoniu topic selection and reply planning
|
2026-04-08 09:23:10 +08:00 |
|
liuwei
|
8ead2c43bf
|
stabilize xiaoniu anti-spam and silent defenses
|
2026-04-08 08:53:47 +08:00 |
|
liuwei
|
3d56b3895a
|
harden xiaoniu defenses and directed cooldowns
|
2026-04-07 17:26:13 +08:00 |
|
liuwei
|
02bde14d52
|
improve xiaoniu reply chunk splitting
|
2026-04-07 16:48:00 +08:00 |
|
liuwei
|
9545664318
|
relax xiaoniu reply planner gating
|
2026-04-07 16:31:29 +08:00 |
|
liuwei
|
c8a7958e2b
|
move xiaoniu runtime logs to debug
|
2026-04-07 16:25:34 +08:00 |
|
liuwei
|
96432039cc
|
add retry for xiaoniu api requests
|
2026-04-07 16:17:58 +08:00 |
|
liuwei
|
2b6deff4ba
|
filter invalid xiaoniu model echoes
|
2026-04-07 16:06:52 +08:00 |
|
liuwei
|
271954cfbb
|
adjust xiaoniu runtime config
|
2026-04-07 16:04:33 +08:00 |
|
liuwei
|
58faa4322c
|
fix xiaoniu mention gating and vector memory config
|
2026-04-07 16:00:31 +08:00 |
|
liuwei
|
fabcb92f3f
|
use richer member memory in xiaoniu replies
|
2026-04-07 15:47:32 +08:00 |
|
liuwei
|
0ac08c45c0
|
tune xiaoniu address style by group
|
2026-04-07 15:38:52 +08:00 |
|
liuwei
|
a29b625bc6
|
refine xiaoniu natural name mentions
|
2026-04-07 15:37:01 +08:00 |
|
liuwei
|
19d2938870
|
improve xiaoniu recipient cues and name-prefixed replies
|
2026-04-07 15:32:38 +08:00 |
|
liuwei
|
9e95b805ec
|
require directed questions for xiaoniu replies
|
2026-04-07 15:21:45 +08:00 |
|
liuwei
|
5ca9a8d1d9
|
tune xiaoniu low-frequency social interjections
|
2026-04-07 14:52:38 +08:00 |
|
liuwei
|
5a02121ace
|
allow multi-part replies for xiaoniu qa responses
|
2026-04-07 14:39:41 +08:00 |
|
liuwei
|
42feb29a40
|
add dota2 match history boundary for xiaoniu
|
2026-04-07 14:12:48 +08:00 |
|
liuwei
|
daf5170008
|
tune xiaoniu mention reply behavior
|
2026-04-07 14:09:31 +08:00 |
|
liuwei
|
acf3177571
|
use latest group image for xiaoniu image followups
|
2026-04-07 14:00:08 +08:00 |
|
liuwei
|
7c12738967
|
add multimodal quote handling for xiaoniu bot
|
2026-04-07 13:51:15 +08:00 |
|
liuwei
|
d507cdf88d
|
improve xiaoniu group awareness and solver suppression
|
2026-04-07 12:27:53 +08:00 |
|
liuwei
|
faa5d68eb0
|
increase xiaoniu prompt context window to 30 messages
|
2026-04-07 12:21:51 +08:00 |
|
liuwei
|
1996df7b99
|
add group-aware persona bias for xiaoniu bot
|
2026-04-07 12:10:47 +08:00 |
|
liuwei
|
d6abb1cc23
|
tighten xiaoniu reply triggers for direct mentions only
|
2026-04-07 11:50:30 +08:00 |
|