配置

配对

“配对”是 OpenClaw 的显式访问批准步骤。 它用于两个地方:

  1. 私信配对(谁可以与机器人对话)
  2. 节点配对(哪些设备/节点可以加入 Gateway 网关网络)

安全上下文:安全

1) 私信配对(入站聊天访问)

当某个渠道配置为 DM 策略 pairing 时,未知发送者会获得一个短代码,并且在你批准之前,其消息不会被处理

默认 DM 策略记录在:安全

只有当有效 DM 允许列表包含 "*" 时,dmPolicy: "open" 才是公开的。 公开开放配置的设置和验证需要这个通配符。如果现有状态包含带有具体 allowFrom 条目的 open,运行时仍然只允许这些发送者,并且配对存储中的批准不会扩大 open 访问范围。

配对代码:

  • 8 个字符,大写,不含易混淆字符(0O1I)。
  • 1 小时后过期。机器人只会在创建新请求时发送配对消息(大约每个发送者每小时一次)。
  • 待处理的 DM 配对请求默认每个渠道最多 3 个;额外请求会被忽略,直到其中一个过期或获批。

批准发送者

openclaw pairing list telegram
openclaw pairing approve telegram <CODE>

如果尚未配置命令所有者,批准 DM 配对代码也会将 commands.ownerAllowFrom 引导设置为已批准的发送者,例如 telegram:123456789。 这为首次设置提供一个用于特权命令和执行批准提示的显式所有者。所有者存在后,后续配对批准只授予 DM 访问权限;它们不会添加更多所有者。

支持的渠道:bluebubblesdiscordfeishugooglechatimessageirclinematrixmattermostmsteamsnextcloud-talknostropenclaw-weixinsignalslacksynology-chattelegramtwitchwhatsappzalozalouser

可复用的发送者组

当同一组受信任发送者应适用于多个消息渠道,或同时适用于 DM 和群组允许列表时,请使用顶层 accessGroups

静态组使用 type: "message.senders",并通过渠道允许列表中的 accessGroup:<name> 引用:

{
  accessGroups: {
    operators: {
      type: "message.senders",
      members: {
        discord: ["discord:123456789012345678"],
        telegram: ["987654321"],
        whatsapp: ["+15551234567"],
      },
    },
  },
  channels: {
    telegram: { dmPolicy: "allowlist", allowFrom: ["accessGroup:operators"] },
    whatsapp: { groupPolicy: "allowlist", groupAllowFrom: ["accessGroup:operators"] },
  },
}

访问组的详细文档在这里:访问组

状态存储位置

存储在 ~/.openclaw/credentials/ 下:

  • 待处理请求:<channel>-pairing.json
  • 已批准允许列表存储:
    • 默认账户:<channel>-allowFrom.json
    • 非默认账户:<channel>-<accountId>-allowFrom.json

账户作用域行为:

  • 非默认账户只读写其作用域内的允许列表文件。
  • 默认账户使用渠道作用域的非作用域允许列表文件。

将这些文件视为敏感文件(它们控制对你的助手的访问)。

2) 节点设备配对(iOS/Android/macOS/无头节点)

节点以 role: node设备身份连接到 Gateway 网关。Gateway 网关会创建设备配对请求,该请求必须获批。

通过 Telegram 配对(推荐用于 iOS)

如果你使用 device-pair 插件,可以完全通过 Telegram 完成首次设备配对:

  1. 在 Telegram 中,向你的机器人发送消息:/pair
  2. 机器人会回复两条消息:一条说明消息和一条单独的设置代码消息(便于在 Telegram 中复制/粘贴)。
  3. 在你的手机上,打开 OpenClaw iOS 应用 → 设置 → Gateway 网关。
  4. 扫描二维码或粘贴设置代码并连接。
  5. 回到 Telegram:/pair pending(查看请求 ID、角色和作用域),然后批准。

设置代码是一个经过 base64 编码的 JSON 载荷,包含:

  • url:Gateway 网关 WebSocket URL(ws://...wss://...
  • bootstrapToken:用于初始配对握手的短期单设备引导令牌

该引导令牌携带内置的配对引导配置:

  • 主要移交的 node 令牌保持 scopes: []
  • 任何移交的 operator 令牌仍限定在引导允许列表内: operator.approvalsoperator.readoperator.talk.secretsoperator.write
  • 引导作用域检查带有角色前缀,而不是一个扁平的作用域池: operator 作用域条目只满足 operator 请求,非 operator 角色仍必须在自己的角色前缀下请求作用域
  • 后续令牌轮换/撤销仍同时受设备已批准的角色契约和调用方会话的 operator 作用域限制

在设置代码有效期间,请像对待密码一样对待它。

对于 Tailscale、公开或其他远程移动配对,请使用 Tailscale Serve/Funnel 或其他 wss:// Gateway 网关 URL。明文 ws:// 设置代码只接受用于 loopback、专用 LAN 地址、.local Bonjour 主机和 Android 模拟器主机。Tailnet CGNAT 地址、.ts.net 名称和公开主机仍会在二维码/设置代码签发前失败关闭。

批准节点设备

openclaw devices list
openclaw devices approve <requestId>
openclaw devices reject <requestId>

当显式批准因正在批准的已配对设备会话是以仅配对作用域打开而被拒绝时,CLI 会使用 operator.admin 重试同一请求。这样,现有具备管理员能力的已配对设备可以恢复新的 Control UI/浏览器配对,而无需手动编辑 devices/paired.json。Gateway 网关仍会验证重试连接;无法使用 operator.admin 进行身份验证的令牌仍会被阻止。

如果同一设备使用不同的认证详细信息重试(例如不同角色/作用域/公钥),之前的待处理请求会被取代,并创建新的 requestId

可选的受信任 CIDR 节点自动批准

设备配对默认保持手动。对于严格受控的节点网络,你可以选择使用显式 CIDR 或精确 IP 启用首次节点自动批准:

{
  gateway: {
    nodes: {
      pairing: {
        autoApproveCidrs: ["192.168.1.0/24"],
      },
    },
  },
}

这只适用于没有请求作用域的全新 role: node 配对请求。Operator、浏览器、Control UI 和 WebChat 客户端仍需要手动批准。角色、作用域、元数据和公钥变更仍需要手动批准。

节点配对状态存储

存储在 ~/.openclaw/devices/ 下:

  • pending.json(短期;待处理请求会过期)
  • paired.json(已配对设备 + 令牌)

备注

  • 旧版 node.pair.* API(CLI:openclaw nodes pending|approve|reject|remove|rename)是独立的 Gateway 网关所有配对存储。WS 节点仍需要设备配对。
  • 配对记录是已批准角色的持久事实来源。活跃设备令牌仍限定在该已批准角色集合内;批准角色之外的零散令牌条目不会创建新的访问权限。

相关文档