Pallas-Bot 官方扩展:多牛分片谁是卧底。
Project description
谁是卧底 pallas-plugin-who-is-spy
提供开房、述词、匿名投票与复盘的群内卧底玩法。
安装方式
需已安装 Pallas-Bot ≥ 4.0。
推荐直接在控制台插件商店安装,或在本体项目中执行:
uv run pallas ext install pallas-plugin-who-is-spy
也可单独安装本包:
uv pip install pallas-plugin-who-is-spy
开发联调:clone 本仓库后 uv pip install -e .(pyproject.toml 可配置本体 path 依赖)。
多进程分片
Pallas-Bot 支持单进程,也支持 hub + 多个 worker 的多进程部署。启用分片时:
- hub 与每个 worker 须安装相同版本的本扩展包;
- 各进程共享同一路径的
data/(注册表、协调状态、WebUI 落盘等); - 同群房间互斥与主持牛路由依赖 Redis 协调层。
本插件通过本体分片协调模块(如 spy_activity)与共享 data/ 保持一致;未安装扩展时不影响 core 插件运行。
详见:多进程分片 · 架构说明
怎么使用
群内谁是卧底:开房、自由讨论、房主发起投票、私聊匿名投票,直至一方阵营获胜。
用户命令
| 口令 / 触发 | 场景 | 说明 |
|---|---|---|
| 牛牛卧底 | 群内 | 开房 |
| 牛牛加入 / 牛牛退出 | 群内 | 筹备阶段进出 |
| 牛牛发身份 [潜藏人数] [白板] [暗牌|明牌] | 群内 | 房主开局并下发词语 |
| @牛牛 + 描述 | 群内 | 讨论阶段记为述词 |
| 牛牛投票 | 群内 | 房主提前开始投票(先发复盘) |
| 私聊回复数字序号或 0 | 私聊 | 投票(0=弃权) |
| 牛牛局势 / 牛牛结束 | 群内 | 察看局势、结束房间 |
命令权限
| 命令 ID | 默认等级 |
|---|---|
who_is_spy.open |
everyone |
who_is_spy.join |
everyone |
who_is_spy.start |
everyone(含牛牛投票) |
who_is_spy.status |
everyone |
who_is_spy.end |
everyone |
详细用法、限制条件和可用范围以帮助为主。
配置项
| 键 | 默认 | 说明 |
|---|---|---|
spy_min_players |
4 | 最少开局人数 |
spy_max_players |
12 | 房间上限 |
spy_default_undercovers |
1 | 默认卧底数 |
spy_default_blanks |
0 | 默认白板数(无词,不计入胜负比较) |
spy_show_role_default |
false | 私聊是否附带身份(false=暗牌,只发词) |
spy_word_avoid_recent |
10 | 同群最近 N 局词对不重复,0 关闭 |
spy_auto_vote_when_all_spoken |
true | 全员 @牛牛 述词后自动投票 |
spy_speak_max_len |
120 | 复盘单条述词最大字数 |
spy_room_cleanup_sec |
600 | 局结束后空房清理秒数 |
spy_email_fallback |
true | 私聊失败时改发玩家 QQ 邮箱 |
字段以本仓库 config.py 为准;WebUI 插件 → 牛牛卧底 修改。
私聊与邮箱:发词/投票说明优先好友私聊;失败时尝试带 group_id 的临时会话;仍失败且 spy_email_fallback=true 时,复用 bot_status 的 SMTP 向 {QQ号}@qq.com 发信。
词库内置 resource/who_is_spy/undercover_words.json;运行期使用 data/who_is_spy/undercover_words.json(首次启动从 resource 复制,之后启动自动合并 resource 新增词对)。编辑 JSON 后重启 Bot 生效。
排障
| 现象 | 处理 |
|---|---|
| 收不到词语/投票私聊 | 加牛牛好友;或查 QQ 邮箱;确认 bot_status SMTP 已配置 |
| 私聊「你的词:」后无字 | 非白板玩法,属投递失败;加好友、查邮箱或看开局提示里的未达名单 |
| 本群已有房间 | 分片下同群互斥;「牛牛结束」或等局后自动清理 |
| @牛牛 述词无回复 | 分片多牛须 @ 本局主持牛(发「词已私聊」的那只);述词优先于 Ollama;协调层未同步时主持牛内存局仍可述词 |
| 词库为空 | 检查 data/who_is_spy/undercover_words.json 或内置 resource/who_is_spy/ |
实现
源码位置:src/pallas_plugin_who_is_spy/
实现要点:
- 围绕开房、发词、述词、投票与复盘构成完整回合流程。
- 私聊失败时可按配置回退到邮箱投递。
- 分片模式下同群互斥和主持牛路由依赖协调层维持一致。
相关链接
| 说明 | 链接 |
|---|---|
| 谁是卧底 · 用户文档 | 文档站 · who_is_spy |
| 插件开发入门 | develop/plugin/getting-started |
| 多进程分片 | architecture/bot-process-sharding |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pallas_plugin_who_is_spy-4.0.7.tar.gz.
File metadata
- Download URL: pallas_plugin_who_is_spy-4.0.7.tar.gz
- Upload date:
- Size: 2.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8833530a3fe555b0b77f4d0c24b0f53dd98bed0d4c950b3bdb920de583f6507a
|
|
| MD5 |
9c923732f5951c7f48ecb16841f87cab
|
|
| BLAKE2b-256 |
7ddfb1deec4422ba7fc9bf74e06fbf576477e9b0bcc1dd8a25443d37eb19163c
|
Provenance
The following attestation bundles were made for pallas_plugin_who_is_spy-4.0.7.tar.gz:
Publisher:
publish-pypi.yml on TogetsuDo/pallas-plugin-who-is-spy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pallas_plugin_who_is_spy-4.0.7.tar.gz -
Subject digest:
8833530a3fe555b0b77f4d0c24b0f53dd98bed0d4c950b3bdb920de583f6507a - Sigstore transparency entry: 1932695850
- Sigstore integration time:
-
Permalink:
TogetsuDo/pallas-plugin-who-is-spy@8f8d9dbb130e76710aeb73d308cab15ddbb18708 -
Branch / Tag:
refs/tags/v4.0.7 - Owner: https://github.com/TogetsuDo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@8f8d9dbb130e76710aeb73d308cab15ddbb18708 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pallas_plugin_who_is_spy-4.0.7-py3-none-any.whl.
File metadata
- Download URL: pallas_plugin_who_is_spy-4.0.7-py3-none-any.whl
- Upload date:
- Size: 52.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5f775ae6d8540162fcbd843659f158419bb8f1235998a483221d29dde7533c8b
|
|
| MD5 |
5a93a5fbac706ad9b22571593e5c1c20
|
|
| BLAKE2b-256 |
068f9255a2d02baca427f53fe0aa0263d9a86b548ba3c45453f9ec2d8f5a61d8
|
Provenance
The following attestation bundles were made for pallas_plugin_who_is_spy-4.0.7-py3-none-any.whl:
Publisher:
publish-pypi.yml on TogetsuDo/pallas-plugin-who-is-spy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pallas_plugin_who_is_spy-4.0.7-py3-none-any.whl -
Subject digest:
5f775ae6d8540162fcbd843659f158419bb8f1235998a483221d29dde7533c8b - Sigstore transparency entry: 1932696010
- Sigstore integration time:
-
Permalink:
TogetsuDo/pallas-plugin-who-is-spy@8f8d9dbb130e76710aeb73d308cab15ddbb18708 -
Branch / Tag:
refs/tags/v4.0.7 - Owner: https://github.com/TogetsuDo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@8f8d9dbb130e76710aeb73d308cab15ddbb18708 -
Trigger Event:
push
-
Statement type: