Skip to main content

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 启动时会:

  1. 通过 config.yamlplugins.enabled 列表加载启用的插件;
  2. ~/.hermes/plugins/lightclawbot/ 下查找 __init__.py + plugin.yaml
  3. 调用插件的 register(ctx) 函数注册 adapter。

注册后自动获得:

  • Platform("lightclawbot") 动态枚举成员
  • gateway 启动时创建并连接 LightClawAdapter
  • send_message tool 通过 _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 未上线 / 收不到消息

  1. 确认 LIGHTCLAW_API_KEY 已设置且非空(cat ~/.hermes/.env | grep LIGHTCLAW
  2. 确认 config.yamlplugins.enabled 包含 lightclawbot
  3. 检查网关日志中是否出现 [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

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

lightclawbot-0.0.3.tar.gz (39.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

lightclawbot-0.0.3-py3-none-any.whl (45.3 kB view details)

Uploaded Python 3

File details

Details for the file lightclawbot-0.0.3.tar.gz.

File metadata

  • Download URL: lightclawbot-0.0.3.tar.gz
  • Upload date:
  • Size: 39.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.4

File hashes

Hashes for lightclawbot-0.0.3.tar.gz
Algorithm Hash digest
SHA256 df3618496514938bd13231e2474d93002509079fac9461e3d2f9b9ed4c720697
MD5 050414df7adacf4323b57596295d54d1
BLAKE2b-256 91151e84f1910d3cace82a68cc199c54dd32efadc3cb8eac28a67cfaea7f6b12

See more details on using hashes here.

File details

Details for the file lightclawbot-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: lightclawbot-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 45.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.4

File hashes

Hashes for lightclawbot-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 17d0603723fd216f228eceaaeaf653cd0e0aa882a923b8bcbeb9007a51e6379f
MD5 608b739a8dc823d09ffe6facbb3f2c67
BLAKE2b-256 56832cab5108f8ffa48f52f1750389bcdddfeded6eec37ae2869457e15b7c5fe

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page