跳转到内容

Nextcloud Talk

状态:捆绑插件(webhook bot)。支持私信、聊天室、反应和 Markdown 消息。

Nextcloud Talk 作为捆绑插件包含在当前的 OpenClaw 版本中,因此 普通的打包版本不需要单独安装。

如果您使用的是旧版本构建或排除了 Nextcloud Talk 的自定义安装,请直接安装 npm 包:

通过 CLI(npm 注册表)安装:

Terminal window
openclaw plugins install @openclaw/nextcloud-talk

使用基础包以跟随当前的官方发布标签。仅在需要可重现安装时才固定确切版本。

本地检出(当从 git 仓库运行时):

Terminal window
openclaw plugins install ./path/to/local/nextcloud-talk-plugin

详情:插件

  1. 确保 Nextcloud Talk 插件可用。

    • 当前的 OpenClaw 打包版本已包含它。
    • 旧版本/自定义安装可以使用上述命令手动添加。
  2. 在您的 Nextcloud 服务器上,创建一个机器人:

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

  4. 配置 OpenClaw:

    • 配置:channels.nextcloud-talk.baseUrl + channels.nextcloud-talk.botSecret
    • 或环境变量:NEXTCLOUD_TALK_BOT_SECRET(仅限默认账户)

    CLI 设置:

    Terminal window
    openclaw channels add --channel nextcloud-talk \
    --url https://cloud.example.com \
    --token "<shared-secret>"

    等效的显式字段:

    Terminal window
    openclaw channels add --channel nextcloud-talk \
    --base-url https://cloud.example.com \
    --secret "<shared-secret>"

    文件支持的密钥:

    Terminal window
    openclaw channels add --channel nextcloud-talk \
    --base-url https://cloud.example.com \
    --secret-file /path/to/nextcloud-talk-secret
  5. 重启网关(或完成设置)。

最小配置:

{
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
回应支持
原生命令不支持

完整配置:配置

提供者选项:

  • channels.nextcloud-talk.enabled:启用/禁用渠道启动。
  • channels.nextcloud-talk.baseUrl:Nextcloud 实例 URL。
  • channels.nextcloud-talk.botSecret:bot 共享密钥。
  • 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:每个房间的设置和允许列表。
  • 可以使用 accessGroup:<name>allowFromgroupAllowFrom 引用静态发送者访问组。
  • 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)。