Signal 设置
Hermes 通过运行在 HTTP 模式下的 signal-cli 守护进程连接到 Signal。适配器通过 SSE(服务器发送事件)实时流式传输消息,并通过 JSON-RPC 发送响应。
Signal 是最注重隐私的主流消息应用——默认端到端加密、开源协议、元数据收集最少。这使其成为安全敏感型智能体工作流程的理想选择。
Signal 适配器使用 httpx(已是 Hermes 的核心依赖)进行所有通信。无需额外的 Python 包。你只需要在外部安装 signal-cli。
先决条件
- signal-cli — 基于 Java 的 Signal 客户端 (GitHub)
- Java 17+ 运行时 — signal-cli 所需
- 一个已安装 Signal 的手机号码(用于作为辅助设备链接)
安装 signal-cli
# Linux (Debian/Ubuntu)
sudo apt install signal-cli
# macOS
brew install signal-cli
# 手动安装(任何平台)
# 从 https://github.com/AsamK/signal-cli/releases 下载
# 解压并添加到 PATH
步骤 1:链接你的 Signal 账户
Signal-cli 作为链接设备工作——类似于 WhatsApp Web,但用于 Signal。你的手机仍然是主设备。
# 生成链接 URI(显示二维码或链接)
signal-cli link -n "HermesAgent"
- 在你的手机上打开 Signal
- 进入 设置 → 已链接的设备
- 点击 链接新设备
- 扫描二维码或输入 URI
步骤 2:启动 signal-cli 守护进程
# 将 +1234567890 替换为你的 Signal 电话号码(E.164 格式)
signal-cli --account +1234567890 daemon --http 127.0.0.1:8080
让它在后台持续运行。你可以使用 systemd、tmux、screen,或将其作为服务运行。
验证它是否在运行:
curl http://127.0.0.1:8080/api/v1/check
# 应返回:{"versions":{"signal-cli":...}}
步骤 3:配置 Hermes
最简单的方式:
hermes gateway setup
从平台菜单中选择 Signal。向导将:
- 检查 signal-cli 是否已安装
- 提示输入 HTTP URL(默认:
http://127.0.0.1:8080) - 测试与守护进程的连接
- 询问你的账户电话号码
- 配置允许的用户和访问策略
手动配置
添加到 ~/.hermes/.env:
# 必需
SIGNAL_HTTP_URL=http://127.0.0.1:8080
SIGNAL_ACCOUNT=+1234567890
# 安全(推荐)
SIGNAL_ALLOWED_USERS=+1234567890,+0987654321 # 逗号分隔的 E.164 号码或 UUID
# 可选
SIGNAL_GROUP_ALLOWED_USERS=groupId1,groupId2 # 启用群组(省略则禁用,* 表示全部)
SIGNAL_HOME_CHANNEL=+1234567890 # 定时任务的默认发送目标
然后启动网关:
hermes gateway # 前台运行
hermes gateway install # 安装为用户服务
sudo hermes gateway install --system # 仅限 Linux:开机启动的系统服务
访问控制
私信访问
私信访问遵循与其他所有 Hermes 平台相同的模式:
- 设置了
SIGNAL_ALLOWED_USERS→ 只有这些用户可以发消息 - 未设置允许列表 → 未知用户会收到一个私信配对码(通过
hermes pairing approve signal CODE批准) SIGNAL_ALLOW_ALL_USERS=true→ 任何人都可以发消息(谨慎使用)
群组访问
群组访问由 SIGNAL_GROUP_ALLOWED_USERS 环境变量控制:
| 配置 | 行为 |
|---|---|
| 未设置(默认) | 忽略所有群组消息。机器人只响应私信。 |
| 设置为群组 ID | 仅监控列出的群组(例如,groupId1,groupId2)。 |
设置为 * | 机器人响应其所在的任何群组。 |
功能特性
附件
适配器支持发送和接收:
- 图片 — PNG、JPEG、GIF、WebP(通过魔数自动检测)
- 音频 — MP3、OGG、WAV、M4A(如果配置了 Whisper,语音消息会被转录)
- 文档 — PDF、ZIP 和其他文件类型
附件大小限制:100 MB。
输入状态指示
机器人在处理消息时会发送输入状态指示,每 8 秒刷新一次。
电话号码脱敏
所有电话号码在日志中会自动脱敏:
+15551234567→+155****4567- 这同时适用于 Hermes 网关日志和全局脱敏系统
给自己发消息(单号码设置)
如果你在自己的手机号码上(而不是一个独立的机器人号码)将 signal-cli 作为链接的辅助设备运行,你可以通过 Signal 的“给自己发消息”功能与 Hermes 交互。
只需从你的手机给自己发一条消息——signal-cli 会接收到它,然后 Hermes 会在同一对话中回复。
工作原理:
- “给自己发消息”以
syncMessage.sentMessage信封形式到达 - 适配器检测到这些消息是发送给机器人自身账户时,会将其作为常规入站消息处理
- 回显保护(发送时间戳跟踪)防止无限循环——机器人自己的回复会被自动过滤掉
无需额外配置。 只要 SIGNAL_ACCOUNT 与你的电话号码匹配,此功能会自动生效。
健康监控
适配器监控 SSE 连接,并在以下情况自动重连:
- 连接断开(采用指数退避:2秒 → 60秒)
- 120 秒内未检测到活动(会 ping signal-cli 以验证)
故障排除
| 问题 | 解决方案 |
|---|---|
| 设置过程中 “无法连接到 signal-cli” | 确保 signal-cli 守护进程正在运行:signal-cli --account +你的号码 daemon --http 127.0.0.1:8080 |
| 收不到消息 | 检查 SIGNAL_ALLOWED_USERS 是否包含发送者的 E.164 格式号码(带 + 前缀) |
| “在 PATH 中找不到 signal-cli” | 安装 signal-cli 并确保它在你的 PATH 中,或使用 Docker |
| 连接持续断开 | 检查 signal-cli 日志中的错误。确保已安装 Java 17+。 |
| 群组消息被忽略 | 配置 SIGNAL_GROUP_ALLOWED_USERS 为特定的群组 ID,或使用 * 允许所有群组。 |
| 机器人不响应任何人 | 配置 SIGNAL_ALLOWED_USERS,使用私信配对,或者如果你想要更广泛的访问权限,通过网关策略明确允许所有用户。 |
| 重复消息 | 确保只有一个 signal-cli 实例在监听你的电话号码 |
安全
务必配置访问控制。 默认情况下,机器人具有终端访问权限。如果没有设置 SIGNAL_ALLOWED_USERS 或私信配对,网关会拒绝所有传入消息作为安全措施。
- 电话号码在所有日志输出中都会被脱敏
- 使用私信配对或明确的允许列表来安全地接纳新用户
- 除非你特别需要群组支持,否则保持群组禁用,或者只允许你信任的群组
- Signal 的端到端加密保护传输中的消息内容
~/.local/share/signal-cli/中的 signal-cli 会话数据包含账户凭证——请像保护密码一样保护它
环境变量参考
| 变量 | 必需 | 默认值 | 描述 |
|---|---|---|---|
SIGNAL_HTTP_URL | 是 | — | signal-cli HTTP 端点 |
SIGNAL_ACCOUNT | 是 | — | 机器人电话号码(E.164) |
SIGNAL_ALLOWED_USERS | 否 | — | 逗号分隔的电话号码/UUID |
SIGNAL_GROUP_ALLOWED_USERS | 否 | — | 要监控的群组 ID,或 * 表示全部(省略则禁用群组) |
SIGNAL_ALLOW_ALL_USERS | 否 | false | 允许任何用户交互(跳过允许列表) |
SIGNAL_HOME_CHANNEL | 否 | — | 定时任务的默认发送目标 |