捆绑插件
Nextcloud Talk 在当前 OpenClaw 版本中作为捆绑插件提供,因此 普通打包构建不需要单独安装。 如果你使用的是较旧的构建版本,或者是一个排除了 Nextcloud Talk 的自定义安装, 请直接安装 npm 包: 通过 CLI 安装(npm registry):快速设置(入门)
-
确保 Nextcloud Talk 插件可用。
- 当前打包版 OpenClaw 已经捆绑了它。
- 较旧/自定义安装可以使用上面的命令手动添加。
-
在你的 Nextcloud 服务器上创建一个 bot:
- 在目标房间设置中启用该 bot。
-
配置 OpenClaw:
- 配置:
channels.nextcloud-talk.baseUrl+channels.nextcloud-talk.botSecret - 或环境变量:
NEXTCLOUD_TALK_BOT_SECRET(仅默认账户)
等效的显式字段:基于文件的 secret: - 配置:
- 重启网关(或完成设置)。
说明
- bot 不能主动发起私信。用户必须先给 bot 发消息。
- webhook URL 必须能被 Gateway 访问;如果位于代理后面,请设置
webhookPublicUrl。 - bot API 不支持媒体上传;媒体会以 URL 的形式发送。
- webhook 负载无法区分私信与房间;设置
apiUser+apiPassword可启用房间类型查找(否则私信会被当作房间处理)。
访问控制(私信)
- 默认:
channels.nextcloud-talk.dmPolicy = "pairing"。未知发送者会获得一个配对码。 - 通过以下方式批准:
openclaw pairing list nextcloud-talkopenclaw pairing approve nextcloud-talk <CODE>
- 公开私信:
channels.nextcloud-talk.dmPolicy="open"再加上channels.nextcloud-talk.allowFrom=["*"]。 allowFrom仅匹配 Nextcloud 用户 ID;显示名称会被忽略。
房间(群组)
- 默认:
channels.nextcloud-talk.groupPolicy = "allowlist"(基于 mention 门控)。 - 使用
channels.nextcloud-talk.rooms将房间加入允许列表:
- 若要不允许任何房间,保持允许列表为空,或设置
channels.nextcloud-talk.groupPolicy="disabled"。
能力
| 功能 | 状态 |
|---|---|
| 私信 | 支持 |
| 房间 | 支持 |
| 线程 | 不支持 |
| 媒体 | 仅限 URL |
| 反应 | 支持 |
| 原生命令 | 不支持 |
配置参考(Nextcloud Talk)
完整配置:配置 提供者选项:channels.nextcloud-talk.enabled: 启用/禁用频道启动。channels.nextcloud-talk.baseUrl: Nextcloud 实例 URL。channels.nextcloud-talk.botSecret: bot 共享密钥。channels.nextcloud-talk.botSecretFile: 常规文件密钥路径。会拒绝符号链接。channels.nextcloud-talk.apiUser: 用于房间查找的 API 用户(DM 检测)。channels.nextcloud-talk.apiPassword: 用于房间查找的 API/app 密码。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.dmPolicy:pairing | allowlist | open | disabled。channels.nextcloud-talk.allowFrom: DM 允许列表(用户 ID)。open需要"*".channels.nextcloud-talk.groupPolicy:allowlist | open | disabled。channels.nextcloud-talk.groupAllowFrom: 群组允许列表(用户 ID)。channels.nextcloud-talk.rooms: 每个房间的设置和允许列表。- 静态发送者访问组可以通过
accessGroup:<name>在allowFrom和groupAllowFrom中引用。 channels.nextcloud-talk.historyLimit: 群组历史记录上限(0 表示禁用)。channels.nextcloud-talk.dmHistoryLimit: DM 历史记录上限(0 表示禁用)。channels.nextcloud-talk.dms: 每个 DM 的覆盖设置(historyLimit)。channels.nextcloud-talk.textChunkLimit: 出站文本分块大小(字符)。channels.nextcloud-talk.chunkMode:length(默认)或newline,先按空行(段落边界)分割,再进行长度分块。channels.nextcloud-talk.blockStreaming: 为此频道禁用块流式传输。channels.nextcloud-talk.blockStreamingCoalesce: 块流式传输合并调优。channels.nextcloud-talk.mediaMaxMb: 入站媒体上限(MB)。