跳转到主要内容

Documentation Index

Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Status: 实验性。此集成通过 OpenClaw 内部原生 zca-js 自动化一个个人 Zalo 账号
这是一个非官方集成,可能导致账号被暂停或封禁。使用风险由你自行承担。

内置插件

Zalo Personal 在当前 OpenClaw 版本中作为内置插件提供,因此普通 打包构建不需要单独安装。 如果你使用的是较旧构建,或是不包含 Zalo Personal 的自定义安装, 请直接安装 npm 包:
  • 通过 CLI 安装:openclaw plugins install @openclaw/zalouser
  • 固定版本:openclaw plugins install @openclaw/zalouser@2026.5.2
  • 或从源码检出安装:openclaw plugins install ./path/to/local/zalouser-plugin
  • 详情:插件
不需要外部 zca/openzca CLI 二进制文件。

快速设置(初学者)

  1. 确保 Zalo Personal 插件可用。
    • 当前打包的 OpenClaw 版本已内置它。
    • 较旧/自定义安装可以使用上面的命令手动添加。
  2. 登录(QR,在 Gateway 网关机器上):
    • openclaw channels login --channel zalouser
    • 使用 Zalo 移动应用扫描二维码。
  3. 启用渠道:
{
  channels: {
    zalouser: {
      enabled: true,
      dmPolicy: "pairing",
    },
  },
}
  1. 重启 Gateway 网关(或完成设置)。
  2. 私信访问默认使用配对;首次联系时批准配对码。

它是什么

  • 完全通过 zca-js 在进程内运行。
  • 使用原生事件监听器接收入站消息。
  • 直接通过 JS API(文本/媒体/链接)发送回复。
  • 面向无法使用 Zalo Bot API 的“个人账号”使用场景设计。

命名

渠道 ID 是 zalouser,用于明确表示此集成自动化一个个人 Zalo 用户账号(非官方)。我们保留 zalo,供未来可能的官方 Zalo API 集成使用。

查找 ID(目录)

使用目录 CLI 发现对端/群组及其 ID:
openclaw directory self --channel zalouser
openclaw directory peers list --channel zalouser --query "name"
openclaw directory groups list --channel zalouser --query "work"

限制

  • 出站文本会被分块为约 2000 个字符(Zalo 客户端限制)。
  • 默认阻止流式传输。

访问控制(私信)

channels.zalouser.dmPolicy 支持:pairing | allowlist | open | disabled(默认:pairing)。 channels.zalouser.allowFrom 应使用稳定的 Zalo 用户 ID。它也可以引用静态发送者访问组(accessGroup:<name>)。在交互式设置期间,输入的名称可以通过插件的进程内联系人查找解析为 ID。 如果原始名称保留在配置中,启动时只有在启用 channels.zalouser.dangerouslyAllowNameMatching: true 时才会解析它。没有该显式启用项时,运行时发送者检查仅基于 ID,原始名称会被忽略用于授权。 通过以下命令批准:
  • openclaw pairing list zalouser
  • openclaw pairing approve zalouser <code>

群组访问(可选)

  • 默认:channels.zalouser.groupPolicy = "open"(允许群组)。未设置时,使用 channels.defaults.groupPolicy 覆盖默认值。
  • 使用以下配置限制为允许列表:
    • channels.zalouser.groupPolicy = "allowlist"
    • channels.zalouser.groups(键应为稳定的群组 ID;只有在启用 channels.zalouser.dangerouslyAllowNameMatching: true 时,名称才会在启动时解析为 ID)
    • channels.zalouser.groupAllowFrom(控制允许的群组中哪些发送者可以触发机器人;可以用 accessGroup:<name> 引用静态发送者访问组)
  • 阻止所有群组:channels.zalouser.groupPolicy = "disabled"
  • 配置向导可以提示输入群组允许列表。
  • 启动时,只有在启用 channels.zalouser.dangerouslyAllowNameMatching: true 时,OpenClaw 才会将允许列表中的群组/用户名称解析为 ID 并记录映射。
  • 群组允许列表匹配默认仅基于 ID。除非启用 channels.zalouser.dangerouslyAllowNameMatching: true,否则未解析的名称会被忽略用于认证。
  • channels.zalouser.dangerouslyAllowNameMatching: true 是一个应急兼容模式,会重新启用可变的启动时名称解析和运行时群组名称匹配。
  • 如果未设置 groupAllowFrom,运行时会回退到 allowFrom 来执行群组发送者检查。
  • 发送者检查同时适用于普通群组消息和控制命令(例如 /new/reset)。
示例:
{
  channels: {
    zalouser: {
      groupPolicy: "allowlist",
      groupAllowFrom: ["1471383327500481391"],
      groups: {
        "123456789": { allow: true },
        "Work Chat": { allow: true },
      },
    },
  },
}

群组提及门控

  • channels.zalouser.groups.<group>.requireMention 控制群组回复是否需要提及。
  • 解析顺序:精确群组 ID/名称 -> 规范化群组 slug -> * -> 默认值(true)。
  • 这同时适用于允许列表群组和开放群组模式。
  • 引用机器人消息会计为群组激活的隐式提及。
  • 已授权的控制命令(例如 /new)可以绕过提及门控。
  • 当群组消息因需要提及而被跳过时,OpenClaw 会将其存储为待处理群组历史,并在下一条已处理的群组消息中包含它。
  • 群组历史限制默认为 messages.groupChat.historyLimit(回退值 50)。你可以使用 channels.zalouser.historyLimit 为每个账号覆盖。
示例:
{
  channels: {
    zalouser: {
      groupPolicy: "allowlist",
      groups: {
        "*": { allow: true, requireMention: true },
        "Work Chat": { allow: true, requireMention: false },
      },
    },
  },
}

多账号

账号会映射到 OpenClaw 状态中的 zalouser 配置文件。示例:
{
  channels: {
    zalouser: {
      enabled: true,
      defaultAccount: "default",
      accounts: {
        work: { enabled: true, profile: "work" },
      },
    },
  },
}

正在输入、回应和送达确认

  • OpenClaw 会在分发回复前发送正在输入事件(尽力而为)。
  • 渠道操作中,zalouser 支持消息回应操作 react
    • 使用 remove: true 从消息中移除特定回应表情。
    • 回应语义:回应
  • 对于包含事件元数据的入站消息,OpenClaw 会发送已送达 + 已读确认(尽力而为)。

故障排除

登录无法保留:
  • openclaw channels status --probe
  • 重新登录:openclaw channels logout --channel zalouser && openclaw channels login --channel zalouser
允许列表/群组名称未解析:
  • allowFrom/groupAllowFrom 中使用数字 ID,并在 groups 中使用稳定的群组 ID。如果你确实需要精确的好友/群组名称,请启用 channels.zalouser.dangerouslyAllowNameMatching: true
从旧的基于 CLI 的设置升级:
  • 移除任何旧的外部 zca 进程假设。
  • 该渠道现在完全在 OpenClaw 中运行,不需要外部 CLI 二进制文件。

相关