Matrix 是 OpenClaw 的可下载渠道插件。 它使用官方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.
matrix-js-sdk,并支持私信、房间、线程、媒体、回应、投票、位置和 E2EE。
安装
在配置渠道前,先从 ClawHub 安装 Matrix:openclaw plugins install clawhub:@openclaw/matrix 或 openclaw plugins install npm:@openclaw/matrix。
从本地检出安装:
plugins install 会注册并启用插件,因此不需要单独执行 openclaw plugins enable matrix 步骤。在配置下面的渠道前,该插件仍不会执行任何操作。请参阅插件了解通用插件行为和安装规则。
设置
- 在你的 homeserver 上创建一个 Matrix 账号。
- 使用
homeserver+accessToken,或homeserver+userId+password配置channels.matrix。 - 重启 Gateway 网关。
- 与机器人开启私信,或邀请它加入房间(请参阅自动加入 - 只有
autoJoin允许时,新邀请才会落地)。
交互式设置
MATRIX_* 环境变量已经存在,并且所选账号没有保存的认证信息,向导会提供一个环境变量快捷方式。若要在保存允许列表前解析房间名称,请运行 openclaw channels resolve --channel matrix "Project Room"。启用 E2EE 时,向导会写入配置,并运行与 openclaw matrix encryption setup 相同的引导流程。
最小配置
基于令牌:自动加入
channels.matrix.autoJoin 默认为 off。使用默认值时,在你手动加入前,机器人不会出现在新邀请带来的新房间或私信中。
OpenClaw 无法在邀请时判断受邀房间是私信还是群组,因此所有邀请(包括类似私信的邀请)都会先经过 autoJoin。dm.policy 只会在稍后应用,即机器人加入且房间完成分类之后。
autoJoin: "always"。
允许列表目标格式
私信和房间允许列表最好填入稳定 ID:- 私信(
dm.allowFrom、groupAllowFrom、groups.<room>.users):使用@user:server。默认会忽略显示名称,因为它们可变;只有在你明确需要兼容显示名称条目时,才设置dangerouslyAllowNameMatching: true。 - 房间允许列表键(
groups、旧版rooms):使用!room:server或#alias:server。默认会忽略纯房间名称;只有在你明确需要兼容已加入房间名称查找时,才设置dangerouslyAllowNameMatching: true。 - 邀请允许列表(
autoJoinAllowlist):使用!room:server、#alias:server或*。纯房间名称会被拒绝。
账号 ID 规范化
向导会将友好名称转换为规范化账号 ID。例如,Ops Bot 会变成 ops-bot。标点符号会在作用域环境变量名称中转义,因此两个账号不会冲突:- → _X2D_,所以 ops-prod 会映射到 MATRIX_OPS_X2D_PROD_*。
缓存凭证
Matrix 会将缓存凭证存储在~/.openclaw/credentials/matrix/ 下:
- 默认账号:
credentials.json - 命名账号:
credentials-<account>.json
openclaw doctor 和渠道状态探测。
环境变量
当等效配置键未设置时使用。默认账号使用无前缀名称;命名账号会在后缀前插入账号 ID。| 默认账号 | 命名账号(<ID> 是规范化账号 ID) |
|---|---|
MATRIX_HOMESERVER | MATRIX_<ID>_HOMESERVER |
MATRIX_ACCESS_TOKEN | MATRIX_<ID>_ACCESS_TOKEN |
MATRIX_USER_ID | MATRIX_<ID>_USER_ID |
MATRIX_PASSWORD | MATRIX_<ID>_PASSWORD |
MATRIX_DEVICE_ID | MATRIX_<ID>_DEVICE_ID |
MATRIX_DEVICE_NAME | MATRIX_<ID>_DEVICE_NAME |
MATRIX_RECOVERY_KEY | MATRIX_<ID>_RECOVERY_KEY |
ops,名称会变为 MATRIX_OPS_HOMESERVER、MATRIX_OPS_ACCESS_TOKEN,依此类推。当你通过 --recovery-key-stdin 输入密钥时,支持恢复的 CLI 流程(verify backup restore、verify device、verify bootstrap)会读取恢复密钥环境变量。
MATRIX_HOMESERVER 不能从工作区 .env 设置;请参阅工作区 .env 文件。
配置示例
一个包含私信配对、房间允许列表和 E2EE 的实用基线:流式预览
Matrix 回复流式传输需要显式选择启用。streaming 控制 OpenClaw 如何交付进行中的助手回复;blockStreaming 控制是否将每个完成的块保留为独立的 Matrix 消息。
streaming | 行为 |
|---|---|
"off"(默认) | 等待完整回复,然后发送一次。true ↔ "partial",false ↔ "off"。 |
"partial" | 在模型写入当前块时,就地编辑一条普通文本消息。原生 Matrix 客户端可能会在第一次预览时通知,而不是在最终编辑时通知。 |
"quiet" | 与 "partial" 相同,但消息是不触发通知的 notice。接收者只会在按用户的推送规则匹配最终编辑后收到一次通知(见下文)。 |
blockStreaming 独立于 streaming:
streaming | blockStreaming: true | blockStreaming: false(默认) |
|---|---|---|
"partial" / "quiet" | 当前块的实时草稿,已完成块保留为消息 | 当前块的实时草稿,就地最终化 |
"off" | 每个完成块一条触发通知的 Matrix 消息 | 完整回复一条触发通知的 Matrix 消息 |
- 如果预览增长到超过 Matrix 的单事件大小限制,OpenClaw 会停止预览流式传输,并回退为仅最终交付。
- 媒体回复始终正常发送附件。如果过期预览无法再安全复用,OpenClaw 会在发送最终媒体回复前将其撤回。
- 当 Matrix 预览流式传输处于活动状态时,默认启用工具进度预览更新。设置
streaming.preview.toolProgress: false可保留答案文本的预览编辑,但让工具进度走正常交付路径。 - 预览编辑会增加额外的 Matrix API 调用。如果你想要最保守的速率限制配置,请保持
streaming: "off"。
审批元数据
Matrix 原生审批提示是普通的m.room.message 事件,其 com.openclaw.approval 下带有 OpenClaw 特定的自定义事件内容。Matrix 允许自定义事件内容键,因此原生客户端仍会渲染文本正文,而支持 OpenClaw 的客户端可以读取结构化审批 ID、类型、状态、可用决策,以及 exec/插件详情。
当审批提示过长,无法放入单个 Matrix 事件时,OpenClaw 会将可见文本分块,并仅将 com.openclaw.approval 附加到第一个块。允许/拒绝决策的回应会绑定到第一个事件,因此长提示与单事件提示保持相同的审批目标。
用于静默最终预览的自托管推送规则
streaming: "quiet" 只会在块或轮次最终化后通知接收者 - 必须有一条按用户的推送规则匹配最终预览标记。请参阅用于静默预览的 Matrix 推送规则获取完整配方(接收者令牌、推送器检查、规则安装、按 homeserver 的说明)。
机器人到机器人房间
默认情况下,会忽略来自其他已配置 OpenClaw Matrix 账号的 Matrix 消息。 当你有意启用智能体间 Matrix 流量时,请使用allowBots:
allowBots: true会接受允许房间和私信中来自其他已配置 Matrix 机器人账号的消息。allowBots: "mentions"只会在这些消息在房间中明确提及此机器人时接受它们。私信仍然允许。groups.<room>.allowBots会覆盖单个房间的账号级设置。- OpenClaw 仍会忽略来自相同 Matrix 用户 ID 的消息,以避免自我回复循环。
- Matrix 这里不会暴露原生机器人标记;OpenClaw 将“由机器人发出”视为“由此 OpenClaw Gateway 网关上另一个已配置的 Matrix 账号发送”。
加密和验证
在加密(E2EE)房间中,出站图片事件使用thumbnail_file,因此图片预览会与完整附件一起加密。未加密房间仍使用普通的 thumbnail_url。无需配置,插件会自动检测 E2EE 状态。
所有 openclaw matrix 命令都接受 --verbose(完整诊断)、--json(机器可读输出)和 --account <id>(多账户设置)。默认输出简洁,并带有静默的内部 SDK 日志。下面的示例展示规范形式;按需添加这些标志。
启用加密
--recovery-key <key>在引导前应用恢复密钥(优先使用下面记录的 stdin 形式)--force-reset-cross-signing丢弃当前 cross-signing 身份并创建新身份(仅在有意这样做时使用)
--encryption 是 --enable-e2ee 的别名。
等效的手动配置:
状态和信任信号
verify status 会报告三个独立的信任信号(--verbose 会显示全部):
Locally trusted:仅受此客户端信任Cross-signing verified:SDK 报告已通过 cross-signing 验证Signed by owner:由你自己的 self-signing 密钥签名(仅用于诊断)
Cross-signing verified 为 yes 时,Verified by owner 才会变为 yes。仅有本地信任或所有者签名并不足够。
--allow-degraded-local-state 会在不先准备 Matrix 账户的情况下返回尽力而为的诊断;适用于离线或部分配置的探测。
使用恢复密钥验证此设备
恢复密钥是敏感信息,请通过 stdin 管道传入,而不是在命令行上传递。设置MATRIX_RECOVERY_KEY(或为命名账户设置 MATRIX_<ID>_RECOVERY_KEY):
Recovery key accepted:Matrix 已接受该密钥,用于 secret storage 或设备信任。Backup usable:可以使用受信任的恢复材料加载房间密钥备份。Device verified by owner:此设备具有完整的 Matrix cross-signing 身份信任。
verify self 会等待 Cross-signing verified: yes,然后才成功退出。使用 --timeout-ms <ms> 调整等待时间。
字面密钥形式 openclaw matrix verify device "<recovery-key>" 也被接受,但密钥会进入你的 shell 历史记录。
引导或修复 cross-signing
verify bootstrap 是加密账户的修复和设置命令。按顺序,它会:
- 引导 secret storage,并在可能时复用现有恢复密钥
- 引导 cross-signing 并上传缺失的公钥
- 标记并 cross-sign 当前设备
- 如果还不存在服务端房间密钥备份,则创建一个
m.login.dummy,再尝试 m.login.password(需要 channels.matrix.password)。
实用标志:
--recovery-key-stdin(配合printf '%s\n' "$MATRIX_RECOVERY_KEY" | …)或--recovery-key <key>--force-reset-cross-signing用于丢弃当前 cross-signing 身份(仅在有意这样做时使用)
房间密钥备份
backup status 会显示是否存在服务端备份,以及此设备是否可以解密它。backup restore 会将已备份的房间密钥导入本地加密存储;如果恢复密钥已在磁盘上,可以省略 --recovery-key-stdin。
要用新的基线替换损坏的备份(接受丢失无法恢复的旧历史;如果当前备份密钥无法加载,也可以重新创建 secret storage):
--rotate-recovery-key。
列出、请求和响应验证
--own-user 请求自验证(你在同一用户的另一个 Matrix 客户端中接受提示);--user-id/--device-id/--room-id 定位其他人。--own-user 不能与其他定位标志组合使用。
对于更底层的生命周期处理,通常是在跟随来自另一个客户端的入站请求时,这些命令会作用于特定请求 <id>(由 verify list 和 verify request 打印):
| 命令 | 用途 |
|---|---|
openclaw matrix verify accept <id> | 接受入站请求 |
openclaw matrix verify start <id> | 启动 SAS 流程 |
openclaw matrix verify sas <id> | 打印 SAS emoji 或十进制数字 |
openclaw matrix verify confirm-sas <id> | 确认 SAS 与另一个客户端显示的内容匹配 |
openclaw matrix verify mismatch-sas <id> | 当 emoji 或十进制数字不匹配时拒绝 SAS |
openclaw matrix verify cancel <id> | 取消;接受可选的 --reason <text> 和 --code <matrix-code> |
accept、start、sas、confirm-sas、mismatch-sas 和 cancel 都接受 --user-id 和 --room-id 作为私信后续提示。
多账户注意事项
如果没有--account <id>,Matrix CLI 命令会使用隐式默认账户。如果你有多个命名账户且未设置 channels.matrix.defaultAccount,它们会拒绝猜测并要求你选择。当某个命名账户的 E2EE 被禁用或不可用时,错误会指向该账户的配置键,例如 channels.matrix.accounts.assistant.encryption。
Startup behavior
Startup behavior
使用
encryption: true 时,startupVerification 默认值为 "if-unverified"。启动时,未验证设备会在另一个 Matrix 客户端中请求自验证,跳过重复请求并应用冷却时间(默认 24 小时)。使用 startupVerificationCooldownHours 调整,或使用 startupVerification: "off" 禁用。启动时还会运行一次保守的加密引导流程,复用当前的 secret storage 和 cross-signing 身份。如果引导状态损坏,即使没有 channels.matrix.password,OpenClaw 也会尝试受保护的修复;如果 homeserver 要求密码 UIA,启动会记录警告并保持非致命。已由所有者签名的设备会被保留。请参阅 Matrix 迁移 了解完整升级流程。Verification notices
Verification notices
Matrix 会将验证生命周期通知作为
m.notice 消息发布到严格的私信验证房间中:请求、就绪(带有“通过 emoji 验证”指引)、开始/完成,以及可用时的 SAS(emoji/十进制)详情。来自另一个 Matrix 客户端的传入请求会被跟踪并自动接受。对于自验证,OpenClaw 会自动启动 SAS 流程,并在 emoji 验证可用后确认自己这一侧;你仍需要在自己的 Matrix 客户端中比较并确认“它们匹配”。验证系统通知不会转发到智能体聊天管道。Deleted or invalid Matrix device
Deleted or invalid Matrix device
如果 对于令牌认证,请在你的 Matrix 客户端或管理 UI 中创建新的访问令牌,然后更新 OpenClaw:将
verify status 表示当前设备不再列在 homeserver 上,请创建新的 OpenClaw Matrix 设备。对于密码登录:assistant 替换为失败命令中的账户 ID,或省略 --account 以使用默认账户。Device hygiene
Device hygiene
旧的 OpenClaw 管理设备可能会累积。列出并清理:
Crypto store
Crypto store
Matrix E2EE 使用官方
matrix-js-sdk Rust 加密路径,并以 fake-indexeddb 作为 IndexedDB shim。加密状态会持久化到 crypto-idb-snapshot.json(限制性文件权限)。加密运行时状态位于 ~/.openclaw/matrix/accounts/<account>/<homeserver>__<user>/<token-hash>/ 下,包含同步存储、加密存储、恢复密钥、IDB 快照、线程绑定和启动验证状态。当令牌发生变化但账户身份保持不变时,OpenClaw 会复用最佳现有根目录,因此先前状态仍然可见。个人资料管理
更新所选账户的 Matrix 自身个人资料:mxc:// 头像 URL;当你传入 http:// 或 https:// 时,OpenClaw 会先上传文件,并将解析后的 mxc:// URL 存入 channels.matrix.avatarUrl(或每账户覆盖项)。
线程
Matrix 支持原生 Matrix 线程,可用于自动回复和消息工具发送。两个独立开关控制行为:会话路由(sessionScope)
dm.sessionScope 决定 Matrix 私信房间如何映射到 OpenClaw 会话:
"per-user"(默认):与同一路由对端相关的所有私信房间共享一个会话。"per-room":每个 Matrix 私信房间都有自己的会话键,即使对端相同也是如此。
sessionScope,因此已绑定的房间和线程会保留其所选目标会话。
回复线程化(threadReplies)
threadReplies 决定机器人在哪里发布回复:
"off":回复位于顶层。入站线程消息保留在父会话中。"inbound":仅当入站消息已经在线程中时,才在线程内回复。"always":在线程内回复,线程根为触发消息;从首次触发开始,该对话会通过匹配的线程作用域会话进行路由。
dm.threadReplies 仅针对私信覆盖此设置,例如让房间线程保持隔离,同时让私信保持扁平。
线程继承和斜杠命令
- 入站线程消息会把线程根消息作为额外智能体上下文包含进来。
- 消息工具发送在目标为同一房间(或同一私信用户目标)时,会自动继承当前 Matrix 线程,除非提供了显式的
threadId。 - 只有当前会话元数据能证明同一 Matrix 账号上的同一私信对端时,才会复用私信用户目标;否则 OpenClaw 会回退到正常的用户作用域路由。
/focus、/unfocus、/agents、/session idle、/session max-age和绑定线程的/acp spawn都可在 Matrix 房间和私信中使用。- 当
threadBindings.spawnSessions启用时,顶层/focus会创建一个新的 Matrix 线程,并将其绑定到目标会话。 - 在现有 Matrix 线程中运行
/focus或/acp spawn --thread here会就地绑定该线程。
m.notice,指向 /focus 逃生通道,并建议更改 dm.sessionScope。该通知只会在线程绑定启用时出现。
ACP 对话绑定
Matrix 房间、私信和现有 Matrix 线程可以转换为持久 ACP 工作区,而不改变聊天界面。 快速操作流程:- 在你想继续使用的 Matrix 私信、房间或现有线程中运行
/acp spawn codex --bind here。 - 在顶层 Matrix 私信或房间中,当前私信/房间会保持为聊天界面,未来消息会路由到生成的 ACP 会话。
- 在现有 Matrix 线程中,
--bind here会就地绑定当前线程。 /new和/reset会就地重置同一个已绑定的 ACP 会话。/acp close会关闭 ACP 会话并移除绑定。
--bind here不会创建子 Matrix 线程。threadBindings.spawnSessions控制/acp spawn --thread auto|here,这时 OpenClaw 需要创建或绑定子 Matrix 线程。
线程绑定配置
Matrix 会继承session.threadBindings 的全局默认值,也支持按渠道覆盖:
threadBindings.enabledthreadBindings.idleHoursthreadBindings.maxAgeHoursthreadBindings.spawnSessionsthreadBindings.defaultSpawnContext
- 设置
threadBindings.spawnSessions: false可阻止顶层/focus和/acp spawn --thread auto|here创建/绑定 Matrix 线程。 - 当原生子智能体线程生成不应 fork 父级转录内容时,设置
threadBindings.defaultSpawnContext: "isolated"。
反应
Matrix 支持出站反应、入站反应通知和确认反应。 出站反应工具由channels.matrix.actions.reactions 控制:
react向 Matrix 事件添加反应。reactions列出 Matrix 事件的当前反应摘要。emoji=""移除该事件上机器人的自身反应。remove: true只移除机器人指定的 emoji 反应。
| 设置 | 顺序 |
|---|---|
ackReaction | 按账号 → 渠道 → messages.ackReaction → 智能体身份 emoji 回退 |
ackReactionScope | 按账号 → 渠道 → messages.ackReactionScope → 默认 "group-mentions" |
reactionNotifications | 按账号 → 渠道 → 默认 "own" |
reactionNotifications: "own" 会在新增的 m.reaction 事件指向机器人所写 Matrix 消息时转发它们;"off" 会禁用反应系统事件。反应移除不会被合成为系统事件,因为 Matrix 将这些表示为撤回,而不是独立的 m.reaction 移除。
历史上下文
channels.matrix.historyLimit控制当 Matrix 房间消息触发智能体时,作为InboundHistory包含的最近房间消息数量。会回退到messages.groupChat.historyLimit;如果两者都未设置,有效默认值为0。设置为0可禁用。- Matrix 房间历史仅限房间。私信继续使用正常会话历史。
- Matrix 房间历史仅限待处理消息:OpenClaw 会缓冲尚未触发回复的房间消息,然后在提及或其他触发到达时快照该窗口。
- 当前触发消息不会包含在
InboundHistory中;它会保留在该轮次的主入站正文中。 - 同一 Matrix 事件的重试会复用原始历史快照,而不是向前漂移到更新的房间消息。
上下文可见性
Matrix 支持共享的contextVisibility 控制,用于补充房间上下文,例如获取的回复文本、线程根和待处理历史。
contextVisibility: "all"是默认值。补充上下文会按接收时保留。contextVisibility: "allowlist"会过滤补充上下文,只发送通过活跃房间/用户 allowlist 检查的发送者内容。contextVisibility: "allowlist_quote"的行为类似allowlist,但仍保留一条显式引用回复。
groupPolicy、groups、groupAllowFrom 和私信策略设置。
私信和房间策略
dm.enabled: false:
直接房间修复
如果直接消息状态不同步,OpenClaw 可能会得到过期的m.direct 映射,指向旧的单人房间,而不是当前可用的私信。检查某个对端的当前映射:
--account <id>,用于多账号设置。修复流程:
- 优先选择已经映射在
m.direct中的严格 1:1 私信 - 回退到与该用户当前已加入的任何严格 1:1 私信
- 如果不存在健康的私信,则创建新的直接房间并重写
m.direct
Exec 批准
Matrix 可以充当原生批准客户端。在channels.matrix.execApprovals 下配置(或在 channels.matrix.accounts.<account>.execApprovals 下配置按账号覆盖):
enabled:通过 Matrix 原生提示传递批准。未设置或为"auto"时,只要至少能解析出一个批准者,Matrix 就会自动启用。设置为false可显式禁用。approvers:允许批准 exec 请求的 Matrix 用户 ID(@owner:example.org)。可选,回退到channels.matrix.dm.allowFrom。target:提示发送位置。"dm"(默认)发送到批准者私信;"channel"发送到发起的 Matrix 房间或私信;"both"同时发送到两者。agentFilter/sessionFilter:可选 allowlist,用于指定哪些智能体/会话触发 Matrix 投递。
- Exec 批准使用
execApprovals.approvers,回退到dm.allowFrom。 - 插件批准只通过
dm.allowFrom授权。
✅允许一次❌拒绝♾️始终允许(当有效 exec 策略允许时)
/approve <id> allow-once、/approve <id> allow-always、/approve <id> deny。
只有已解析的批准者可以批准或拒绝。exec 批准的渠道投递会包含命令文本,请只在受信任房间中启用 channel 或 both。
相关:Exec approvals。
斜杠命令
斜杠命令(/new、/reset、/model、/focus、/unfocus、/agents、/session、/acp、/approve 等)可直接在私信中使用。在房间中,OpenClaw 也会识别以机器人自身 Matrix 提及为前缀的命令,因此 @bot:server /new 会触发命令路径,而不需要自定义提及正则。这让机器人能够响应 Element 和类似客户端在用户输入命令前通过 Tab 补全机器人时发出的房间风格 @mention /command 帖子。
授权规则仍然适用:命令发送者必须满足与普通消息相同的私信或房间 allowlist/所有者策略。
多账号
- 顶层
channels.matrix值会作为命名账号的默认值,除非账号覆盖它们。 - 使用
groups.<room>.account将继承的房间条目限定到特定账号。没有account的条目会在账号之间共享;当默认账号在顶层配置时,account: "default"仍然可用。
- 设置
defaultAccount可选择隐式路由、探测和 CLI 命令优先使用的命名账号。 - 如果你有多个账号,并且其中一个字面上命名为
default,即使未设置defaultAccount,OpenClaw 也会隐式使用它。 - 如果你有多个命名账号且未选择默认账号,CLI 命令会拒绝猜测,请设置
defaultAccount或传递--account <id>。 - 只有当其认证完整(
homeserver+accessToken,或homeserver+userId+password)时,顶层channels.matrix.*块才会被视为隐式default账号。只要缓存凭据覆盖认证,命名账号仍可通过homeserver+userId发现。
- 当 OpenClaw 在修复或设置期间将单账号配置提升为多账号时,如果已有命名账号或
defaultAccount已指向某个账号,它会保留该账号。只有 Matrix 认证/引导键会移动到提升后的账号;共享投递策略键会留在顶层。
私有/LAN homeserver
默认情况下,出于 SSRF 防护,OpenClaw 会阻止私有/内部 Matrix homeserver,除非你按账号显式选择启用。 如果你的 homeserver 运行在 localhost、LAN/Tailscale IP 或内部主机名上,请为该 Matrix 账号启用network.dangerouslyAllowPrivateNetwork:
http://matrix.example.org:8008,仍会被阻止。尽可能优先使用 https://。
代理 Matrix 流量
如果你的 Matrix 部署需要显式的出站 HTTP(S) 代理,请设置channels.matrix.proxy:
channels.matrix.accounts.<id>.proxy 覆盖顶层默认值。
OpenClaw 对运行时 Matrix 流量和账号状态探测使用相同的代理设置。
目标解析
在 OpenClaw 要求你提供房间或用户目标的任何位置,Matrix 都接受以下目标形式:- 用户:
@user:server、user:@user:server或matrix:user:@user:server - 房间:
!room:server、room:!room:server或matrix:room:!room:server - 别名:
#alias:server、channel:#alias:server或matrix:channel:#alias:server
- 用户查找会查询该 homeserver 上的 Matrix 用户目录。
- 房间查找会直接接受显式房间 ID 和别名。已加入房间的名称查找是尽力而为的,并且仅在设置了
dangerouslyAllowNameMatching: true时适用于运行时房间允许列表。 - 如果房间名称无法解析为 ID 或别名,运行时允许列表解析会忽略它。
配置参考
允许列表式用户字段(groupAllowFrom、dm.allowFrom、groups.<room>.users)接受完整的 Matrix 用户 ID(最安全)。默认会忽略非 ID 用户条目。如果你设置 dangerouslyAllowNameMatching: true,会在启动时以及监控器运行期间允许列表发生变化时,解析精确匹配的 Matrix 目录显示名称;运行时会忽略无法解析的条目。
房间允许列表键(groups,旧版 rooms)应为房间 ID 或别名。默认会忽略普通房间名称键;dangerouslyAllowNameMatching: true 会恢复基于已加入房间名称的尽力查找。
账号和连接
enabled:启用或禁用该渠道。name:账号的可选显示标签。defaultAccount:配置多个 Matrix 账号时首选的账号 ID。accounts:具名的逐账号覆盖。顶层channels.matrix值会作为默认值继承。homeserver:homeserver URL,例如https://matrix.example.org。network.dangerouslyAllowPrivateNetwork:允许此账号连接到localhost、LAN/Tailscale IP 或内部主机名。proxy:Matrix 流量的可选 HTTP(S) 代理 URL。支持逐账号覆盖。userId:完整的 Matrix 用户 ID(@bot:example.org)。accessToken:基于令牌认证的访问令牌。支持跨 env/file/exec 提供商的明文值和 SecretRef 值(密钥管理)。password:基于密码登录的密码。支持明文值和 SecretRef 值。deviceId:显式 Matrix 设备 ID。deviceName:密码登录时使用的设备显示名称。avatarUrl:用于资料同步和profile set更新的已存储自头像 URL。initialSyncLimit:启动同步期间获取的最大事件数。
加密
encryption:启用 E2EE。默认值:false。startupVerification:"if-unverified"(E2EE 开启时的默认值)或"off"。当此设备未验证时,启动时自动请求自验证。startupVerificationCooldownHours:下一次自动启动请求之前的冷却时间。默认值:24。
访问和策略
groupPolicy:"open"、"allowlist"或"disabled"。默认值:"allowlist"。groupAllowFrom:房间流量的用户 ID 允许列表。dm.enabled:当为false时,忽略所有私信。默认值:true。dm.policy:"pairing"(默认)、"allowlist"、"open"或"disabled"。在机器人已加入并将房间分类为私信之后应用;不会影响邀请处理。dm.allowFrom:私信流量的用户 ID 允许列表。dm.sessionScope:"per-user"(默认)或"per-room"。dm.threadReplies:仅私信用的回复线程覆盖("off"、"inbound"、"always")。allowBots:接受来自其他已配置 Matrix 机器人账号的消息(true或"mentions")。allowlistOnly:当为true时,会强制所有活动私信策略(除了"disabled")和"open"群组策略改为"allowlist"。不会更改"disabled"策略。dangerouslyAllowNameMatching:当为true时,允许对用户允许列表条目执行 Matrix 显示名称目录查找,并对房间允许列表键执行已加入房间名称查找。优先使用完整的@user:serverID 以及房间 ID 或别名。autoJoin:"always"、"allowlist"或"off"。默认值:"off"。适用于每个 Matrix 邀请,包括私信式邀请。autoJoinAllowlist:当autoJoin为"allowlist"时允许的房间/别名。别名条目会针对 homeserver 解析,而不是针对受邀房间声明的状态解析。contextVisibility:补充上下文可见性(默认"all"、"allowlist"、"allowlist_quote")。
回复行为
replyToMode:"off"、"first"、"all"或"batched"。threadReplies:"off"、"inbound"或"always"。threadBindings:线程绑定会话路由和生命周期的逐渠道覆盖。streaming:"off"(默认)、"partial"、"quiet",或对象形式{ mode, preview: { toolProgress } }。true↔"partial",false↔"off"。blockStreaming:当为true时,已完成的 assistant 块会保留为单独的进度消息。markdown:出站文本的可选 Markdown 渲染配置。responsePrefix:追加到出站回复前的可选字符串。textChunkLimit:当chunkMode: "length"时,出站分块的字符大小。默认值:4000。chunkMode:"length"(默认,按字符数拆分)或"newline"(按行边界拆分)。historyLimit:当房间消息触发智能体时,作为InboundHistory包含的最近房间消息数量。回退到messages.groupChat.historyLimit;有效默认值为0(禁用)。mediaMaxMb:出站发送和入站处理的媒体大小上限,单位为 MB。
表情回应设置
ackReaction:此渠道/账号的确认表情回应覆盖。ackReactionScope:范围覆盖(默认"group-mentions"、"group-all"、"direct"、"all"、"none"、"off")。reactionNotifications:入站表情回应通知模式(默认"own"、"off")。
工具和逐房间覆盖
actions:逐操作工具门控(messages、reactions、pins、profile、memberInfo、channelInfo、verification)。groups:逐房间策略映射。解析后,会话身份使用稳定的房间 ID。(rooms是旧版别名。)groups.<room>.account:将一个继承的房间条目限制到特定账号。groups.<room>.allowBots:渠道级设置的逐房间覆盖(true或"mentions")。groups.<room>.users:逐房间发送者允许列表。groups.<room>.tools:逐房间工具允许/拒绝覆盖。groups.<room>.autoReply:逐房间提及门控覆盖。true会禁用该房间的提及要求;false会强制重新开启。groups.<room>.skills:逐房间技能过滤器。groups.<room>.systemPrompt:逐房间系统提示片段。
Exec 审批设置
execApprovals.enabled:通过 Matrix 原生提示投递 exec 审批。execApprovals.approvers:允许审批的 Matrix 用户 ID。回退到dm.allowFrom。execApprovals.target:"dm"(默认)、"channel"或"both"。execApprovals.agentFilter/execApprovals.sessionFilter:用于投递的可选智能体/会话允许列表。