fengming 0.3.10 → 0.3.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (761) hide show
  1. package/dist/build-info.json +2 -2
  2. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  3. package/dist/cli-startup-metadata.json +8 -8
  4. package/dist/control-ui/assets/{activity-D-mnRThU.js → activity-wgT0-JR0.js} +2 -2
  5. package/dist/control-ui/assets/{agents-U_KSP5I_.js → agents-DG5PobrT.js} +2 -2
  6. package/dist/control-ui/assets/{channels-ohK9_G1O.js → channels-CX28oM42.js} +2 -2
  7. package/dist/control-ui/assets/{cron-6ZCzfU29.js → cron-B8ixwBqU.js} +2 -2
  8. package/dist/control-ui/assets/{debug-CSsDLg_s.js → debug-CnkYZUXy.js} +2 -2
  9. package/dist/control-ui/assets/{index-jUDczxhd.js → index-DQRZJKbO.js} +4 -4
  10. package/dist/control-ui/assets/{instances-782ZoDT4.js → instances-BE3mV1JC.js} +2 -2
  11. package/dist/control-ui/assets/{nodes-BMX16BKM.js → nodes-Cou4PWRX.js} +2 -2
  12. package/dist/control-ui/assets/{sessions-jLGSApYa.js → sessions-DpAaBT21.js} +2 -2
  13. package/dist/control-ui/assets/{skills-DweBwUhs.js → skills-DjA_j_20.js} +2 -2
  14. package/dist/control-ui/assets/{workboard-BsU-FXIo.js → workboard-BFnvbS0k.js} +2 -2
  15. package/dist/control-ui/index.html +1 -1
  16. package/dist/control-ui/sw.js +1 -1
  17. package/dist/gateway/protocol/index.d.ts +1 -1
  18. package/dist/{index-AZzJCgph.d.ts → index-DuDY3bCZ.d.ts} +2 -2
  19. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  20. package/dist/plugin-sdk/agent-config-primitives.d.ts +1 -1
  21. package/dist/plugin-sdk/{bundled-channel-config-schema-Dfn3b8sF.d.ts → bundled-channel-config-schema-BPFNnbwu.d.ts} +23 -23
  22. package/dist/plugin-sdk/bundled-channel-config-schema.d.ts +3 -3
  23. package/dist/plugin-sdk/channel-config-primitives.d.ts +2 -2
  24. package/dist/plugin-sdk/channel-config-schema-legacy.d.ts +3 -3
  25. package/dist/plugin-sdk/channel-config-schema.d.ts +2 -2
  26. package/dist/plugin-sdk/channel-core.d.ts +1 -1
  27. package/dist/plugin-sdk/channel-plugin-common.d.ts +1 -1
  28. package/dist/plugin-sdk/compat.d.ts +2 -2
  29. package/dist/plugin-sdk/{config-schema-DUddICQM.d.ts → config-schema-D7cABQ6o.d.ts} +1 -1
  30. package/dist/plugin-sdk/config-schema.d.ts +2 -2
  31. package/dist/plugin-sdk/core.d.ts +1 -1
  32. package/dist/plugin-sdk/discord.d.ts +2 -2
  33. package/dist/plugin-sdk/tts-runtime.d.ts +1 -1
  34. package/dist/plugin-sdk/{zod-schema.core-B4_b2R5K.d.ts → zod-schema.core-CwBNqcXp.d.ts} +1 -1
  35. package/package.json +4 -409
  36. package/CHANGELOG.md +0 -42
  37. package/THIRD_PARTY_NOTICES.md +0 -37
  38. package/docs/.i18n/README.md +0 -81
  39. package/docs/.i18n/ar-navigation.json +0 -18
  40. package/docs/.i18n/de-navigation.json +0 -18
  41. package/docs/.i18n/es-navigation.json +0 -18
  42. package/docs/.i18n/fr-navigation.json +0 -18
  43. package/docs/.i18n/glossary.ar.json +0 -78
  44. package/docs/.i18n/glossary.de.json +0 -78
  45. package/docs/.i18n/glossary.es.json +0 -78
  46. package/docs/.i18n/glossary.fa.json +0 -78
  47. package/docs/.i18n/glossary.fr.json +0 -78
  48. package/docs/.i18n/glossary.id.json +0 -78
  49. package/docs/.i18n/glossary.it.json +0 -78
  50. package/docs/.i18n/glossary.ja-JP.json +0 -98
  51. package/docs/.i18n/glossary.ko.json +0 -78
  52. package/docs/.i18n/glossary.nl.json +0 -78
  53. package/docs/.i18n/glossary.pl.json +0 -78
  54. package/docs/.i18n/glossary.pt-BR.json +0 -78
  55. package/docs/.i18n/glossary.th.json +0 -78
  56. package/docs/.i18n/glossary.tr.json +0 -78
  57. package/docs/.i18n/glossary.uk.json +0 -78
  58. package/docs/.i18n/glossary.vi.json +0 -78
  59. package/docs/.i18n/glossary.zh-CN.json +0 -1122
  60. package/docs/.i18n/glossary.zh-TW.json +0 -78
  61. package/docs/.i18n/id-navigation.json +0 -18
  62. package/docs/.i18n/it-navigation.json +0 -18
  63. package/docs/.i18n/ja-navigation.json +0 -18
  64. package/docs/.i18n/ko-navigation.json +0 -18
  65. package/docs/.i18n/pl-navigation.json +0 -18
  66. package/docs/.i18n/pt-BR-navigation.json +0 -18
  67. package/docs/.i18n/tr-navigation.json +0 -18
  68. package/docs/.i18n/translation-workflow.md +0 -111
  69. package/docs/.i18n/zh-Hans-navigation.json +0 -552
  70. package/docs/AGENTS.md +0 -36
  71. package/docs/CLAUDE.md +0 -1
  72. package/docs/agent-runtime-architecture.md +0 -48
  73. package/docs/announcements/bluebubbles-imessage.md +0 -79
  74. package/docs/auth-credential-semantics.md +0 -124
  75. package/docs/automation/auth-monitoring.md +0 -11
  76. package/docs/automation/clawflow.md +0 -12
  77. package/docs/automation/cron-jobs.md +0 -534
  78. package/docs/automation/cron-vs-heartbeat.md +0 -11
  79. package/docs/automation/gmail-pubsub.md +0 -11
  80. package/docs/automation/hooks.md +0 -387
  81. package/docs/automation/index.md +0 -135
  82. package/docs/automation/poll.md +0 -12
  83. package/docs/automation/standing-orders.md +0 -250
  84. package/docs/automation/taskflow.md +0 -155
  85. package/docs/automation/tasks.md +0 -374
  86. package/docs/automation/troubleshooting.md +0 -12
  87. package/docs/automation/webhook.md +0 -12
  88. package/docs/brave-search.md +0 -11
  89. package/docs/channels/access-groups.md +0 -201
  90. package/docs/channels/ambient-room-events.md +0 -214
  91. package/docs/channels/bot-loop-protection.md +0 -131
  92. package/docs/channels/broadcast-groups.md +0 -472
  93. package/docs/channels/channel-routing.md +0 -162
  94. package/docs/channels/clickclack.md +0 -138
  95. package/docs/channels/discord.md +0 -1758
  96. package/docs/channels/feishu.md +0 -650
  97. package/docs/channels/googlechat.md +0 -284
  98. package/docs/channels/group-messages.md +0 -95
  99. package/docs/channels/groups.md +0 -524
  100. package/docs/channels/imessage-from-bluebubbles.md +0 -259
  101. package/docs/channels/imessage.md +0 -839
  102. package/docs/channels/index.md +0 -64
  103. package/docs/channels/irc.md +0 -253
  104. package/docs/channels/line.md +0 -243
  105. package/docs/channels/location.md +0 -71
  106. package/docs/channels/matrix-migration.md +0 -370
  107. package/docs/channels/matrix-presentation.md +0 -77
  108. package/docs/channels/matrix-push-rules.md +0 -150
  109. package/docs/channels/matrix.md +0 -921
  110. package/docs/channels/mattermost.md +0 -542
  111. package/docs/channels/msteams.md +0 -1096
  112. package/docs/channels/nextcloud-talk.md +0 -176
  113. package/docs/channels/nostr.md +0 -253
  114. package/docs/channels/pairing.md +0 -214
  115. package/docs/channels/qqbot.md +0 -314
  116. package/docs/channels/signal.md +0 -417
  117. package/docs/channels/slack.md +0 -1623
  118. package/docs/channels/synology-chat.md +0 -187
  119. package/docs/channels/telegram.md +0 -1124
  120. package/docs/channels/tlon.md +0 -296
  121. package/docs/channels/troubleshooting.md +0 -162
  122. package/docs/channels/twitch.md +0 -431
  123. package/docs/channels/wechat.md +0 -171
  124. package/docs/channels/whatsapp.md +0 -796
  125. package/docs/channels/yuanbao.md +0 -416
  126. package/docs/channels/zalo.md +0 -253
  127. package/docs/channels/zalouser.md +0 -217
  128. package/docs/ci.md +0 -657
  129. package/docs/clawhub/publishing.md +0 -96
  130. package/docs/cli/acp.md +0 -370
  131. package/docs/cli/agent.md +0 -109
  132. package/docs/cli/agents.md +0 -253
  133. package/docs/cli/approvals.md +0 -190
  134. package/docs/cli/backup.md +0 -98
  135. package/docs/cli/browser.md +0 -307
  136. package/docs/cli/channels.md +0 -154
  137. package/docs/cli/clawbot.md +0 -25
  138. package/docs/cli/commitments.md +0 -90
  139. package/docs/cli/completion.md +0 -39
  140. package/docs/cli/config.md +0 -504
  141. package/docs/cli/configure.md +0 -77
  142. package/docs/cli/crestodian.md +0 -337
  143. package/docs/cli/cron.md +0 -304
  144. package/docs/cli/daemon.md +0 -67
  145. package/docs/cli/dashboard.md +0 -33
  146. package/docs/cli/devices.md +0 -240
  147. package/docs/cli/directory.md +0 -68
  148. package/docs/cli/dns.md +0 -53
  149. package/docs/cli/docs.md +0 -63
  150. package/docs/cli/doctor.md +0 -241
  151. package/docs/cli/flows.md +0 -52
  152. package/docs/cli/gateway.md +0 -572
  153. package/docs/cli/health.md +0 -43
  154. package/docs/cli/hooks.md +0 -345
  155. package/docs/cli/index.md +0 -400
  156. package/docs/cli/infer.md +0 -364
  157. package/docs/cli/logs.md +0 -68
  158. package/docs/cli/mcp.md +0 -529
  159. package/docs/cli/memory.md +0 -183
  160. package/docs/cli/message.md +0 -317
  161. package/docs/cli/migrate.md +0 -334
  162. package/docs/cli/models.md +0 -239
  163. package/docs/cli/node.md +0 -177
  164. package/docs/cli/nodes.md +0 -76
  165. package/docs/cli/onboard.md +0 -250
  166. package/docs/cli/pairing.md +0 -77
  167. package/docs/cli/path.md +0 -511
  168. package/docs/cli/plugins.md +0 -459
  169. package/docs/cli/policy.md +0 -886
  170. package/docs/cli/proxy.md +0 -89
  171. package/docs/cli/qr.md +0 -56
  172. package/docs/cli/reset.md +0 -39
  173. package/docs/cli/sandbox.md +0 -208
  174. package/docs/cli/secrets.md +0 -202
  175. package/docs/cli/security.md +0 -136
  176. package/docs/cli/sessions.md +0 -164
  177. package/docs/cli/setup.md +0 -59
  178. package/docs/cli/skills.md +0 -122
  179. package/docs/cli/status.md +0 -45
  180. package/docs/cli/system.md +0 -89
  181. package/docs/cli/tasks.md +0 -111
  182. package/docs/cli/transcripts.md +0 -151
  183. package/docs/cli/tui.md +0 -91
  184. package/docs/cli/uninstall.md +0 -44
  185. package/docs/cli/update.md +0 -243
  186. package/docs/cli/voicecall.md +0 -204
  187. package/docs/cli/webhooks.md +0 -117
  188. package/docs/cli/wiki.md +0 -256
  189. package/docs/concepts/active-memory.md +0 -856
  190. package/docs/concepts/agent-loop.md +0 -185
  191. package/docs/concepts/agent-runtimes.md +0 -276
  192. package/docs/concepts/agent-workspace.md +0 -230
  193. package/docs/concepts/agent.md +0 -140
  194. package/docs/concepts/architecture.md +0 -154
  195. package/docs/concepts/channel-docking.md +0 -145
  196. package/docs/concepts/commitments.md +0 -150
  197. package/docs/concepts/compaction.md +0 -203
  198. package/docs/concepts/context-engine.md +0 -347
  199. package/docs/concepts/context.md +0 -199
  200. package/docs/concepts/delegate-architecture.md +0 -319
  201. package/docs/concepts/dreaming.md +0 -264
  202. package/docs/concepts/experimental-features.md +0 -109
  203. package/docs/concepts/features.md +0 -91
  204. package/docs/concepts/fengming-sdk.md +0 -323
  205. package/docs/concepts/mantis-slack-desktop-runbook.md +0 -231
  206. package/docs/concepts/mantis.md +0 -744
  207. package/docs/concepts/markdown-formatting.md +0 -139
  208. package/docs/concepts/memory-builtin.md +0 -148
  209. package/docs/concepts/memory-honcho.md +0 -144
  210. package/docs/concepts/memory-qmd.md +0 -271
  211. package/docs/concepts/memory-search.md +0 -167
  212. package/docs/concepts/memory.md +0 -299
  213. package/docs/concepts/message-lifecycle-refactor.md +0 -1126
  214. package/docs/concepts/messages.md +0 -214
  215. package/docs/concepts/model-failover.md +0 -384
  216. package/docs/concepts/model-providers.md +0 -719
  217. package/docs/concepts/models.md +0 -371
  218. package/docs/concepts/multi-agent.md +0 -625
  219. package/docs/concepts/oauth.md +0 -198
  220. package/docs/concepts/parallel-specialist-lanes.md +0 -127
  221. package/docs/concepts/personal-agent-benchmark-pack.md +0 -74
  222. package/docs/concepts/presence.md +0 -117
  223. package/docs/concepts/progress-drafts.md +0 -406
  224. package/docs/concepts/qa-e2e-automation.md +0 -947
  225. package/docs/concepts/qa-matrix.md +0 -139
  226. package/docs/concepts/queue-steering.md +0 -90
  227. package/docs/concepts/queue.md +0 -136
  228. package/docs/concepts/retry.md +0 -86
  229. package/docs/concepts/session-pruning.md +0 -104
  230. package/docs/concepts/session-tool.md +0 -188
  231. package/docs/concepts/session.md +0 -164
  232. package/docs/concepts/soul.md +0 -116
  233. package/docs/concepts/streaming.md +0 -257
  234. package/docs/concepts/system-prompt.md +0 -328
  235. package/docs/concepts/timezone.md +0 -47
  236. package/docs/concepts/typebox.md +0 -309
  237. package/docs/concepts/typing-indicators.md +0 -88
  238. package/docs/concepts/usage-tracking.md +0 -66
  239. package/docs/date-time.md +0 -126
  240. package/docs/debug/node-issue.md +0 -90
  241. package/docs/diagnostics/flags.md +0 -182
  242. package/docs/docs.json +0 -1862
  243. package/docs/fengming-agent-runtime.md +0 -82
  244. package/docs/gateway/authentication.md +0 -256
  245. package/docs/gateway/background-process.md +0 -147
  246. package/docs/gateway/bonjour.md +0 -303
  247. package/docs/gateway/bridge-protocol.md +0 -97
  248. package/docs/gateway/cli-backends.md +0 -439
  249. package/docs/gateway/config-agents.md +0 -1525
  250. package/docs/gateway/config-channels.md +0 -945
  251. package/docs/gateway/config-tools.md +0 -774
  252. package/docs/gateway/configuration-examples.md +0 -704
  253. package/docs/gateway/configuration-reference.md +0 -1391
  254. package/docs/gateway/configuration.md +0 -739
  255. package/docs/gateway/diagnostics.md +0 -213
  256. package/docs/gateway/discovery.md +0 -154
  257. package/docs/gateway/doctor.md +0 -575
  258. package/docs/gateway/gateway-lock.md +0 -37
  259. package/docs/gateway/health.md +0 -73
  260. package/docs/gateway/heartbeat.md +0 -498
  261. package/docs/gateway/index.md +0 -383
  262. package/docs/gateway/local-model-services.md +0 -205
  263. package/docs/gateway/local-models.md +0 -355
  264. package/docs/gateway/logging.md +0 -149
  265. package/docs/gateway/multiple-gateways.md +0 -178
  266. package/docs/gateway/network-model.md +0 -15
  267. package/docs/gateway/openai-http-api.md +0 -378
  268. package/docs/gateway/openresponses-http-api.md +0 -347
  269. package/docs/gateway/openshell.md +0 -316
  270. package/docs/gateway/opentelemetry.md +0 -433
  271. package/docs/gateway/operator-scopes.md +0 -119
  272. package/docs/gateway/pairing.md +0 -207
  273. package/docs/gateway/prometheus.md +0 -249
  274. package/docs/gateway/protocol.md +0 -826
  275. package/docs/gateway/remote-gateway-readme.md +0 -169
  276. package/docs/gateway/remote.md +0 -280
  277. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -148
  278. package/docs/gateway/sandboxing.md +0 -546
  279. package/docs/gateway/secrets-plan-contract.md +0 -159
  280. package/docs/gateway/secrets.md +0 -805
  281. package/docs/gateway/security/audit-checks.md +0 -127
  282. package/docs/gateway/security/exposure-runbook.md +0 -212
  283. package/docs/gateway/security/index.md +0 -1343
  284. package/docs/gateway/security/secure-file-operations.md +0 -76
  285. package/docs/gateway/security/shrinkwrap.md +0 -111
  286. package/docs/gateway/tailscale.md +0 -156
  287. package/docs/gateway/tools-invoke-http-api.md +0 -169
  288. package/docs/gateway/troubleshooting.md +0 -877
  289. package/docs/gateway/trusted-proxy-auth.md +0 -483
  290. package/docs/help/debugging.md +0 -341
  291. package/docs/help/environment.md +0 -233
  292. package/docs/help/faq-first-run.md +0 -870
  293. package/docs/help/faq-models.md +0 -556
  294. package/docs/help/faq.md +0 -2041
  295. package/docs/help/index.md +0 -39
  296. package/docs/help/scripts.md +0 -56
  297. package/docs/help/testing-live.md +0 -587
  298. package/docs/help/testing-updates-plugins.md +0 -299
  299. package/docs/help/testing.md +0 -977
  300. package/docs/help/troubleshooting.md +0 -449
  301. package/docs/index.md +0 -196
  302. package/docs/install/ansible.md +0 -233
  303. package/docs/install/azure.md +0 -315
  304. package/docs/install/bun.md +0 -59
  305. package/docs/install/clawdock.md +0 -112
  306. package/docs/install/development-channels.md +0 -148
  307. package/docs/install/digitalocean.md +0 -174
  308. package/docs/install/docker-vm-runtime.md +0 -154
  309. package/docs/install/docker.md +0 -564
  310. package/docs/install/exe-dev.md +0 -201
  311. package/docs/install/fly.md +0 -524
  312. package/docs/install/gcp.md +0 -418
  313. package/docs/install/hetzner.md +0 -285
  314. package/docs/install/hostinger.md +0 -98
  315. package/docs/install/index.md +0 -232
  316. package/docs/install/installer.md +0 -447
  317. package/docs/install/kubernetes.md +0 -196
  318. package/docs/install/macos-vm.md +0 -281
  319. package/docs/install/migrating-claude.md +0 -165
  320. package/docs/install/migrating-hermes.md +0 -178
  321. package/docs/install/migrating.md +0 -137
  322. package/docs/install/nix.md +0 -112
  323. package/docs/install/node.md +0 -142
  324. package/docs/install/northflank.mdx +0 -44
  325. package/docs/install/oracle.md +0 -218
  326. package/docs/install/podman.md +0 -216
  327. package/docs/install/railway.mdx +0 -92
  328. package/docs/install/raspberry-pi.md +0 -234
  329. package/docs/install/render.mdx +0 -167
  330. package/docs/install/uninstall.md +0 -131
  331. package/docs/install/updating.md +0 -284
  332. package/docs/install/upstash.md +0 -96
  333. package/docs/logging.md +0 -320
  334. package/docs/nav-tabs-underline.js +0 -100
  335. package/docs/network.md +0 -72
  336. package/docs/nodes/audio.md +0 -216
  337. package/docs/nodes/camera.md +0 -166
  338. package/docs/nodes/images.md +0 -77
  339. package/docs/nodes/index.md +0 -439
  340. package/docs/nodes/location-command.md +0 -102
  341. package/docs/nodes/media-understanding.md +0 -495
  342. package/docs/nodes/talk.md +0 -160
  343. package/docs/nodes/troubleshooting.md +0 -123
  344. package/docs/nodes/voicewake.md +0 -93
  345. package/docs/perplexity.md +0 -11
  346. package/docs/plan/codex-context-engine-harness.md +0 -624
  347. package/docs/plan/ui-channels.md +0 -284
  348. package/docs/platforms/digitalocean.md +0 -12
  349. package/docs/platforms/easyrunner.md +0 -109
  350. package/docs/platforms/index.md +0 -51
  351. package/docs/platforms/linux.md +0 -141
  352. package/docs/platforms/mac/bundled-gateway.md +0 -79
  353. package/docs/platforms/mac/canvas.md +0 -128
  354. package/docs/platforms/mac/child-process.md +0 -72
  355. package/docs/platforms/mac/dev-setup.md +0 -112
  356. package/docs/platforms/mac/health.md +0 -39
  357. package/docs/platforms/mac/icon.md +0 -36
  358. package/docs/platforms/mac/logging.md +0 -62
  359. package/docs/platforms/mac/menu-bar.md +0 -93
  360. package/docs/platforms/mac/peekaboo.md +0 -96
  361. package/docs/platforms/mac/permissions.md +0 -73
  362. package/docs/platforms/mac/remote.md +0 -123
  363. package/docs/platforms/mac/signing.md +0 -52
  364. package/docs/platforms/mac/skills.md +0 -43
  365. package/docs/platforms/mac/voice-overlay.md +0 -66
  366. package/docs/platforms/mac/voicewake.md +0 -73
  367. package/docs/platforms/mac/webchat.md +0 -54
  368. package/docs/platforms/mac/xpc.md +0 -66
  369. package/docs/platforms/oracle.md +0 -12
  370. package/docs/platforms/raspberry-pi.md +0 -13
  371. package/docs/platforms/windows.md +0 -286
  372. package/docs/plugins/adding-capabilities.md +0 -146
  373. package/docs/plugins/admin-http-rpc.md +0 -216
  374. package/docs/plugins/agent-tools.md +0 -13
  375. package/docs/plugins/architecture-internals.md +0 -1196
  376. package/docs/plugins/architecture.md +0 -483
  377. package/docs/plugins/building-extensions.md +0 -13
  378. package/docs/plugins/building-plugins.md +0 -335
  379. package/docs/plugins/bundles.md +0 -310
  380. package/docs/plugins/cli-backend-plugins.md +0 -310
  381. package/docs/plugins/codex-computer-use.md +0 -297
  382. package/docs/plugins/codex-harness-reference.md +0 -470
  383. package/docs/plugins/codex-harness-runtime.md +0 -268
  384. package/docs/plugins/codex-harness.md +0 -780
  385. package/docs/plugins/codex-native-plugins.md +0 -276
  386. package/docs/plugins/community.md +0 -77
  387. package/docs/plugins/compatibility.md +0 -167
  388. package/docs/plugins/copilot.md +0 -356
  389. package/docs/plugins/dependency-resolution.md +0 -176
  390. package/docs/plugins/google-meet.md +0 -1737
  391. package/docs/plugins/hooks.md +0 -484
  392. package/docs/plugins/install-overrides.md +0 -80
  393. package/docs/plugins/manage-plugins.md +0 -210
  394. package/docs/plugins/manifest.md +0 -1457
  395. package/docs/plugins/memory-lancedb.md +0 -385
  396. package/docs/plugins/memory-wiki.md +0 -529
  397. package/docs/plugins/message-presentation.md +0 -473
  398. package/docs/plugins/oc-path.md +0 -166
  399. package/docs/plugins/plugin-inventory.md +0 -189
  400. package/docs/plugins/plugin-permission-requests.md +0 -193
  401. package/docs/plugins/reference/acpx.md +0 -23
  402. package/docs/plugins/reference/admin-http-rpc.md +0 -23
  403. package/docs/plugins/reference/alibaba.md +0 -23
  404. package/docs/plugins/reference/amazon-bedrock-mantle.md +0 -23
  405. package/docs/plugins/reference/amazon-bedrock.md +0 -23
  406. package/docs/plugins/reference/anthropic-vertex.md +0 -19
  407. package/docs/plugins/reference/anthropic.md +0 -23
  408. package/docs/plugins/reference/arcee.md +0 -23
  409. package/docs/plugins/reference/azure-speech.md +0 -23
  410. package/docs/plugins/reference/bonjour.md +0 -19
  411. package/docs/plugins/reference/brave.md +0 -23
  412. package/docs/plugins/reference/browser.md +0 -23
  413. package/docs/plugins/reference/byteplus.md +0 -19
  414. package/docs/plugins/reference/canvas.md +0 -19
  415. package/docs/plugins/reference/cerebras.md +0 -23
  416. package/docs/plugins/reference/chutes.md +0 -23
  417. package/docs/plugins/reference/clickclack.md +0 -23
  418. package/docs/plugins/reference/cloudflare-ai-gateway.md +0 -23
  419. package/docs/plugins/reference/codex-supervisor.md +0 -27
  420. package/docs/plugins/reference/codex.md +0 -23
  421. package/docs/plugins/reference/comfy.md +0 -23
  422. package/docs/plugins/reference/copilot-proxy.md +0 -19
  423. package/docs/plugins/reference/copilot.md +0 -23
  424. package/docs/plugins/reference/deepgram.md +0 -23
  425. package/docs/plugins/reference/deepinfra.md +0 -23
  426. package/docs/plugins/reference/deepseek.md +0 -23
  427. package/docs/plugins/reference/diagnostics-otel.md +0 -19
  428. package/docs/plugins/reference/diagnostics-prometheus.md +0 -19
  429. package/docs/plugins/reference/diffs-language-pack.md +0 -19
  430. package/docs/plugins/reference/diffs.md +0 -19
  431. package/docs/plugins/reference/discord.md +0 -23
  432. package/docs/plugins/reference/document-extract.md +0 -23
  433. package/docs/plugins/reference/duckduckgo.md +0 -23
  434. package/docs/plugins/reference/elevenlabs.md +0 -23
  435. package/docs/plugins/reference/exa.md +0 -23
  436. package/docs/plugins/reference/fal.md +0 -23
  437. package/docs/plugins/reference/feishu.md +0 -23
  438. package/docs/plugins/reference/file-transfer.md +0 -19
  439. package/docs/plugins/reference/firecrawl.md +0 -23
  440. package/docs/plugins/reference/fireworks.md +0 -23
  441. package/docs/plugins/reference/github-copilot.md +0 -23
  442. package/docs/plugins/reference/gmi.md +0 -23
  443. package/docs/plugins/reference/google-meet.md +0 -23
  444. package/docs/plugins/reference/google.md +0 -23
  445. package/docs/plugins/reference/googlechat.md +0 -23
  446. package/docs/plugins/reference/gradium.md +0 -23
  447. package/docs/plugins/reference/groq.md +0 -23
  448. package/docs/plugins/reference/huggingface.md +0 -23
  449. package/docs/plugins/reference/imessage.md +0 -23
  450. package/docs/plugins/reference/inworld.md +0 -23
  451. package/docs/plugins/reference/irc.md +0 -23
  452. package/docs/plugins/reference/kilocode.md +0 -23
  453. package/docs/plugins/reference/kimi.md +0 -23
  454. package/docs/plugins/reference/line.md +0 -23
  455. package/docs/plugins/reference/litellm.md +0 -23
  456. package/docs/plugins/reference/llm-task.md +0 -19
  457. package/docs/plugins/reference/lmstudio.md +0 -23
  458. package/docs/plugins/reference/lobster.md +0 -19
  459. package/docs/plugins/reference/matrix.md +0 -23
  460. package/docs/plugins/reference/mattermost.md +0 -23
  461. package/docs/plugins/reference/memory-core.md +0 -19
  462. package/docs/plugins/reference/memory-lancedb.md +0 -23
  463. package/docs/plugins/reference/memory-wiki.md +0 -23
  464. package/docs/plugins/reference/microsoft-foundry.md +0 -19
  465. package/docs/plugins/reference/microsoft.md +0 -19
  466. package/docs/plugins/reference/migrate-claude.md +0 -19
  467. package/docs/plugins/reference/migrate-hermes.md +0 -19
  468. package/docs/plugins/reference/minimax.md +0 -23
  469. package/docs/plugins/reference/mistral.md +0 -23
  470. package/docs/plugins/reference/moonshot.md +0 -23
  471. package/docs/plugins/reference/msteams.md +0 -23
  472. package/docs/plugins/reference/nextcloud-talk.md +0 -23
  473. package/docs/plugins/reference/nostr.md +0 -23
  474. package/docs/plugins/reference/novita.md +0 -23
  475. package/docs/plugins/reference/nvidia.md +0 -23
  476. package/docs/plugins/reference/oc-path.md +0 -23
  477. package/docs/plugins/reference/ollama.md +0 -23
  478. package/docs/plugins/reference/open-prose.md +0 -19
  479. package/docs/plugins/reference/openai.md +0 -23
  480. package/docs/plugins/reference/opencode-go.md +0 -23
  481. package/docs/plugins/reference/opencode.md +0 -23
  482. package/docs/plugins/reference/openrouter.md +0 -23
  483. package/docs/plugins/reference/openshell.md +0 -19
  484. package/docs/plugins/reference/perplexity.md +0 -23
  485. package/docs/plugins/reference/pixverse.md +0 -23
  486. package/docs/plugins/reference/policy.md +0 -72
  487. package/docs/plugins/reference/qa-channel.md +0 -23
  488. package/docs/plugins/reference/qa-lab.md +0 -19
  489. package/docs/plugins/reference/qa-matrix.md +0 -19
  490. package/docs/plugins/reference/qianfan.md +0 -23
  491. package/docs/plugins/reference/qqbot.md +0 -23
  492. package/docs/plugins/reference/qwen.md +0 -23
  493. package/docs/plugins/reference/runway.md +0 -23
  494. package/docs/plugins/reference/searxng.md +0 -19
  495. package/docs/plugins/reference/senseaudio.md +0 -23
  496. package/docs/plugins/reference/sglang.md +0 -23
  497. package/docs/plugins/reference/signal.md +0 -23
  498. package/docs/plugins/reference/skill-workshop.md +0 -23
  499. package/docs/plugins/reference/slack.md +0 -23
  500. package/docs/plugins/reference/stepfun.md +0 -23
  501. package/docs/plugins/reference/synology-chat.md +0 -23
  502. package/docs/plugins/reference/synthetic.md +0 -23
  503. package/docs/plugins/reference/tavily.md +0 -23
  504. package/docs/plugins/reference/telegram.md +0 -23
  505. package/docs/plugins/reference/tencent.md +0 -23
  506. package/docs/plugins/reference/tlon.md +0 -23
  507. package/docs/plugins/reference/together.md +0 -23
  508. package/docs/plugins/reference/tokenjuice.md +0 -23
  509. package/docs/plugins/reference/tts-local-cli.md +0 -19
  510. package/docs/plugins/reference/twitch.md +0 -23
  511. package/docs/plugins/reference/venice.md +0 -23
  512. package/docs/plugins/reference/vercel-ai-gateway.md +0 -23
  513. package/docs/plugins/reference/vllm.md +0 -23
  514. package/docs/plugins/reference/voice-call.md +0 -23
  515. package/docs/plugins/reference/volcengine.md +0 -23
  516. package/docs/plugins/reference/voyage.md +0 -19
  517. package/docs/plugins/reference/vydra.md +0 -23
  518. package/docs/plugins/reference/web-readability.md +0 -19
  519. package/docs/plugins/reference/webhooks.md +0 -23
  520. package/docs/plugins/reference/whatsapp.md +0 -23
  521. package/docs/plugins/reference/workboard.md +0 -23
  522. package/docs/plugins/reference/xai.md +0 -23
  523. package/docs/plugins/reference/xiaomi.md +0 -23
  524. package/docs/plugins/reference/zai.md +0 -23
  525. package/docs/plugins/reference/zalo.md +0 -23
  526. package/docs/plugins/reference/zalouser.md +0 -24
  527. package/docs/plugins/reference.md +0 -145
  528. package/docs/plugins/sdk-agent-harness.md +0 -338
  529. package/docs/plugins/sdk-channel-inbound.md +0 -70
  530. package/docs/plugins/sdk-channel-ingress.md +0 -137
  531. package/docs/plugins/sdk-channel-message.md +0 -18
  532. package/docs/plugins/sdk-channel-outbound.md +0 -113
  533. package/docs/plugins/sdk-channel-plugins.md +0 -765
  534. package/docs/plugins/sdk-channel-turn.md +0 -9
  535. package/docs/plugins/sdk-entrypoints.md +0 -344
  536. package/docs/plugins/sdk-migration.md +0 -979
  537. package/docs/plugins/sdk-overview.md +0 -511
  538. package/docs/plugins/sdk-provider-plugins.md +0 -846
  539. package/docs/plugins/sdk-runtime.md +0 -676
  540. package/docs/plugins/sdk-setup.md +0 -550
  541. package/docs/plugins/sdk-subpaths.md +0 -391
  542. package/docs/plugins/sdk-testing.md +0 -403
  543. package/docs/plugins/skill-workshop.md +0 -713
  544. package/docs/plugins/tool-plugins.md +0 -411
  545. package/docs/plugins/voice-call.md +0 -942
  546. package/docs/plugins/webhooks.md +0 -192
  547. package/docs/plugins/workboard.md +0 -252
  548. package/docs/plugins/zalouser.md +0 -86
  549. package/docs/prose.md +0 -137
  550. package/docs/providers/alibaba.md +0 -158
  551. package/docs/providers/anthropic.md +0 -381
  552. package/docs/providers/arcee.md +0 -144
  553. package/docs/providers/azure-speech.md +0 -119
  554. package/docs/providers/bedrock-mantle.md +0 -211
  555. package/docs/providers/bedrock.md +0 -414
  556. package/docs/providers/cerebras.md +0 -130
  557. package/docs/providers/chutes.md +0 -153
  558. package/docs/providers/claude-max-api-proxy.md +0 -191
  559. package/docs/providers/cloudflare-ai-gateway.md +0 -119
  560. package/docs/providers/comfy.md +0 -362
  561. package/docs/providers/deepgram.md +0 -184
  562. package/docs/providers/deepinfra.md +0 -92
  563. package/docs/providers/deepseek.md +0 -146
  564. package/docs/providers/ds4.md +0 -309
  565. package/docs/providers/elevenlabs.md +0 -130
  566. package/docs/providers/fal.md +0 -240
  567. package/docs/providers/fireworks.md +0 -144
  568. package/docs/providers/github-copilot.md +0 -257
  569. package/docs/providers/gmi.md +0 -92
  570. package/docs/providers/google.md +0 -472
  571. package/docs/providers/gradium.md +0 -123
  572. package/docs/providers/groq.md +0 -171
  573. package/docs/providers/huggingface.md +0 -235
  574. package/docs/providers/index.md +0 -105
  575. package/docs/providers/inferrs.md +0 -272
  576. package/docs/providers/inworld.md +0 -120
  577. package/docs/providers/kilocode.md +0 -135
  578. package/docs/providers/litellm.md +0 -234
  579. package/docs/providers/lmstudio.md +0 -224
  580. package/docs/providers/minimax.md +0 -505
  581. package/docs/providers/mistral.md +0 -235
  582. package/docs/providers/models.md +0 -64
  583. package/docs/providers/moonshot.md +0 -413
  584. package/docs/providers/novita.md +0 -92
  585. package/docs/providers/nvidia.md +0 -158
  586. package/docs/providers/ollama-cloud.md +0 -115
  587. package/docs/providers/ollama.md +0 -1225
  588. package/docs/providers/openai.md +0 -1093
  589. package/docs/providers/opencode-go.md +0 -123
  590. package/docs/providers/opencode.md +0 -149
  591. package/docs/providers/openrouter.md +0 -349
  592. package/docs/providers/perplexity-provider.md +0 -123
  593. package/docs/providers/pixverse.md +0 -165
  594. package/docs/providers/qianfan.md +0 -132
  595. package/docs/providers/qwen-oauth.md +0 -115
  596. package/docs/providers/qwen.md +0 -364
  597. package/docs/providers/runway.md +0 -103
  598. package/docs/providers/senseaudio.md +0 -68
  599. package/docs/providers/sglang.md +0 -161
  600. package/docs/providers/stepfun.md +0 -229
  601. package/docs/providers/synthetic.md +0 -154
  602. package/docs/providers/tencent.md +0 -130
  603. package/docs/providers/together.md +0 -140
  604. package/docs/providers/venice.md +0 -312
  605. package/docs/providers/vercel-ai-gateway.md +0 -128
  606. package/docs/providers/vllm.md +0 -407
  607. package/docs/providers/volcengine.md +0 -199
  608. package/docs/providers/vydra.md +0 -180
  609. package/docs/providers/xai.md +0 -571
  610. package/docs/providers/xiaomi.md +0 -262
  611. package/docs/providers/zai.md +0 -224
  612. package/docs/refactor/access.md +0 -9
  613. package/docs/refactor/acp.md +0 -298
  614. package/docs/refactor/canvas.md +0 -131
  615. package/docs/refactor/database-first.md +0 -2256
  616. package/docs/refactor/ingress-core.md +0 -341
  617. package/docs/reference/AGENTS.default.md +0 -131
  618. package/docs/reference/RELEASING.md +0 -799
  619. package/docs/reference/api-usage-costs.md +0 -208
  620. package/docs/reference/application-modernization-plan.md +0 -208
  621. package/docs/reference/code-mode.md +0 -773
  622. package/docs/reference/credits.md +0 -33
  623. package/docs/reference/device-models.md +0 -50
  624. package/docs/reference/fengming-sdk-api-design.md +0 -390
  625. package/docs/reference/full-release-validation.md +0 -202
  626. package/docs/reference/memory-config.md +0 -604
  627. package/docs/reference/prompt-caching.md +0 -358
  628. package/docs/reference/release-performance-sweep.md +0 -360
  629. package/docs/reference/rich-output-protocol.md +0 -101
  630. package/docs/reference/rpc.md +0 -43
  631. package/docs/reference/secret-placeholder-conventions.md +0 -33
  632. package/docs/reference/secretref-credential-surface.md +0 -159
  633. package/docs/reference/secretref-user-supplied-credentials-matrix.json +0 -663
  634. package/docs/reference/session-management-compaction.md +0 -474
  635. package/docs/reference/templates/AGENTS.dev.md +0 -90
  636. package/docs/reference/templates/AGENTS.md +0 -227
  637. package/docs/reference/templates/BOOT.md +0 -16
  638. package/docs/reference/templates/BOOTSTRAP.md +0 -66
  639. package/docs/reference/templates/CLAUDE.md +0 -1
  640. package/docs/reference/templates/HEARTBEAT.md +0 -24
  641. package/docs/reference/templates/IDENTITY.dev.md +0 -52
  642. package/docs/reference/templates/IDENTITY.md +0 -34
  643. package/docs/reference/templates/SOUL.dev.md +0 -82
  644. package/docs/reference/templates/SOUL.md +0 -49
  645. package/docs/reference/templates/TOOLS.dev.md +0 -29
  646. package/docs/reference/templates/TOOLS.md +0 -51
  647. package/docs/reference/templates/USER.dev.md +0 -23
  648. package/docs/reference/templates/USER.md +0 -28
  649. package/docs/reference/test.md +0 -247
  650. package/docs/reference/token-use.md +0 -246
  651. package/docs/reference/transcript-hygiene.md +0 -214
  652. package/docs/reference/wizard.md +0 -252
  653. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +0 -101
  654. package/docs/security/THREAT-MODEL-ATLAS.md +0 -611
  655. package/docs/security/formal-verification.md +0 -170
  656. package/docs/security/incident-response.md +0 -59
  657. package/docs/security/network-proxy.md +0 -268
  658. package/docs/snippets/plugin-publish/minimal-fengming.plugin.json +0 -12
  659. package/docs/snippets/plugin-publish/minimal-package.json +0 -16
  660. package/docs/specs/claw-supervisor.md +0 -247
  661. package/docs/start/bootstrapping.md +0 -49
  662. package/docs/start/docs-directory.md +0 -69
  663. package/docs/start/fengming.md +0 -252
  664. package/docs/start/getting-started.md +0 -152
  665. package/docs/start/hubs.md +0 -201
  666. package/docs/start/lore.md +0 -223
  667. package/docs/start/onboarding-overview.md +0 -72
  668. package/docs/start/onboarding.md +0 -98
  669. package/docs/start/quickstart.md +0 -25
  670. package/docs/start/setup.md +0 -178
  671. package/docs/start/showcase.md +0 -363
  672. package/docs/start/wizard-cli-automation.md +0 -232
  673. package/docs/start/wizard-cli-reference.md +0 -331
  674. package/docs/start/wizard.md +0 -141
  675. package/docs/style.css +0 -137
  676. package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +0 -316
  677. package/docs/tools/acp-agents-setup.md +0 -351
  678. package/docs/tools/acp-agents.md +0 -854
  679. package/docs/tools/agent-send.md +0 -130
  680. package/docs/tools/apply-patch.md +0 -64
  681. package/docs/tools/brave-search.md +0 -139
  682. package/docs/tools/browser-control.md +0 -391
  683. package/docs/tools/browser-linux-troubleshooting.md +0 -173
  684. package/docs/tools/browser-login.md +0 -77
  685. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +0 -219
  686. package/docs/tools/browser.md +0 -810
  687. package/docs/tools/btw.md +0 -159
  688. package/docs/tools/capability-cookbook.md +0 -12
  689. package/docs/tools/clawhub.md +0 -5
  690. package/docs/tools/code-execution.md +0 -173
  691. package/docs/tools/creating-skills.md +0 -158
  692. package/docs/tools/diffs.md +0 -525
  693. package/docs/tools/duckduckgo-search.md +0 -109
  694. package/docs/tools/elevated.md +0 -128
  695. package/docs/tools/exa-search.md +0 -152
  696. package/docs/tools/exec-approvals-advanced.md +0 -444
  697. package/docs/tools/exec-approvals.md +0 -494
  698. package/docs/tools/exec.md +0 -285
  699. package/docs/tools/firecrawl.md +0 -155
  700. package/docs/tools/gemini-search.md +0 -114
  701. package/docs/tools/goal.md +0 -217
  702. package/docs/tools/grok-search.md +0 -129
  703. package/docs/tools/image-generation.md +0 -493
  704. package/docs/tools/index.md +0 -178
  705. package/docs/tools/kimi-search.md +0 -105
  706. package/docs/tools/llm-task.md +0 -137
  707. package/docs/tools/lobster.md +0 -365
  708. package/docs/tools/loop-detection.md +0 -154
  709. package/docs/tools/media-overview.md +0 -160
  710. package/docs/tools/minimax-search.md +0 -102
  711. package/docs/tools/multi-agent-sandbox-tools.md +0 -409
  712. package/docs/tools/music-generation.md +0 -372
  713. package/docs/tools/ollama-search.md +0 -153
  714. package/docs/tools/pdf.md +0 -213
  715. package/docs/tools/perplexity-search.md +0 -220
  716. package/docs/tools/plugin.md +0 -363
  717. package/docs/tools/reactions.md +0 -100
  718. package/docs/tools/searxng-search.md +0 -141
  719. package/docs/tools/skills-config.md +0 -195
  720. package/docs/tools/skills.md +0 -569
  721. package/docs/tools/slash-commands.md +0 -487
  722. package/docs/tools/steer.md +0 -77
  723. package/docs/tools/subagents.md +0 -651
  724. package/docs/tools/tavily.md +0 -162
  725. package/docs/tools/thinking.md +0 -142
  726. package/docs/tools/tokenjuice.md +0 -84
  727. package/docs/tools/tool-search.md +0 -269
  728. package/docs/tools/trajectory.md +0 -229
  729. package/docs/tools/tts.md +0 -1009
  730. package/docs/tools/video-generation.md +0 -555
  731. package/docs/tools/web-fetch.md +0 -210
  732. package/docs/tools/web.md +0 -461
  733. package/docs/tts.md +0 -11
  734. package/docs/vps.md +0 -139
  735. package/docs/web/control-ui.md +0 -512
  736. package/docs/web/dashboard.md +0 -107
  737. package/docs/web/index.md +0 -133
  738. package/docs/web/tui.md +0 -250
  739. package/docs/web/webchat.md +0 -102
  740. package/npm-shrinkwrap.json +0 -12861
  741. package/patches/.gitkeep +0 -0
  742. package/patches/@agentclientprotocol__claude-agent-acp@0.37.0.patch +0 -41
  743. package/pnpm-workspace.yaml +0 -120
  744. package/scripts/crabbox-wrapper.mjs +0 -2004
  745. package/scripts/lib/official-external-channel-catalog.json +0 -560
  746. package/scripts/lib/official-external-plugin-catalog.json +0 -264
  747. package/scripts/lib/official-external-provider-catalog.json +0 -158
  748. package/scripts/lib/package-dist-imports.mjs +0 -171
  749. package/scripts/npm-runner.mjs +0 -91
  750. package/scripts/postinstall-bundled-plugins.mjs +0 -978
  751. package/scripts/preinstall-package-manager-warning.mjs +0 -64
  752. package/scripts/prepare-git-hooks.mjs +0 -72
  753. package/scripts/windows-cmd-helpers.mjs +0 -22
  754. package/skills/batch/SKILL.md +0 -118
  755. package/skills/code-review/SKILL.md +0 -107
  756. package/skills/debug/SKILL.md +0 -83
  757. package/skills/loop/SKILL.md +0 -118
  758. package/skills/run/SKILL.md +0 -79
  759. package/skills/run-skill-generator/SKILL.md +0 -179
  760. package/skills/verify/SKILL.md +0 -103
  761. package/src/agents/templates/HEARTBEAT.md +0 -3
