Nextcloud Talk
Nextcloud Talk (插件)
Section titled “Nextcloud Talk (插件)”状态:通过插件支持(Webhook 机器人)。支持私信、房间、回应 (reactions) 和 markdown 消息。
Nextcloud Talk 作为插件发布,不随核心安装包捆绑。
通过 CLI 安装 (npm 注册表):
openclaw plugins install @openclaw/nextcloud-talk本地检出(从 git 仓库运行时):
openclaw plugins install ./extensions/nextcloud-talk如果在配置/引导期间选择 Nextcloud Talk 并且检测到 git 检出,OpenClaw 将自动提供本地安装路径。
详情:插件 (Plugins)
快速设置 (初学者)
Section titled “快速设置 (初学者)”- 安装 Nextcloud Talk 插件。
- 在你的 Nextcloud 服务器上,创建一个机器人:
Terminal window ./occ talk:bot:install "OpenClaw" "<shared-secret>" "<webhook-url>" --feature reaction - 在目标房间设置中启用机器人。
- 配置 OpenClaw:
- 配置:
channels.nextcloud-talk.baseUrl+channels.nextcloud-talk.botSecret - 或环境变量:
NEXTCLOUD_TALK_BOT_SECRET(仅限默认账户)
- 配置:
- 重启网关(或完成引导)。
最小配置:
{ channels: { "nextcloud-talk": { enabled: true, baseUrl: "https://cloud.example.com", botSecret: "shared-secret", dmPolicy: "pairing" } }}- 机器人无法发起私信。用户必须先给机器人发消息。
- Webhook URL 必须可被网关访问;如果位于代理后面,请设置
webhookPublicUrl。 - 机器人 API 不支持媒体上传;媒体作为 URL 发送。
- Webhook 负载不区分私信与房间;设置
apiUser+apiPassword以启用房间类型查找(否则私信被视为房间)。
访问控制 (私信)
Section titled “访问控制 (私信)”- 默认:
channels.nextcloud-talk.dmPolicy = "pairing". 未知发送者会收到配对码。 - 批准方式:
openclaw pairing list nextcloud-talkopenclaw pairing approve nextcloud-talk <CODE>
- 公共私信:
channels.nextcloud-talk.dmPolicy="open"加上channels.nextcloud-talk.allowFrom=["*"].
房间 (群组)
Section titled “房间 (群组)”- 默认:
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)
Section titled “配置参考 (Nextcloud Talk)”完整配置:配置 (Configuration)
提供商选项:
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.dmPolicy:pairing | allowlist | open | disabled.channels.nextcloud-talk.allowFrom: 私信白名单 (用户 ID).open需要"*"。channels.nextcloud-talk.groupPolicy:allowlist | 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.chunkMode:length(默认) 或newline在长度分块之前先在空行(段落边界)拆分。channels.nextcloud-talk.blockStreaming: 禁用此通道的块流式传输。channels.nextcloud-talk.blockStreamingCoalesce: 块流式传输合并调整。channels.nextcloud-talk.mediaMaxMb: 入站媒体上限 (MB)。