Nextcloud Talk(插件)

状态:通过插件支持(webhook 机器人)。支持私信、房间、表情回应和 Markdown 消息。

需要安装插件

Nextcloud Talk 以插件形式提供,不包含在核心安装中。

通过 CLI(npm 仓库)安装:

openclaw plugins install @openclaw/nextcloud-talk

本地代码安装(从 Git 仓库运行时):

openclaw plugins install ./extensions/nextcloud-talk

在引导过程中选择 Nextcloud Talk 并检测到 Git 仓库时,OpenClaw 会自动提供本地安装路径。

详情:插件

快速开始

  1. 安装 Nextcloud Talk 插件。

  2. 在 Nextcloud 服务器上创建机器人:

    ./occ talk:bot:install "OpenClaw" "<shared-secret>" "<webhook-url>" --feature reaction
  3. 在目标房间的设置中启用机器人。

  4. 配置 OpenClaw:

    • 配置文件:channels.nextcloud-talk.baseUrl + channels.nextcloud-talk.botSecret
    • 或环境变量:NEXTCLOUD_TALK_BOT_SECRET(仅默认账户)
  5. 重启 Gateway(或完成引导)。

最小配置:

{
  channels: {
    "nextcloud-talk": {
      enabled: true,
      baseUrl: "https://cloud.example.com",
      botSecret: "shared-secret",
      dmPolicy: "pairing",
    },
  },
}

注意事项

  • 机器人无法主动发起私信,必须由用户先发消息。
  • Webhook URL 必须能被 Gateway 访问;如在代理后面,请设置 webhookPublicUrl
  • 机器人 API 不支持媒体上传;媒体以 URL 形式发送。
  • Webhook 载荷无法区分私信和房间消息;设置 apiUser + apiPassword 可启用房间类型查询(否则私信被视为房间消息)。

访问控制(私信)

  • 默认:channels.nextcloud-talk.dmPolicy = "pairing"。未知发送者收到配对码。
  • 审批方式:
    • openclaw pairing list nextcloud-talk
    • openclaw pairing approve nextcloud-talk <CODE>
  • 公开私信:channels.nextcloud-talk.dmPolicy="open" 加上 channels.nextcloud-talk.allowFrom=["*"]
  • allowFrom 仅匹配 Nextcloud 用户 ID;显示名称不参与匹配。

房间(群组)

  • 默认:channels.nextcloud-talk.groupPolicy = "allowlist"(需提及)。
  • 使用 channels.nextcloud-talk.rooms 配置房间白名单:
{
  channels: {
    "nextcloud-talk": {
      rooms: {
        "room-token": { requireMention: true },
      },
    },
  },
}
  • 如不允许任何房间,保持白名单为空或设置 channels.nextcloud-talk.groupPolicy="disabled"

功能支持

功能状态
私信已支持
房间已支持
线程不支持
媒体仅 URL
表情回应已支持
原生命令不支持

配置参考(Nextcloud Talk)

完整配置:配置

频道选项:

  • channels.nextcloud-talk.enabled:启用/禁用频道启动。
  • channels.nextcloud-talk.baseUrl:Nextcloud 实例 URL。
  • channels.nextcloud-talk.botSecret:机器人共享密钥。
  • channels.nextcloud-talk.botSecretFile:常规密钥文件路径。不接受符号链接。
  • channels.nextcloud-talk.apiUser:用于房间查询的 API 用户(私信检测)。
  • channels.nextcloud-talk.apiPassword:用于房间查询的 API/应用密码。
  • channels.nextcloud-talk.apiPasswordFile:API 密码文件路径。
  • channels.nextcloud-talk.webhookPort:webhook 监听端口(默认:8788)。
  • channels.nextcloud-talk.webhookHost:webhook 主机(默认:0.0.0.0)。
  • channels.nextcloud-talk.webhookPath:webhook 路径(默认:/nextcloud-talk-webhook)。
  • channels.nextcloud-talk.webhookPublicUrl:外部可达的 webhook URL。
  • channels.nextcloud-talk.dmPolicypairing | allowlist | open | disabled
  • channels.nextcloud-talk.allowFrom:私信白名单(用户 ID)。open 需包含 "*"
  • channels.nextcloud-talk.groupPolicyallowlist | open | disabled
  • channels.nextcloud-talk.groupAllowFrom:群组白名单(用户 ID)。
  • channels.nextcloud-talk.rooms:按房间设置和白名单。
  • channels.nextcloud-talk.historyLimit:群组历史限制(0 禁用)。
  • channels.nextcloud-talk.dmHistoryLimit:私信历史限制(0 禁用)。
  • channels.nextcloud-talk.dms:按私信的覆盖配置(historyLimit)。
  • channels.nextcloud-talk.textChunkLimit:出站文本分块大小(字符)。
  • channels.nextcloud-talk.chunkModelength(默认)或 newline,按空行(段落边界)分割后再按长度分块。
  • channels.nextcloud-talk.blockStreaming:禁用此频道的块流式传输。
  • channels.nextcloud-talk.blockStreamingCoalesce:块流式传输合并调参。
  • channels.nextcloud-talk.mediaMaxMb:入站媒体上限(MB)。