@@ -1,921 +0,0 @@
1
- ---
2
- summary: "Matrix support status, setup, and configuration examples"
3
- read_when:
4
- - Setting up Matrix in FengMing
5
- - Configuring Matrix E2EE and verification
6
- title: "Matrix"
7
- ---
8
-
9
- Matrix is a downloadable channel plugin for FengMing.
10
- It uses the official `matrix-js-sdk` and supports DMs, rooms, threads, media, reactions, polls, location, and E2EE.
11
-
12
- ## Install
13
-
14
- Install Matrix from ClawHub before configuring the channel:
15
-
16
- ```bash
17
- fengming plugins install @fengming/matrix
18
- ```
19
-
20
- Bare plugin specs try ClawHub first, then npm fallback. To force the registry source, use `fengming plugins install clawhub:@fengming/matrix` or `fengming plugins install npm:@fengming/matrix`.
21
-
22
- From a local checkout:
23
-
24
- ```bash
25
- fengming plugins install ./path/to/local/matrix-plugin
26
- ```
27
-
28
- `plugins install` registers and enables the plugin, so no separate `fengming plugins enable matrix` step is needed. The plugin still does nothing until you configure the channel below. See [Plugins](/tools/plugin) for general plugin behavior and install rules.
29
-
30
- ## Setup
31
-
32
- 1. Create a Matrix account on your homeserver.
33
- 2. Configure `channels.matrix` with either `homeserver` + `accessToken`, or `homeserver` + `userId` + `password`.
34
- 3. Restart the gateway.
35
- 4. Start a DM with the bot, or invite it to a room (see [auto-join](#auto-join) - fresh invites only land when `autoJoin` allows them).
36
-
37
- ### Interactive setup
38
-
39
- ```bash
40
- fengming channels add
41
- fengming configure --section channels
42
- ```
43
-
44
- The wizard asks for: homeserver URL, auth method (access token or password), user ID (password auth only), optional device name, whether to enable E2EE, and whether to configure room access and auto-join.
45
-
46
- If matching `MATRIX_*` env vars already exist and the selected account has no saved auth, the wizard offers an env-var shortcut. To resolve room names before saving an allowlist, run `fengming channels resolve --channel matrix "Project Room"`. When E2EE is enabled, the wizard writes the config and runs the same bootstrap as [`fengming matrix encryption setup`](#encryption-and-verification).
47
-
48
- ### Minimal config
49
-
50
- Token-based:
51
-
52
- ```json5
53
- {
54
- channels: {
55
- matrix: {
56
- enabled: true,
57
- homeserver: "https://matrix.example.org",
58
- accessToken: "syt_xxx",
59
- dm: { policy: "pairing" },
60
- },
61
- },
62
- }
63
- ```
64
-
65
- Password-based (the token is cached after first login):
66
-
67
- ```json5
68
- {
69
- channels: {
70
- matrix: {
71
- enabled: true,
72
- homeserver: "https://matrix.example.org",
73
- userId: "@bot:example.org",
74
- password: "replace-me", // pragma: allowlist secret
75
- deviceName: "FengMing Gateway",
76
- },
77
- },
78
- }
79
- ```
80
-
81
- ### Auto-join
82
-
83
- `channels.matrix.autoJoin` defaults to `off`. With the default, the bot will not appear in new rooms or DMs from fresh invites until you join manually.
84
-
85
- FengMing cannot tell at invite time whether an invited room is a DM or a group, so all invites - including DM-style invites - go through `autoJoin` first. `dm.policy` only applies later, after the bot has joined and the room has been classified.
86
-
87
- <Warning>
88
- Set `autoJoin: "allowlist"` plus `autoJoinAllowlist` to restrict which invites the bot accepts, or `autoJoin: "always"` to accept every invite.
89
-
90
- `autoJoinAllowlist` only accepts stable targets: `!roomId:server`, `#alias:server`, or `*`. Plain room names are rejected; alias entries are resolved against the homeserver, not against state claimed by the invited room.
91
- </Warning>
92
-
93
- ```json5
94
- {
95
- channels: {
96
- matrix: {
97
- autoJoin: "allowlist",
98
- autoJoinAllowlist: ["!ops:example.org", "#support:example.org"],
99
- groups: {
100
- "!ops:example.org": { requireMention: true },
101
- },
102
- },
103
- },
104
- }
105
- ```
106
-
107
- To accept every invite, use `autoJoin: "always"`.
108
-
109
- ### Allowlist target formats
110
-
111
- DM and room allowlists are best populated with stable IDs:
112
-
113
- - DMs (`dm.allowFrom`, `groupAllowFrom`, `groups.<room>.users`): use `@user:server`. Display names are ignored by default because they are mutable; set `dangerouslyAllowNameMatching: true` only when you explicitly need compatibility with display-name entries.
114
- - Room allowlist keys (`groups`, legacy `rooms`): use `!room:server` or `#alias:server`. Plain room names are ignored by default; set `dangerouslyAllowNameMatching: true` only when you explicitly need compatibility with joined-room name lookup.
115
- - Invite allowlists (`autoJoinAllowlist`): use `!room:server`, `#alias:server`, or `*`. Plain room names are rejected.
116
-
117
- ### Account ID normalization
118
-
119
- The wizard converts a friendly name into a normalized account ID. For example, `Ops Bot` becomes `ops-bot`. Punctuation is escaped in scoped env-var names so that two accounts cannot collide: `-` → `_X2D_`, so `ops-prod` maps to `MATRIX_OPS_X2D_PROD_*`.
120
-
121
- ### Cached credentials
122
-
123
- Matrix stores cached credentials under `~/.fengming/credentials/matrix/`:
124
-
125
- - default account: `credentials.json`
126
- - named accounts: `credentials-<account>.json`
127
-
128
- When cached credentials exist there, FengMing treats Matrix as configured even if the access token is not in the config file - that covers setup, `fengming doctor`, and channel-status probes.
129
-
130
- ### Environment variables
131
-
132
- Used when the equivalent config key is not set. The default account uses unprefixed names; named accounts use the account ID inserted before the suffix.
133
-
134
- | Default account | Named account (`<ID>` is the normalized account ID) |
135
- | --------------------- | --------------------------------------------------- |
136
- | `MATRIX_HOMESERVER` | `MATRIX_<ID>_HOMESERVER` |
137
- | `MATRIX_ACCESS_TOKEN` | `MATRIX_<ID>_ACCESS_TOKEN` |
138
- | `MATRIX_USER_ID` | `MATRIX_<ID>_USER_ID` |
139
- | `MATRIX_PASSWORD` | `MATRIX_<ID>_PASSWORD` |
140
- | `MATRIX_DEVICE_ID` | `MATRIX_<ID>_DEVICE_ID` |
141
- | `MATRIX_DEVICE_NAME` | `MATRIX_<ID>_DEVICE_NAME` |
142
- | `MATRIX_RECOVERY_KEY` | `MATRIX_<ID>_RECOVERY_KEY` |
143
-
144
- For account `ops`, the names become `MATRIX_OPS_HOMESERVER`, `MATRIX_OPS_ACCESS_TOKEN`, and so on. The recovery-key env vars are read by recovery-aware CLI flows (`verify backup restore`, `verify device`, `verify bootstrap`) when you pipe the key in via `--recovery-key-stdin`.
145
-
146
- `MATRIX_HOMESERVER` cannot be set from a workspace `.env`; see [Workspace `.env` files](/gateway/security).
147
-
148
- ## Configuration example
149
-
150
- A practical baseline with DM pairing, room allowlist, and E2EE:
151
-
152
- ```json5
153
- {
154
- channels: {
155
- matrix: {
156
- enabled: true,
157
- homeserver: "https://matrix.example.org",
158
- accessToken: "syt_xxx",
159
- encryption: true,
160
-
161
- dm: {
162
- policy: "pairing",
163
- sessionScope: "per-room",
164
- threadReplies: "off",
165
- },
166
-
167
- groupPolicy: "allowlist",
168
- groupAllowFrom: ["@admin:example.org"],
169
- groups: {
170
- "!roomid:example.org": { requireMention: true },
171
- },
172
-
173
- autoJoin: "allowlist",
174
- autoJoinAllowlist: ["!roomid:example.org"],
175
- threadReplies: "inbound",
176
- replyToMode: "off",
177
- streaming: "partial",
178
- },
179
- },
180
- }
181
- ```
182
-
183
- ## Streaming previews
184
-
185
- Matrix reply streaming is opt-in. `streaming` controls how FengMing delivers the in-flight assistant reply; `blockStreaming` controls whether each completed block is preserved as its own Matrix message.
186
-
187
- ```json5
188
- {
189
- channels: {
190
- matrix: {
191
- streaming: "partial",
192
- },
193
- },
194
- }
195
- ```
196
-
197
- To keep live answer previews but hide interim tool/progress lines, use object
198
- form:
199
-
200
- ```json5
201
- {
202
- channels: {
203
- matrix: {
204
- streaming: {
205
- mode: "partial",
206
- preview: {
207
- toolProgress: false,
208
- },
209
- },
210
- },
211
- },
212
- }
213
- ```
214
-
215
- | `streaming` | Behavior |
216
- | ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
217
- | `"off"` (default) | Wait for the full reply, send once. `true` ↔ `"partial"`, `false` ↔ `"off"`. |
218
- | `"partial"` | Edit one normal text message in place as the model writes the current block. Stock Matrix clients may notify on the first preview, not the final edit. |
219
- | `"quiet"` | Same as `"partial"` but the message is a non-notifying notice. Recipients only get a notification once a per-user push rule matches the finalized edit (see below). |
220
-
221
- `blockStreaming` is independent of `streaming`:
222
-
223
- | `streaming` | `blockStreaming: true` | `blockStreaming: false` (default) |
224
- | ----------------------- | ------------------------------------------------------------------- | ---------------------------------------------------- |
225
- | `"partial"` / `"quiet"` | Live draft for the current block, completed blocks kept as messages | Live draft for the current block, finalized in place |
226
- | `"off"` | One notifying Matrix message per finished block | One notifying Matrix message for the full reply |
227
-
228
- Notes:
229
-
230
- - If a preview grows past Matrix's per-event size limit, FengMing stops preview streaming and falls back to final-only delivery.
231
- - Media replies always send attachments normally. If a stale preview can no longer be reused safely, FengMing redacts it before sending the final media reply.
232
- - Tool-progress preview updates are enabled by default when Matrix preview streaming is active. Set `streaming.preview.toolProgress: false` to keep preview edits for answer text but leave tool progress on the normal delivery path.
233
- - Preview edits cost extra Matrix API calls. Leave `streaming: "off"` if you want the most conservative rate-limit profile.
234
-
235
- ## Approval metadata
236
-
237
- Matrix native approval prompts are normal `m.room.message` events with FengMing-specific custom event content under `com.fengming.approval`. Matrix permits custom event-content keys, so stock clients still render the text body while FengMing-aware clients can read the structured approval id, kind, state, available decisions, and exec/plugin details.
238
-
239
- When an approval prompt is too long for one Matrix event, FengMing chunks the visible text and attaches `com.fengming.approval` to the first chunk only. Reactions for allow/deny decisions are bound to that first event, so long prompts keep the same approval target as single-event prompts.
240
-
241
- ### Self-hosted push rules for quiet finalized previews
242
-
243
- `streaming: "quiet"` only notifies recipients once a block or turn is finalized - a per-user push rule has to match the finalized preview marker. See [Matrix push rules for quiet previews](/channels/matrix-push-rules) for the full recipe (recipient token, pusher check, rule install, per-homeserver notes).
244
-
245
- ## Bot-to-bot rooms
246
-
247
- By default, Matrix messages from other configured FengMing Matrix accounts are ignored.
248
-
249
- Use `allowBots` when you intentionally want inter-agent Matrix traffic:
250
-
251
- ```json5
252
- {
253
- channels: {
254
- matrix: {
255
- allowBots: "mentions", // true | "mentions"
256
- groups: {
257
- "!roomid:example.org": {
258
- requireMention: true,
259
- },
260
- },
261
- },
262
- },
263
- }
264
- ```
265
-
266
- - `allowBots: true` accepts messages from other configured Matrix bot accounts in allowed rooms and DMs.
267
- - `allowBots: "mentions"` accepts those messages only when they visibly mention this bot in rooms. DMs are still allowed.
268
- - `groups.<room>.allowBots` overrides the account-level setting for one room.
269
- - Accepted configured-bot messages use shared [bot loop protection](/channels/bot-loop-protection). Configure `channels.defaults.botLoopProtection`, then override with `channels.matrix.botLoopProtection` or `channels.matrix.groups.<room>.botLoopProtection` when one room needs a different budget.
270
- - FengMing still ignores messages from the same Matrix user ID to avoid self-reply loops.
271
- - Matrix does not expose a native bot flag here; FengMing treats "bot-authored" as "sent by another configured Matrix account on this FengMing gateway".
272
-
273
- Use strict room allowlists and mention requirements when enabling bot-to-bot traffic in shared rooms.
274
-
275
- ## Encryption and verification
276
-
277
- In encrypted (E2EE) rooms, outbound image events use `thumbnail_file` so image previews are encrypted alongside the full attachment. Unencrypted rooms still use plain `thumbnail_url`. No configuration is needed - the plugin detects E2EE state automatically.
278
-
279
- All `fengming matrix` commands accept `--verbose` (full diagnostics), `--json` (machine-readable output), and `--account <id>` (multi-account setups). Output is concise by default with quiet internal SDK logging. The examples below show the canonical form; add the flags as needed.
280
-
281
- ### Enable encryption
282
-
283
- ```bash
284
- fengming matrix encryption setup
285
- ```
286
-
287
- Bootstraps secret storage and cross-signing, creates a room-key backup if needed, then prints status and next steps. Useful flags:
288
-
289
- - `--recovery-key <key>` apply a recovery key before bootstrapping (prefer the stdin form documented below)
290
- - `--force-reset-cross-signing` discard the current cross-signing identity and create a new one (use only intentionally)
291
-
292
- For a new account, enable E2EE at creation time:
293
-
294
- ```bash
295
- fengming matrix account add \
296
- --homeserver https://matrix.example.org \
297
- --access-token syt_xxx \
298
- --enable-e2ee
299
- ```
300
-
301
- `--encryption` is an alias for `--enable-e2ee`.
302
-
303
- Manual config equivalent:
304
-
305
- ```json5
306
- {
307
- channels: {
308
- matrix: {
309
- enabled: true,
310
- homeserver: "https://matrix.example.org",
311
- accessToken: "syt_xxx",
312
- encryption: true,
313
- dm: { policy: "pairing" },
314
- },
315
- },
316
- }
317
- ```
318
-
319
- ### Status and trust signals
320
-
321
- ```bash
322
- fengming matrix verify status
323
- fengming matrix verify status --include-recovery-key --json
324
- ```
325
-
326
- `verify status` reports three independent trust signals (`--verbose` shows all of them):
327
-
328
- - `Locally trusted`: trusted by this client only
329
- - `Cross-signing verified`: the SDK reports verification via cross-signing
330
- - `Signed by owner`: signed by your own self-signing key (diagnostic only)
331
-
332
- `Verified by owner` becomes `yes` only when `Cross-signing verified` is `yes`. Local trust or an owner signature alone is not enough.
333
-
334
- `--allow-degraded-local-state` returns best-effort diagnostics without preparing the Matrix account first; useful for offline or partially-configured probes.
335
-
336
- ### Verify this device with a recovery key
337
-
338
- The recovery key is sensitive - pipe it via stdin instead of passing it on the command line. Set `MATRIX_RECOVERY_KEY` (or `MATRIX_<ID>_RECOVERY_KEY` for a named account):
339
-
340
- ```bash
341
- printf '%s\n' "$MATRIX_RECOVERY_KEY" | fengming matrix verify device --recovery-key-stdin
342
- ```
343
-
344
- The command reports three states:
345
-
346
- - `Recovery key accepted`: Matrix accepted the key for secret storage or device trust.
347
- - `Backup usable`: room-key backup can be loaded with the trusted recovery material.
348
- - `Device verified by owner`: this device has full Matrix cross-signing identity trust.
349
-
350
- It exits non-zero when full identity trust is incomplete, even if the recovery key unlocked backup material. In that case, finish self-verification from another Matrix client:
351
-
352
- ```bash
353
- fengming matrix verify self
354
- ```
355
-
356
- `verify self` waits for `Cross-signing verified: yes` before it exits successfully. Use `--timeout-ms <ms>` to tune the wait.
357
-
358
- The literal-key form `fengming matrix verify device "<recovery-key>"` is also accepted, but the key ends up in your shell history.
359
-
360
- ### Bootstrap or repair cross-signing
361
-
362
- ```bash
363
- fengming matrix verify bootstrap
364
- ```
365
-
366
- `verify bootstrap` is the repair and setup command for encrypted accounts. In order, it:
367
-
368
- - bootstraps secret storage, reusing an existing recovery key when possible
369
- - bootstraps cross-signing and uploads missing public keys
370
- - marks and cross-signs the current device
371
- - creates a server-side room-key backup if one does not already exist
372
-
373
- If the homeserver requires UIA to upload cross-signing keys, FengMing tries no-auth first, then `m.login.dummy`, then `m.login.password` (requires `channels.matrix.password`).
374
-
375
- Useful flags:
376
-
377
- - `--recovery-key-stdin` (pair with `printf '%s\n' "$MATRIX_RECOVERY_KEY" | …`) or `--recovery-key <key>`
378
- - `--force-reset-cross-signing` to discard the current cross-signing identity (intentional only)
379
-
380
- ### Room-key backup
381
-
382
- ```bash
383
- fengming matrix verify backup status
384
- printf '%s\n' "$MATRIX_RECOVERY_KEY" | fengming matrix verify backup restore --recovery-key-stdin
385
- ```
386
-
387
- `backup status` shows whether a server-side backup exists and whether this device can decrypt it. `backup restore` imports backed-up room keys into the local crypto store; if the recovery key is already on disk you can omit `--recovery-key-stdin`.
388
-
389
- To replace a broken backup with a fresh baseline (accepts losing unrecoverable old history; can also recreate secret storage if the current backup secret is unloadable):
390
-
391
- ```bash
392
- fengming matrix verify backup reset --yes
393
- ```
394
-
395
- Add `--rotate-recovery-key` only when you intentionally want the previous recovery key to stop unlocking the fresh backup baseline.
396
-
397
- ### Listing, requesting, and responding to verifications
398
-
399
- ```bash
400
- fengming matrix verify list
401
- ```
402
-
403
- Lists pending verification requests for the selected account.
404
-
405
- ```bash
406
- fengming matrix verify request --own-user
407
- fengming matrix verify request --user-id @ops:example.org --device-id ABCDEF
408
- ```
409
-
410
- Sends a verification request from this FengMing account. `--own-user` requests self-verification (you accept the prompt in another Matrix client of the same user); `--user-id`/`--device-id`/`--room-id` target someone else. `--own-user` cannot be combined with the other targeting flags.
411
-
412
- For lower-level lifecycle handling - typically while shadowing inbound requests from another client - these commands act on a specific request `<id>` (printed by `verify list` and `verify request`):
413
-
414
- | Command | Purpose |
415
- | ------------------------------------------ | ------------------------------------------------------------------- |
416
- | `fengming matrix verify accept <id>` | Accept an inbound request |
417
- | `fengming matrix verify start <id>` | Start the SAS flow |
418
- | `fengming matrix verify sas <id>` | Print the SAS emoji or decimals |
419
- | `fengming matrix verify confirm-sas <id>` | Confirm that the SAS matches what the other client shows |
420
- | `fengming matrix verify mismatch-sas <id>` | Reject the SAS when the emoji or decimals do not match |
421
- | `fengming matrix verify cancel <id>` | Cancel; takes optional `--reason <text>` and `--code <matrix-code>` |
422
-
423
- `accept`, `start`, `sas`, `confirm-sas`, `mismatch-sas`, and `cancel` all accept `--user-id` and `--room-id` as DM follow-up hints when the verification is anchored to a specific direct-message room.
424
-
425
- ### Multi-account notes
426
-
427
- Without `--account <id>`, Matrix CLI commands use the implicit default account. If you have multiple named accounts and have not set `channels.matrix.defaultAccount`, they will refuse to guess and ask you to choose. When E2EE is disabled or unavailable for a named account, errors point at that account's config key, for example `channels.matrix.accounts.assistant.encryption`.
428
-
429
- <AccordionGroup>
430
- <Accordion title="Startup behavior">
431
- With `encryption: true`, `startupVerification` defaults to `"if-unverified"`. On startup an unverified device requests self-verification in another Matrix client, skipping duplicates and applying a cooldown (24 hours by default). Tune with `startupVerificationCooldownHours` or disable with `startupVerification: "off"`.
432
-
433
- Startup also runs a conservative crypto bootstrap pass that reuses the current secret storage and cross-signing identity. If bootstrap state is broken, FengMing attempts a guarded repair even without `channels.matrix.password`; if the homeserver requires password UIA, startup logs a warning and stays non-fatal. Already-owner-signed devices are preserved.
434
-
435
- See [Matrix migration](/channels/matrix-migration) for the full upgrade flow.
436
-
437
- </Accordion>
438
-
439
- <Accordion title="Verification notices">
440
- Matrix posts verification lifecycle notices into the strict DM verification room as `m.notice` messages: request, ready (with "Verify by emoji" guidance), start/completion, and SAS (emoji/decimal) details when available.
441
-
442
- Incoming requests from another Matrix client are tracked and auto-accepted. For self-verification, FengMing starts the SAS flow automatically and confirms its own side once emoji verification is available - you still need to compare and confirm "They match" in your Matrix client.
443
-
444
- Verification system notices are not forwarded to the agent chat pipeline.
445
-
446
- </Accordion>
447
-
448
- <Accordion title="Deleted or invalid Matrix device">
449
- If `verify status` says the current device is no longer listed on the homeserver, create a new FengMing Matrix device. For password login:
450
-
451
- ```bash
452
- fengming matrix account add \
453
- --account assistant \
454
- --homeserver https://matrix.example.org \
455
- --user-id '@assistant:example.org' \
456
- --password '<password>' \
457
- --device-name FengMing-Gateway
458
- ```
459
-
460
- For token auth, create a fresh access token in your Matrix client or admin UI, then update FengMing:
461
-
462
- ```bash
463
- fengming matrix account add \
464
- --account assistant \
465
- --homeserver https://matrix.example.org \
466
- --access-token '<token>'
467
- ```
468
-
469
- Replace `assistant` with the account ID from the failed command, or omit `--account` for the default account.
470
-
471
- </Accordion>
472
-
473
- <Accordion title="Device hygiene">
474
- Old FengMing-managed devices can accumulate. List and prune:
475
-
476
- ```bash
477
- fengming matrix devices list
478
- fengming matrix devices prune-stale
479
- ```
480
-
481
- </Accordion>
482
-
483
- <Accordion title="Crypto store">
484
- Matrix E2EE uses the official `matrix-js-sdk` Rust crypto path with `fake-indexeddb` as the IndexedDB shim. Crypto state persists to `crypto-idb-snapshot.json` (restrictive file permissions).
485
-
486
- Encrypted runtime state lives under `~/.fengming/matrix/accounts/<account>/<homeserver>__<user>/<token-hash>/` and includes the sync store, crypto store, recovery key, IDB snapshot, thread bindings, and startup verification state. When the token changes but the account identity stays the same, FengMing reuses the best existing root so prior state remains visible.
487
-
488
- </Accordion>
489
- </AccordionGroup>
490
-
491
- ## Profile management
492
-
493
- Update the Matrix self-profile for the selected account:
494
-
495
- ```bash
496
- fengming matrix profile set --name "FengMing Assistant"
497
- fengming matrix profile set --avatar-url https://cdn.example.org/avatar.png
498
- ```
499
-
500
- You can pass both options in one call. Matrix accepts `mxc://` avatar URLs directly; when you pass `http://` or `https://`, FengMing uploads the file first and stores the resolved `mxc://` URL into `channels.matrix.avatarUrl` (or the per-account override).
501
-
502
- ## Threads
503
-
504
- Matrix supports native Matrix threads for both automatic replies and message-tool sends. Two independent knobs control behavior:
505
-
506
- ### Session routing (`sessionScope`)
507
-
508
- `dm.sessionScope` decides how Matrix DM rooms map to FengMing sessions:
509
-
510
- - `"per-user"` (default): all DM rooms with the same routed peer share one session.
511
- - `"per-room"`: each Matrix DM room gets its own session key, even when the peer is the same.
512
-
513
- Explicit conversation bindings always win over `sessionScope`, so bound rooms and threads keep their chosen target session.
514
-
515
- ### Reply threading (`threadReplies`)
516
-
517
- `threadReplies` decides where the bot posts its reply:
518
-
519
- - `"off"`: replies are top-level. Inbound threaded messages stay on the parent session.
520
- - `"inbound"`: reply inside a thread only when the inbound message was already in that thread.
521
- - `"always"`: reply inside a thread rooted at the triggering message; that conversation is routed through a matching thread-scoped session from the first trigger onward.
522
-
523
- `dm.threadReplies` overrides this for DMs only - for example, keep room threads isolated while keeping DMs flat.
524
-
525
- ### Thread inheritance and slash commands
526
-
527
- - Inbound threaded messages include the thread root message as extra agent context.
528
- - Message-tool sends auto-inherit the current Matrix thread when targeting the same room (or the same DM user target), unless an explicit `threadId` is provided.
529
- - DM user-target reuse only kicks in when the current session metadata proves the same DM peer on the same Matrix account; otherwise FengMing falls back to normal user-scoped routing.
530
- - `/focus`, `/unfocus`, `/agents`, `/session idle`, `/session max-age`, and thread-bound `/acp spawn` all work in Matrix rooms and DMs.
531
- - Top-level `/focus` creates a new Matrix thread and binds it to the target session when `threadBindings.spawnSessions` is enabled.
532
- - Running `/focus` or `/acp spawn --thread here` inside an existing Matrix thread binds that thread in place.
533
-
534
- When FengMing detects a Matrix DM room colliding with another DM room on the same shared session, it posts a one-time `m.notice` in that room pointing to the `/focus` escape hatch and suggesting a `dm.sessionScope` change. The notice only appears when thread bindings are enabled.
535
-
536
- ## ACP conversation bindings
537
-
538
- Matrix rooms, DMs, and existing Matrix threads can be turned into durable ACP workspaces without changing the chat surface.
539
-
540
- Fast operator flow:
541
-
542
- - Run `/acp spawn codex --bind here` inside the Matrix DM, room, or existing thread you want to keep using.
543
- - In a top-level Matrix DM or room, the current DM/room stays the chat surface and future messages route to the spawned ACP session.
544
- - Inside an existing Matrix thread, `--bind here` binds that current thread in place.
545
- - `/new` and `/reset` reset the same bound ACP session in place.
546
- - `/acp close` closes the ACP session and removes the binding.
547
-
548
- Notes:
549
-
550
- - `--bind here` does not create a child Matrix thread.
551
- - `threadBindings.spawnSessions` gates `/acp spawn --thread auto|here`, where FengMing needs to create or bind a child Matrix thread.
552
-
553
- ### Thread binding config
554
-
555
- Matrix inherits global defaults from `session.threadBindings`, and also supports per-channel overrides:
556
-
557
- - `threadBindings.enabled`
558
- - `threadBindings.idleHours`
559
- - `threadBindings.maxAgeHours`
560
- - `threadBindings.spawnSessions`
561
- - `threadBindings.defaultSpawnContext`
562
-
563
- Matrix thread-bound session spawns default on:
564
-
565
- - Set `threadBindings.spawnSessions: false` to block top-level `/focus` and `/acp spawn --thread auto|here` from creating/binding Matrix threads.
566
- - Set `threadBindings.defaultSpawnContext: "isolated"` when native subagent thread spawns should not fork the parent transcript.
567
-
568
- ## Reactions
569
-
570
- Matrix supports outbound reactions, inbound reaction notifications, and ack reactions.
571
-
572
- Outbound reaction tooling is gated by `channels.matrix.actions.reactions`:
573
-
574
- - `react` adds a reaction to a Matrix event.
575
- - `reactions` lists the current reaction summary for a Matrix event.
576
- - `emoji=""` removes the bot's own reactions on that event.
577
- - `remove: true` removes only the specified emoji reaction from the bot.
578
-
579
- **Resolution order** (first defined value wins):
580
-
581
- | Setting | Order |
582
- | ----------------------- | -------------------------------------------------------------------------------- |
583
- | `ackReaction` | per-account → channel → `messages.ackReaction` → agent identity emoji fallback |
584
- | `ackReactionScope` | per-account → channel → `messages.ackReactionScope` → default `"group-mentions"` |
585
- | `reactionNotifications` | per-account → channel → default `"own"` |
586
-
587
- `reactionNotifications: "own"` forwards added `m.reaction` events when they target bot-authored Matrix messages; `"off"` disables reaction system events. Reaction removals are not synthesized into system events because Matrix surfaces those as redactions, not as standalone `m.reaction` removals.
588
-
589
- ## History context
590
-
591
- - `channels.matrix.historyLimit` controls how many recent room messages are included as `InboundHistory` when a Matrix room message triggers the agent. Falls back to `messages.groupChat.historyLimit`; if both are unset, the effective default is `0`. Set `0` to disable.
592
- - Matrix room history is room-only. DMs keep using normal session history.
593
- - Matrix room history is pending-only: FengMing buffers room messages that did not trigger a reply yet, then snapshots that window when a mention or other trigger arrives.
594
- - The current trigger message is not included in `InboundHistory`; it stays in the main inbound body for that turn.
595
- - Retries of the same Matrix event reuse the original history snapshot instead of drifting forward to newer room messages.
596
-
597
- ## Context visibility
598
-
599
- Matrix supports the shared `contextVisibility` control for supplemental room context such as fetched reply text, thread roots, and pending history.
600
-
601
- - `contextVisibility: "all"` is the default. Supplemental context is kept as received.
602
- - `contextVisibility: "allowlist"` filters supplemental context to senders allowed by the active room/user allowlist checks.
603
- - `contextVisibility: "allowlist_quote"` behaves like `allowlist`, but still keeps one explicit quoted reply.
604
-
605
- This setting affects supplemental context visibility, not whether the inbound message itself can trigger a reply.
606
- Trigger authorization still comes from `groupPolicy`, `groups`, `groupAllowFrom`, and DM policy settings.
607
-
608
- ## DM and room policy
609
-
610
- ```json5
611
- {
612
- channels: {
613
- matrix: {
614
- dm: {
615
- policy: "allowlist",
616
- allowFrom: ["@admin:example.org"],
617
- threadReplies: "off",
618
- },
619
- groupPolicy: "allowlist",
620
- groupAllowFrom: ["@admin:example.org"],
621
- groups: {
622
- "!roomid:example.org": { requireMention: true },
623
- },
624
- },
625
- },
626
- }
627
- ```
628
-
629
- To silence DMs entirely while keeping rooms working, set `dm.enabled: false`:
630
-
631
- ```json5
632
- {
633
- channels: {
634
- matrix: {
635
- dm: { enabled: false },
636
- groupPolicy: "allowlist",
637
- groupAllowFrom: ["@admin:example.org"],
638
- },
639
- },
640
- }
641
- ```
642
-
643
- See [Groups](/channels/groups) for mention-gating and allowlist behavior.
644
-
645
- Pairing example for Matrix DMs:
646
-
647
- ```bash
648
- fengming pairing list matrix
649
- fengming pairing approve matrix <CODE>
650
- ```
651
-
652
- If an unapproved Matrix user keeps messaging you before approval, FengMing reuses the same pending pairing code and may send a reminder reply after a short cooldown instead of minting a new code.
653
-
654
- See [Pairing](/channels/pairing) for the shared DM pairing flow and storage layout.
655
-
656
- ## Direct room repair
657
-
658
- If direct-message state drifts out of sync, FengMing can end up with stale `m.direct` mappings that point at old solo rooms instead of the live DM. Inspect the current mapping for a peer:
659
-
660
- ```bash
661
- fengming matrix direct inspect --user-id @alice:example.org
662
- ```
663
-
664
- Repair it:
665
-
666
- ```bash
667
- fengming matrix direct repair --user-id @alice:example.org
668
- ```
669
-
670
- Both commands accept `--account <id>` for multi-account setups. The repair flow:
671
-
672
- - prefers a strict 1:1 DM that is already mapped in `m.direct`
673
- - falls back to any currently joined strict 1:1 DM with that user
674
- - creates a fresh direct room and rewrites `m.direct` if no healthy DM exists
675
-
676
- It does not delete old rooms automatically. It picks the healthy DM and updates the mapping so future Matrix sends, verification notices, and other direct-message flows target the right room.
677
-
678
- ## Exec approvals
679
-
680
- Matrix can act as a native approval client. Configure under `channels.matrix.execApprovals` (or `channels.matrix.accounts.<account>.execApprovals` for a per-account override):
681
-
682
- - `enabled`: deliver approvals through Matrix-native prompts. When unset or `"auto"`, Matrix auto-enables once at least one approver can be resolved. Set `false` to disable explicitly.
683
- - `approvers`: Matrix user IDs (`@owner:example.org`) allowed to approve exec requests. Optional - falls back to `channels.matrix.dm.allowFrom`.
684
- - `target`: where prompts go. `"dm"` (default) sends to approver DMs; `"channel"` sends to the originating Matrix room or DM; `"both"` sends to both.
685
- - `agentFilter` / `sessionFilter`: optional allowlists for which agents/sessions trigger Matrix delivery.
686
-
687
- Authorization differs slightly between approval kinds:
688
-
689
- - **Exec approvals** use `execApprovals.approvers`, falling back to `dm.allowFrom`.
690
- - **Plugin approvals** authorize through `dm.allowFrom` only.
691
-
692
- Both kinds share Matrix reaction shortcuts and message updates. Approvers see reaction shortcuts on the primary approval message:
693
-
694
- - `✅` allow once
695
- - `❌` deny
696
- - `♾️` allow always (when the effective exec policy allows it)
697
-
698
- Fallback slash commands: `/approve <id> allow-once`, `/approve <id> allow-always`, `/approve <id> deny`.
699
-
700
- Only resolved approvers can approve or deny. Channel delivery for exec approvals includes the command text - only enable `channel` or `both` in trusted rooms.
701
-
702
- Related: [Exec approvals](/tools/exec-approvals).
703
-
704
- ## Slash commands
705
-
706
- Slash commands (`/new`, `/reset`, `/model`, `/focus`, `/unfocus`, `/agents`, `/session`, `/acp`, `/approve`, etc.) work directly in DMs. In rooms, FengMing also recognizes commands that are prefixed with the bot's own Matrix mention, so `@bot:server /new` triggers the command path without a custom mention regex. This keeps the bot responsive to the room-style `@mention /command` posts that Element and similar clients emit when a user tab-completes the bot before typing the command.
707
-
708
- Authorization rules still apply: command senders must satisfy the same DM or room allowlist/owner policies as plain messages.
709
-
710
- ## Multi-account
711
-
712
- ```json5
713
- {
714
- channels: {
715
- matrix: {
716
- enabled: true,
717
- defaultAccount: "assistant",
718
- dm: { policy: "pairing" },
719
- accounts: {
720
- assistant: {
721
- homeserver: "https://matrix.example.org",
722
- accessToken: "syt_assistant_xxx",
723
- encryption: true,
724
- },
725
- alerts: {
726
- homeserver: "https://matrix.example.org",
727
- accessToken: "syt_alerts_xxx",
728
- dm: {
729
- policy: "allowlist",
730
- allowFrom: ["@ops:example.org"],
731
- threadReplies: "off",
732
- },
733
- },
734
- },
735
- },
736
- },
737
- }
738
- ```
739
-
740
- **Inheritance:**
741
-
742
- - Top-level `channels.matrix` values act as defaults for named accounts unless an account overrides them.
743
- - Scope an inherited room entry to a specific account with `groups.<room>.account`. Entries without `account` are shared across accounts; `account: "default"` still works when the default account is configured at the top level.
744
-
745
- **Default account selection:**
746
-
747
- - Set `defaultAccount` to pick the named account that implicit routing, probing, and CLI commands prefer.
748
- - If you have multiple accounts and one is literally named `default`, FengMing uses it implicitly even when `defaultAccount` is unset.
749
- - If you have multiple named accounts and no default is selected, CLI commands refuse to guess - set `defaultAccount` or pass `--account <id>`.
750
- - The top-level `channels.matrix.*` block is only treated as the implicit `default` account when its auth is complete (`homeserver` + `accessToken`, or `homeserver` + `userId` + `password`). Named accounts remain discoverable from `homeserver` + `userId` once cached credentials cover auth.
751
-
752
- **Promotion:**
753
-
754
- - When FengMing promotes a single-account config to multi-account during repair or setup, it preserves the existing named account if one exists or `defaultAccount` already points at one. Only Matrix auth/bootstrap keys move into the promoted account; shared delivery-policy keys stay at the top level.
755
-
756
- See [Configuration reference](/gateway/config-channels#multi-account-all-channels) for the shared multi-account pattern.
757
-
758
- ## Private/LAN homeservers
759
-
760
- By default, FengMing blocks private/internal Matrix homeservers for SSRF protection unless you
761
- explicitly opt in per account.
762
-
763
- If your homeserver runs on localhost, a LAN/Tailscale IP, or an internal hostname, enable
764
- `network.dangerouslyAllowPrivateNetwork` for that Matrix account:
765
-
766
- ```json5
767
- {
768
- channels: {
769
- matrix: {
770
- homeserver: "http://matrix-synapse:8008",
771
- network: {
772
- dangerouslyAllowPrivateNetwork: true,
773
- },
774
- accessToken: "syt_internal_xxx",
775
- },
776
- },
777
- }
778
- ```
779
-
780
- CLI setup example:
781
-
782
- ```bash
783
- fengming matrix account add \
784
- --account ops \
785
- --homeserver http://matrix-synapse:8008 \
786
- --allow-private-network \
787
- --access-token syt_ops_xxx
788
- ```
789
-
790
- This opt-in only allows trusted private/internal targets. Public cleartext homeservers such as
791
- `http://matrix.example.org:8008` remain blocked. Prefer `https://` whenever possible.
792
-
793
- ## Proxying Matrix traffic
794
-
795
- If your Matrix deployment needs an explicit outbound HTTP(S) proxy, set `channels.matrix.proxy`:
796
-
797
- ```json5
798
- {
799
- channels: {
800
- matrix: {
801
- homeserver: "https://matrix.example.org",
802
- accessToken: "syt_bot_xxx",
803
- proxy: "http://127.0.0.1:7890",
804
- },
805
- },
806
- }
807
- ```
808
-
809
- Named accounts can override the top-level default with `channels.matrix.accounts.<id>.proxy`.
810
- FengMing uses the same proxy setting for runtime Matrix traffic and account status probes.
811
-
812
- ## Target resolution
813
-
814
- Matrix accepts these target forms anywhere FengMing asks you for a room or user target:
815
-
816
- - Users: `@user:server`, `user:@user:server`, or `matrix:user:@user:server`
817
- - Rooms: `!room:server`, `room:!room:server`, or `matrix:room:!room:server`
818
- - Aliases: `#alias:server`, `channel:#alias:server`, or `matrix:channel:#alias:server`
819
-
820
- Matrix room IDs are case-sensitive. Use the exact room ID casing from Matrix
821
- when configuring explicit delivery targets, cron jobs, bindings, or allowlists.
822
- FengMing keeps internal session keys canonical for storage, so those lowercase
823
- keys are not a reliable source for Matrix delivery IDs.
824
-
825
- Live directory lookup uses the logged-in Matrix account:
826
-
827
- - User lookups query the Matrix user directory on that homeserver.
828
- - Room lookups accept explicit room IDs and aliases directly. Joined-room name lookup is best-effort and only applies to runtime room allowlists when `dangerouslyAllowNameMatching: true` is set.
829
- - If a room name cannot be resolved to an ID or alias, it is ignored by runtime allowlist resolution.
830
-
831
- ## Configuration reference
832
-
833
- Allowlist-style user fields (`groupAllowFrom`, `dm.allowFrom`, `groups.<room>.users`) accept full Matrix user IDs (safest). Non-ID user entries are ignored by default. If you set `dangerouslyAllowNameMatching: true`, exact Matrix directory display-name matches are resolved at startup and whenever the allowlist changes while the monitor is running; entries that cannot be resolved are ignored at runtime.
834
-
835
- Room allowlist keys (`groups`, legacy `rooms`) should be room IDs or aliases. Plain room-name keys are ignored by default; `dangerouslyAllowNameMatching: true` restores best-effort lookup against joined room names.
836
-
837
- ### Account and connection
838
-
839
- - `enabled`: enable or disable the channel.
840
- - `name`: optional display label for the account.
841
- - `defaultAccount`: preferred account ID when multiple Matrix accounts are configured.
842
- - `accounts`: named per-account overrides. Top-level `channels.matrix` values are inherited as defaults.
843
- - `homeserver`: homeserver URL, for example `https://matrix.example.org`.
844
- - `network.dangerouslyAllowPrivateNetwork`: allow this account to connect to `localhost`, LAN/Tailscale IPs, or internal hostnames.
845
- - `proxy`: optional HTTP(S) proxy URL for Matrix traffic. Per-account override supported.
846
- - `userId`: full Matrix user ID (`@bot:example.org`).
847
- - `accessToken`: access token for token-based auth. Plaintext and SecretRef values supported across env/file/exec providers ([Secrets Management](/gateway/secrets)).
848
- - `password`: password for password-based login. Plaintext and SecretRef values supported.
849
- - `deviceId`: explicit Matrix device ID.
850
- - `deviceName`: device display name used at password-login time.
851
- - `avatarUrl`: stored self-avatar URL for profile sync and `profile set` updates.
852
- - `initialSyncLimit`: maximum number of events fetched during startup sync.
853
-
854
- ### Encryption
855
-
856
- - `encryption`: enable E2EE. Default: `false`.
857
- - `startupVerification`: `"if-unverified"` (default when E2EE is on) or `"off"`. Auto-requests self-verification on startup when this device is unverified.
858
- - `startupVerificationCooldownHours`: cooldown before the next automatic startup request. Default: `24`.
859
-
860
- ### Access and policy
861
-
862
- - `groupPolicy`: `"open"`, `"allowlist"`, or `"disabled"`. Default: `"allowlist"`.
863
- - `groupAllowFrom`: allowlist of user IDs for room traffic.
864
- - `dm.enabled`: when `false`, ignore all DMs. Default: `true`.
865
- - `dm.policy`: `"pairing"` (default), `"allowlist"`, `"open"`, or `"disabled"`. Applies after the bot has joined and classified the room as a DM; it does not affect invite handling.
866
- - `dm.allowFrom`: allowlist of user IDs for DM traffic.
867
- - `dm.sessionScope`: `"per-user"` (default) or `"per-room"`.
868
- - `dm.threadReplies`: DM-only override for reply threading (`"off"`, `"inbound"`, `"always"`).
869
- - `allowBots`: accept messages from other configured Matrix bot accounts (`true` or `"mentions"`).
870
- - `allowlistOnly`: when `true`, forces all active DM policies (except `"disabled"`) and `"open"` group policies to `"allowlist"`. Does not change `"disabled"` policies.
871
- - `dangerouslyAllowNameMatching`: when `true`, allows Matrix display-name directory lookup for user allowlist entries and joined-room name lookup for room allowlist keys. Prefer full `@user:server` IDs and room IDs or aliases.
872
- - `autoJoin`: `"always"`, `"allowlist"`, or `"off"`. Default: `"off"`. Applies to every Matrix invite, including DM-style invites.
873
- - `autoJoinAllowlist`: rooms/aliases allowed when `autoJoin` is `"allowlist"`. Alias entries are resolved against the homeserver, not against state claimed by the invited room.
874
- - `contextVisibility`: supplemental context visibility (`"all"` default, `"allowlist"`, `"allowlist_quote"`).
875
-
876
- ### Reply behavior
877
-
878
- - `replyToMode`: `"off"`, `"first"`, `"all"`, or `"batched"`.
879
- - `threadReplies`: `"off"`, `"inbound"`, or `"always"`.
880
- - `threadBindings`: per-channel overrides for thread-bound session routing and lifecycle.
881
- - `streaming`: `"off"` (default), `"partial"`, `"quiet"`, or object form `{ mode, preview: { toolProgress } }`. `true` ↔ `"partial"`, `false` ↔ `"off"`.
882
- - `blockStreaming`: when `true`, completed assistant blocks are kept as separate progress messages.
883
- - `markdown`: optional Markdown rendering config for outbound text.
884
- - `responsePrefix`: optional string prepended to outbound replies.
885
- - `textChunkLimit`: outbound chunk size in characters when `chunkMode: "length"`. Default: `4000`.
886
- - `chunkMode`: `"length"` (default, splits by character count) or `"newline"` (splits at line boundaries).
887
- - `historyLimit`: number of recent room messages included as `InboundHistory` when a room message triggers the agent. Falls back to `messages.groupChat.historyLimit`; effective default `0` (disabled).
888
- - `mediaMaxMb`: media size cap in MB for outbound sends and inbound processing.
889
-
890
- ### Reaction settings
891
-
892
- - `ackReaction`: ack reaction override for this channel/account.
893
- - `ackReactionScope`: scope override (`"group-mentions"` default, `"group-all"`, `"direct"`, `"all"`, `"none"`, `"off"`).
894
- - `reactionNotifications`: inbound reaction notification mode (`"own"` default, `"off"`).
895
-
896
- ### Tooling and per-room overrides
897
-
898
- - `actions`: per-action tool gating (`messages`, `reactions`, `pins`, `profile`, `memberInfo`, `channelInfo`, `verification`).
899
- - `groups`: per-room policy map. Session identity uses the stable room ID after resolution. (`rooms` is a legacy alias.)
900
- - `groups.<room>.account`: restrict one inherited room entry to a specific account.
901
- - `groups.<room>.allowBots`: per-room override of the channel-level setting (`true` or `"mentions"`).
902
- - `groups.<room>.users`: per-room sender allowlist.
903
- - `groups.<room>.tools`: per-room tool allow/deny overrides.
904
- - `groups.<room>.autoReply`: per-room mention-gating override. `true` disables mention requirements for that room; `false` forces them back on.
905
- - `groups.<room>.skills`: per-room skill filter.
906
- - `groups.<room>.systemPrompt`: per-room system prompt snippet.
907
-
908
- ### Exec approval settings
909
-
910
- - `execApprovals.enabled`: deliver exec approvals through Matrix-native prompts.
911
- - `execApprovals.approvers`: Matrix user IDs allowed to approve. Falls back to `dm.allowFrom`.
912
- - `execApprovals.target`: `"dm"` (default), `"channel"`, or `"both"`.
913
- - `execApprovals.agentFilter` / `execApprovals.sessionFilter`: optional agent/session allowlists for delivery.
914
-
915
- ## Related
916
-
917
- - [Channels Overview](/channels) - all supported channels
918
- - [Pairing](/channels/pairing) - DM authentication and pairing flow
919
- - [Groups](/channels/groups) - group chat behavior and mention gating
920
- - [Channel Routing](/channels/channel-routing) - session routing for messages
921
- - [Security](/gateway/security) - access model and hardening