LightClaw platform plugin for Hermes Agent — connects via native WebSocket to LightClaw server
Project description
lightclawbot
LightClaw 平台适配器插件,为 Hermes Agent 提供通过 WebSocket 接入 LightClaw 服务端的能力,使 Hermes Agent 能与 LightClaw 用户进行实时对话、收发文件附件、发送打字指示符,以及通过 cron 定时推送消息。
用户(前端) ←→ LightClaw Server ←→ lightclawbot ←→ Hermes AIAgent
(WebSocket) (本插件,非侵入)
工作原理
lightclawbot 采用 Hermes Agent 的插件注册机制集成,不修改主仓库任何源码。
Hermes Agent 启动时会:
- 通过
config.yaml的plugins.enabled列表加载启用的插件; - 在
~/.hermes/plugins/lightclawbot/下查找__init__.py+plugin.yaml; - 调用插件的
register(ctx)函数注册 adapter。
注册后自动获得:
Platform("lightclawbot")动态枚举成员- gateway 启动时创建并连接
LightClawAdapter send_messagetool 通过_send_via_adapter()路由- cron delivery 到
lightclawbot:<chat_id>自动生效 - 用户授权遵循
LIGHTCLAW_ALLOWED_USERS环境变量
前置条件
| 要求 | 最低版本 |
|---|---|
| Python | 3.11+ |
| Hermes Agent | 已安装 |
| aiohttp | 3.9+(由宿主 Hermes Agent 提供) |
本插件不直接声明
aiohttp依赖;它由宿主 Hermes Agent 环境提供。
环境变量配置
在 ~/.hermes/.env 中设置以下变量:
| 变量 | 必填 | 说明 |
|---|---|---|
LIGHTCLAW_API_KEY |
是 | Bearer Token |
LIGHTCLAW_ALLOW_ALL_USERS |
否 | 设为 true 接受所有用户消息 |
最简配置示例:
LIGHTCLAW_API_KEY=your-secret-api-key
LIGHTCLAW_ALLOW_ALL_USERS=true
启动网关
完成配置后正常启动 Hermes 网关:
hermes gateway start
只要 LIGHTCLAW_API_KEY 已设置,LightClaw 适配器就会自动建立连接。日志中应出现:
[lightclawbot] Bot clientId: xxxx, 1 key(s) mapped
[lightclawbot] Connected (sid=xxxx)
Cron 定时投递
在 Hermes Agent 内创建定时任务时,指定 deliver 参数即可将结果推送到 LightClaw:
deliver=lightclawbot:<chat_id>
示例(在 Hermes Agent 对话中):
每天早上 9 点发送新闻摘要。deliver=lightclawbot:123456
也可以设置全局默认投递目标:
LIGHTCLAW_HOME_CHANNEL=123456
项目结构
lightclawbot/
├── __init__.py register(ctx) 插件入口
├── plugin.yaml 插件元数据(kind: platform)
└── src/ adapter 实现
├── __init__.py 公开 API
├── adapter.py 主类 + 生命周期
├── config.py 常量 + 工具函数
├── inbound.py 入站消息处理
├── outbound.py 出站消息发送
├── history.py 历史记录/会话列表响应
├── media.py 媒体类型探测与格式化
├── file_storage.py 文件上传/下载 REST API
├── download_handler.py 客户端下载请求处理
├── tenancy.py 多租户 API key 映射
└── socket/
├── native_socket.py WebSocket 连接循环
└── reliable_emitter.py ACK 重试发送
常见问题排查
Bot 未上线 / 收不到消息
- 确认
LIGHTCLAW_API_KEY已设置且非空(cat ~/.hermes/.env | grep LIGHTCLAW) - 确认
config.yaml中plugins.enabled包含lightclawbot - 检查网关日志中是否出现
[lightclawbot] Connected;若无,WebSocket 握手失败
aiohttp not installed
# 在 hermes 的 venv 里安装
~/.hermes/hermes-agent/venv/bin/pip install "aiohttp>=3.9,<4"
插件未被发现
确认以下两点:
# 1. 插件目录存在且结构正确
ls ~/.hermes/plugins/lightclawbot/
# 应当看到 __init__.py 和 plugin.yaml
# 2. config.yaml 已启用
grep -A2 plugins ~/.hermes/config.yaml
# plugins:
# enabled:
# - lightclawbot
# platforms:
# lightclawbot:
# enabled: true
没有流式输出
config.yaml 已启用
# display:
# platforms:
# lightclawbot:
# streaming: true
License
MIT
Project details
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 lightclawbot-0.0.5.tar.gz.
File metadata
- Download URL: lightclawbot-0.0.5.tar.gz
- Upload date:
- Size: 59.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca860482527bb393ad2a709ed3c020d7119ad8ffe61f7d65e239673eb1bd1cf1
|
|
| MD5 |
7c9d455bec0c5702ac67efaaa8fe3032
|
|
| BLAKE2b-256 |
1fe268791e36f96ac8268a2d7407ff541d3f152efd2aebdc5f7fc722250cab73
|
File details
Details for the file lightclawbot-0.0.5-py3-none-any.whl.
File metadata
- Download URL: lightclawbot-0.0.5-py3-none-any.whl
- Upload date:
- Size: 65.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0dce8bde3617a11ef311f5cb3528ccf0cac241a26d49fece88b45d232f23bc77
|
|
| MD5 |
c0c4ee39829539a91217ecc06d271821
|
|
| BLAKE2b-256 |
eeee804595fb1d9669bc11e245d875b716b18add47c36602c67efcc8976577ab
|