fengming 0.3.9 → 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 (763) hide show
  1. package/dist/build-info.json +2 -2
  2. package/dist/{bundled-channel-config-schema-DpdKMATU.d.ts → bundled-channel-config-schema-Bte--ZlY.d.ts} +26 -26
  3. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  4. package/dist/cli-startup-metadata.json +8 -8
  5. package/dist/control-ui/assets/{activity-B2W-IeAT.js → activity-wgT0-JR0.js} +2 -2
  6. package/dist/control-ui/assets/{agents-mRUyNVCz.js → agents-DG5PobrT.js} +2 -2
  7. package/dist/control-ui/assets/{channels-8QHOqBnt.js → channels-CX28oM42.js} +2 -2
  8. package/dist/control-ui/assets/{cron-H3unP_mO.js → cron-B8ixwBqU.js} +2 -2
  9. package/dist/control-ui/assets/{debug-CxLsQ9vH.js → debug-CnkYZUXy.js} +2 -2
  10. package/dist/control-ui/assets/{index-jtIYT0Eh.js → index-DQRZJKbO.js} +4 -4
  11. package/dist/control-ui/assets/{instances-B1JQeCRb.js → instances-BE3mV1JC.js} +2 -2
  12. package/dist/control-ui/assets/{nodes-RGOmq_1l.js → nodes-Cou4PWRX.js} +2 -2
  13. package/dist/control-ui/assets/{sessions-C2O-Jgpg.js → sessions-DpAaBT21.js} +2 -2
  14. package/dist/control-ui/assets/{skills-jyJOYA4I.js → skills-DjA_j_20.js} +2 -2
  15. package/dist/control-ui/assets/{workboard-uM_kK8cQ.js → workboard-BFnvbS0k.js} +2 -2
  16. package/dist/control-ui/index.html +1 -1
  17. package/dist/control-ui/sw.js +1 -1
  18. package/dist/gateway/protocol/index.d.ts +1 -1
  19. package/dist/{index-DhOQs6M_.d.ts → index-DuDY3bCZ.d.ts} +45 -45
  20. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  21. package/dist/plugin-sdk/agent-config-primitives.d.ts +1 -1
  22. package/dist/plugin-sdk/{bundled-channel-config-schema-Dfn3b8sF.d.ts → bundled-channel-config-schema-BPFNnbwu.d.ts} +23 -23
  23. package/dist/plugin-sdk/bundled-channel-config-schema.d.ts +3 -3
  24. package/dist/plugin-sdk/channel-config-primitives.d.ts +2 -2
  25. package/dist/plugin-sdk/channel-config-schema-legacy.d.ts +3 -3
  26. package/dist/plugin-sdk/channel-config-schema.d.ts +2 -2
  27. package/dist/plugin-sdk/channel-core.d.ts +1 -1
  28. package/dist/plugin-sdk/channel-plugin-common.d.ts +1 -1
  29. package/dist/plugin-sdk/compat.d.ts +2 -2
  30. package/dist/plugin-sdk/{config-schema-DUddICQM.d.ts → config-schema-D7cABQ6o.d.ts} +1 -1
  31. package/dist/plugin-sdk/config-schema.d.ts +4 -4
  32. package/dist/plugin-sdk/core.d.ts +1 -1
  33. package/dist/plugin-sdk/discord.d.ts +2 -2
  34. package/dist/plugin-sdk/tts-runtime.d.ts +1 -1
  35. package/dist/plugin-sdk/{zod-schema.core-B4_b2R5K.d.ts → zod-schema.core-CwBNqcXp.d.ts} +1 -1
  36. package/dist/{zod-schema.core-Cuz0lz6m.d.ts → zod-schema.core-BGLctDlK.d.ts} +1 -1
  37. package/package.json +7 -412
  38. package/CHANGELOG.md +0 -38
  39. package/THIRD_PARTY_NOTICES.md +0 -37
  40. package/docs/.i18n/README.md +0 -81
  41. package/docs/.i18n/ar-navigation.json +0 -18
  42. package/docs/.i18n/de-navigation.json +0 -18
  43. package/docs/.i18n/es-navigation.json +0 -18
  44. package/docs/.i18n/fr-navigation.json +0 -18
  45. package/docs/.i18n/glossary.ar.json +0 -78
  46. package/docs/.i18n/glossary.de.json +0 -78
  47. package/docs/.i18n/glossary.es.json +0 -78
  48. package/docs/.i18n/glossary.fa.json +0 -78
  49. package/docs/.i18n/glossary.fr.json +0 -78
  50. package/docs/.i18n/glossary.id.json +0 -78
  51. package/docs/.i18n/glossary.it.json +0 -78
  52. package/docs/.i18n/glossary.ja-JP.json +0 -98
  53. package/docs/.i18n/glossary.ko.json +0 -78
  54. package/docs/.i18n/glossary.nl.json +0 -78
  55. package/docs/.i18n/glossary.pl.json +0 -78
  56. package/docs/.i18n/glossary.pt-BR.json +0 -78
  57. package/docs/.i18n/glossary.th.json +0 -78
  58. package/docs/.i18n/glossary.tr.json +0 -78
  59. package/docs/.i18n/glossary.uk.json +0 -78
  60. package/docs/.i18n/glossary.vi.json +0 -78
  61. package/docs/.i18n/glossary.zh-CN.json +0 -1122
  62. package/docs/.i18n/glossary.zh-TW.json +0 -78
  63. package/docs/.i18n/id-navigation.json +0 -18
  64. package/docs/.i18n/it-navigation.json +0 -18
  65. package/docs/.i18n/ja-navigation.json +0 -18
  66. package/docs/.i18n/ko-navigation.json +0 -18
  67. package/docs/.i18n/pl-navigation.json +0 -18
  68. package/docs/.i18n/pt-BR-navigation.json +0 -18
  69. package/docs/.i18n/tr-navigation.json +0 -18
  70. package/docs/.i18n/translation-workflow.md +0 -111
  71. package/docs/.i18n/zh-Hans-navigation.json +0 -552
  72. package/docs/AGENTS.md +0 -36
  73. package/docs/CLAUDE.md +0 -1
  74. package/docs/agent-runtime-architecture.md +0 -48
  75. package/docs/announcements/bluebubbles-imessage.md +0 -79
  76. package/docs/auth-credential-semantics.md +0 -124
  77. package/docs/automation/auth-monitoring.md +0 -11
  78. package/docs/automation/clawflow.md +0 -12
  79. package/docs/automation/cron-jobs.md +0 -534
  80. package/docs/automation/cron-vs-heartbeat.md +0 -11
  81. package/docs/automation/gmail-pubsub.md +0 -11
  82. package/docs/automation/hooks.md +0 -387
  83. package/docs/automation/index.md +0 -135
  84. package/docs/automation/poll.md +0 -12
  85. package/docs/automation/standing-orders.md +0 -250
  86. package/docs/automation/taskflow.md +0 -155
  87. package/docs/automation/tasks.md +0 -374
  88. package/docs/automation/troubleshooting.md +0 -12
  89. package/docs/automation/webhook.md +0 -12
  90. package/docs/brave-search.md +0 -11
  91. package/docs/channels/access-groups.md +0 -201
  92. package/docs/channels/ambient-room-events.md +0 -214
  93. package/docs/channels/bot-loop-protection.md +0 -131
  94. package/docs/channels/broadcast-groups.md +0 -472
  95. package/docs/channels/channel-routing.md +0 -162
  96. package/docs/channels/clickclack.md +0 -138
  97. package/docs/channels/discord.md +0 -1758
  98. package/docs/channels/feishu.md +0 -650
  99. package/docs/channels/googlechat.md +0 -284
  100. package/docs/channels/group-messages.md +0 -95
  101. package/docs/channels/groups.md +0 -524
  102. package/docs/channels/imessage-from-bluebubbles.md +0 -259
  103. package/docs/channels/imessage.md +0 -839
  104. package/docs/channels/index.md +0 -64
  105. package/docs/channels/irc.md +0 -253
  106. package/docs/channels/line.md +0 -243
  107. package/docs/channels/location.md +0 -71
  108. package/docs/channels/matrix-migration.md +0 -370
  109. package/docs/channels/matrix-presentation.md +0 -77
  110. package/docs/channels/matrix-push-rules.md +0 -150
  111. package/docs/channels/matrix.md +0 -921
  112. package/docs/channels/mattermost.md +0 -542
  113. package/docs/channels/msteams.md +0 -1096
  114. package/docs/channels/nextcloud-talk.md +0 -176
  115. package/docs/channels/nostr.md +0 -253
  116. package/docs/channels/pairing.md +0 -214
  117. package/docs/channels/qqbot.md +0 -314
  118. package/docs/channels/signal.md +0 -417
  119. package/docs/channels/slack.md +0 -1623
  120. package/docs/channels/synology-chat.md +0 -187
  121. package/docs/channels/telegram.md +0 -1124
  122. package/docs/channels/tlon.md +0 -296
  123. package/docs/channels/troubleshooting.md +0 -162
  124. package/docs/channels/twitch.md +0 -431
  125. package/docs/channels/wechat.md +0 -171
  126. package/docs/channels/whatsapp.md +0 -796
  127. package/docs/channels/yuanbao.md +0 -416
  128. package/docs/channels/zalo.md +0 -253
  129. package/docs/channels/zalouser.md +0 -217
  130. package/docs/ci.md +0 -657
  131. package/docs/clawhub/publishing.md +0 -96
  132. package/docs/cli/acp.md +0 -370
  133. package/docs/cli/agent.md +0 -109
  134. package/docs/cli/agents.md +0 -253
  135. package/docs/cli/approvals.md +0 -190
  136. package/docs/cli/backup.md +0 -98
  137. package/docs/cli/browser.md +0 -307
  138. package/docs/cli/channels.md +0 -154
  139. package/docs/cli/clawbot.md +0 -25
  140. package/docs/cli/commitments.md +0 -90
  141. package/docs/cli/completion.md +0 -39
  142. package/docs/cli/config.md +0 -504
  143. package/docs/cli/configure.md +0 -77
  144. package/docs/cli/crestodian.md +0 -337
  145. package/docs/cli/cron.md +0 -304
  146. package/docs/cli/daemon.md +0 -67
  147. package/docs/cli/dashboard.md +0 -33
  148. package/docs/cli/devices.md +0 -240
  149. package/docs/cli/directory.md +0 -68
  150. package/docs/cli/dns.md +0 -53
  151. package/docs/cli/docs.md +0 -63
  152. package/docs/cli/doctor.md +0 -241
  153. package/docs/cli/flows.md +0 -52
  154. package/docs/cli/gateway.md +0 -572
  155. package/docs/cli/health.md +0 -43
  156. package/docs/cli/hooks.md +0 -345
  157. package/docs/cli/index.md +0 -400
  158. package/docs/cli/infer.md +0 -364
  159. package/docs/cli/logs.md +0 -68
  160. package/docs/cli/mcp.md +0 -529
  161. package/docs/cli/memory.md +0 -183
  162. package/docs/cli/message.md +0 -317
  163. package/docs/cli/migrate.md +0 -334
  164. package/docs/cli/models.md +0 -239
  165. package/docs/cli/node.md +0 -177
  166. package/docs/cli/nodes.md +0 -76
  167. package/docs/cli/onboard.md +0 -250
  168. package/docs/cli/pairing.md +0 -77
  169. package/docs/cli/path.md +0 -511
  170. package/docs/cli/plugins.md +0 -459
  171. package/docs/cli/policy.md +0 -886
  172. package/docs/cli/proxy.md +0 -89
  173. package/docs/cli/qr.md +0 -56
  174. package/docs/cli/reset.md +0 -39
  175. package/docs/cli/sandbox.md +0 -208
  176. package/docs/cli/secrets.md +0 -202
  177. package/docs/cli/security.md +0 -136
  178. package/docs/cli/sessions.md +0 -164
  179. package/docs/cli/setup.md +0 -59
  180. package/docs/cli/skills.md +0 -122
  181. package/docs/cli/status.md +0 -45
  182. package/docs/cli/system.md +0 -89
  183. package/docs/cli/tasks.md +0 -111
  184. package/docs/cli/transcripts.md +0 -151
  185. package/docs/cli/tui.md +0 -91
  186. package/docs/cli/uninstall.md +0 -44
  187. package/docs/cli/update.md +0 -243
  188. package/docs/cli/voicecall.md +0 -204
  189. package/docs/cli/webhooks.md +0 -117
  190. package/docs/cli/wiki.md +0 -256
  191. package/docs/concepts/active-memory.md +0 -856
  192. package/docs/concepts/agent-loop.md +0 -185
  193. package/docs/concepts/agent-runtimes.md +0 -276
  194. package/docs/concepts/agent-workspace.md +0 -230
  195. package/docs/concepts/agent.md +0 -140
  196. package/docs/concepts/architecture.md +0 -154
  197. package/docs/concepts/channel-docking.md +0 -145
  198. package/docs/concepts/commitments.md +0 -150
  199. package/docs/concepts/compaction.md +0 -203
  200. package/docs/concepts/context-engine.md +0 -347
  201. package/docs/concepts/context.md +0 -199
  202. package/docs/concepts/delegate-architecture.md +0 -319
  203. package/docs/concepts/dreaming.md +0 -264
  204. package/docs/concepts/experimental-features.md +0 -109
  205. package/docs/concepts/features.md +0 -91
  206. package/docs/concepts/fengming-sdk.md +0 -323
  207. package/docs/concepts/mantis-slack-desktop-runbook.md +0 -231
  208. package/docs/concepts/mantis.md +0 -744
  209. package/docs/concepts/markdown-formatting.md +0 -139
  210. package/docs/concepts/memory-builtin.md +0 -148
  211. package/docs/concepts/memory-honcho.md +0 -144
  212. package/docs/concepts/memory-qmd.md +0 -271
  213. package/docs/concepts/memory-search.md +0 -167
  214. package/docs/concepts/memory.md +0 -299
  215. package/docs/concepts/message-lifecycle-refactor.md +0 -1126
  216. package/docs/concepts/messages.md +0 -214
  217. package/docs/concepts/model-failover.md +0 -384
  218. package/docs/concepts/model-providers.md +0 -719
  219. package/docs/concepts/models.md +0 -371
  220. package/docs/concepts/multi-agent.md +0 -625
  221. package/docs/concepts/oauth.md +0 -198
  222. package/docs/concepts/parallel-specialist-lanes.md +0 -127
  223. package/docs/concepts/personal-agent-benchmark-pack.md +0 -74
  224. package/docs/concepts/presence.md +0 -117
  225. package/docs/concepts/progress-drafts.md +0 -406
  226. package/docs/concepts/qa-e2e-automation.md +0 -947
  227. package/docs/concepts/qa-matrix.md +0 -139
  228. package/docs/concepts/queue-steering.md +0 -90
  229. package/docs/concepts/queue.md +0 -136
  230. package/docs/concepts/retry.md +0 -86
  231. package/docs/concepts/session-pruning.md +0 -104
  232. package/docs/concepts/session-tool.md +0 -188
  233. package/docs/concepts/session.md +0 -164
  234. package/docs/concepts/soul.md +0 -116
  235. package/docs/concepts/streaming.md +0 -257
  236. package/docs/concepts/system-prompt.md +0 -328
  237. package/docs/concepts/timezone.md +0 -47
  238. package/docs/concepts/typebox.md +0 -309
  239. package/docs/concepts/typing-indicators.md +0 -88
  240. package/docs/concepts/usage-tracking.md +0 -66
  241. package/docs/date-time.md +0 -126
  242. package/docs/debug/node-issue.md +0 -90
  243. package/docs/diagnostics/flags.md +0 -182
  244. package/docs/docs.json +0 -1862
  245. package/docs/fengming-agent-runtime.md +0 -82
  246. package/docs/gateway/authentication.md +0 -256
  247. package/docs/gateway/background-process.md +0 -147
  248. package/docs/gateway/bonjour.md +0 -303
  249. package/docs/gateway/bridge-protocol.md +0 -97
  250. package/docs/gateway/cli-backends.md +0 -439
  251. package/docs/gateway/config-agents.md +0 -1525
  252. package/docs/gateway/config-channels.md +0 -945
  253. package/docs/gateway/config-tools.md +0 -774
  254. package/docs/gateway/configuration-examples.md +0 -704
  255. package/docs/gateway/configuration-reference.md +0 -1391
  256. package/docs/gateway/configuration.md +0 -739
  257. package/docs/gateway/diagnostics.md +0 -213
  258. package/docs/gateway/discovery.md +0 -154
  259. package/docs/gateway/doctor.md +0 -575
  260. package/docs/gateway/gateway-lock.md +0 -37
  261. package/docs/gateway/health.md +0 -73
  262. package/docs/gateway/heartbeat.md +0 -498
  263. package/docs/gateway/index.md +0 -383
  264. package/docs/gateway/local-model-services.md +0 -205
  265. package/docs/gateway/local-models.md +0 -355
  266. package/docs/gateway/logging.md +0 -149
  267. package/docs/gateway/multiple-gateways.md +0 -178
  268. package/docs/gateway/network-model.md +0 -15
  269. package/docs/gateway/openai-http-api.md +0 -378
  270. package/docs/gateway/openresponses-http-api.md +0 -347
  271. package/docs/gateway/openshell.md +0 -316
  272. package/docs/gateway/opentelemetry.md +0 -433
  273. package/docs/gateway/operator-scopes.md +0 -119
  274. package/docs/gateway/pairing.md +0 -207
  275. package/docs/gateway/prometheus.md +0 -249
  276. package/docs/gateway/protocol.md +0 -826
  277. package/docs/gateway/remote-gateway-readme.md +0 -169
  278. package/docs/gateway/remote.md +0 -280
  279. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -148
  280. package/docs/gateway/sandboxing.md +0 -546
  281. package/docs/gateway/secrets-plan-contract.md +0 -159
  282. package/docs/gateway/secrets.md +0 -805
  283. package/docs/gateway/security/audit-checks.md +0 -127
  284. package/docs/gateway/security/exposure-runbook.md +0 -212
  285. package/docs/gateway/security/index.md +0 -1343
  286. package/docs/gateway/security/secure-file-operations.md +0 -76
  287. package/docs/gateway/security/shrinkwrap.md +0 -111
  288. package/docs/gateway/tailscale.md +0 -156
  289. package/docs/gateway/tools-invoke-http-api.md +0 -169
  290. package/docs/gateway/troubleshooting.md +0 -877
  291. package/docs/gateway/trusted-proxy-auth.md +0 -483
  292. package/docs/help/debugging.md +0 -341
  293. package/docs/help/environment.md +0 -233
  294. package/docs/help/faq-first-run.md +0 -870
  295. package/docs/help/faq-models.md +0 -556
  296. package/docs/help/faq.md +0 -2041
  297. package/docs/help/index.md +0 -39
  298. package/docs/help/scripts.md +0 -56
  299. package/docs/help/testing-live.md +0 -587
  300. package/docs/help/testing-updates-plugins.md +0 -299
  301. package/docs/help/testing.md +0 -977
  302. package/docs/help/troubleshooting.md +0 -449
  303. package/docs/index.md +0 -196
  304. package/docs/install/ansible.md +0 -233
  305. package/docs/install/azure.md +0 -315
  306. package/docs/install/bun.md +0 -59
  307. package/docs/install/clawdock.md +0 -112
  308. package/docs/install/development-channels.md +0 -148
  309. package/docs/install/digitalocean.md +0 -174
  310. package/docs/install/docker-vm-runtime.md +0 -154
  311. package/docs/install/docker.md +0 -564
  312. package/docs/install/exe-dev.md +0 -201
  313. package/docs/install/fly.md +0 -524
  314. package/docs/install/gcp.md +0 -418
  315. package/docs/install/hetzner.md +0 -285
  316. package/docs/install/hostinger.md +0 -98
  317. package/docs/install/index.md +0 -232
  318. package/docs/install/installer.md +0 -447
  319. package/docs/install/kubernetes.md +0 -196
  320. package/docs/install/macos-vm.md +0 -281
  321. package/docs/install/migrating-claude.md +0 -165
  322. package/docs/install/migrating-hermes.md +0 -178
  323. package/docs/install/migrating.md +0 -137
  324. package/docs/install/nix.md +0 -112
  325. package/docs/install/node.md +0 -142
  326. package/docs/install/northflank.mdx +0 -44
  327. package/docs/install/oracle.md +0 -218
  328. package/docs/install/podman.md +0 -216
  329. package/docs/install/railway.mdx +0 -92
  330. package/docs/install/raspberry-pi.md +0 -234
  331. package/docs/install/render.mdx +0 -167
  332. package/docs/install/uninstall.md +0 -131
  333. package/docs/install/updating.md +0 -284
  334. package/docs/install/upstash.md +0 -96
  335. package/docs/logging.md +0 -320
  336. package/docs/nav-tabs-underline.js +0 -100
  337. package/docs/network.md +0 -72
  338. package/docs/nodes/audio.md +0 -216
  339. package/docs/nodes/camera.md +0 -166
  340. package/docs/nodes/images.md +0 -77
  341. package/docs/nodes/index.md +0 -439
  342. package/docs/nodes/location-command.md +0 -102
  343. package/docs/nodes/media-understanding.md +0 -495
  344. package/docs/nodes/talk.md +0 -160
  345. package/docs/nodes/troubleshooting.md +0 -123
  346. package/docs/nodes/voicewake.md +0 -93
  347. package/docs/perplexity.md +0 -11
  348. package/docs/plan/codex-context-engine-harness.md +0 -624
  349. package/docs/plan/ui-channels.md +0 -284
  350. package/docs/platforms/digitalocean.md +0 -12
  351. package/docs/platforms/easyrunner.md +0 -109
  352. package/docs/platforms/index.md +0 -51
  353. package/docs/platforms/linux.md +0 -141
  354. package/docs/platforms/mac/bundled-gateway.md +0 -79
  355. package/docs/platforms/mac/canvas.md +0 -128
  356. package/docs/platforms/mac/child-process.md +0 -72
  357. package/docs/platforms/mac/dev-setup.md +0 -112
  358. package/docs/platforms/mac/health.md +0 -39
  359. package/docs/platforms/mac/icon.md +0 -36
  360. package/docs/platforms/mac/logging.md +0 -62
  361. package/docs/platforms/mac/menu-bar.md +0 -93
  362. package/docs/platforms/mac/peekaboo.md +0 -96
  363. package/docs/platforms/mac/permissions.md +0 -73
  364. package/docs/platforms/mac/remote.md +0 -123
  365. package/docs/platforms/mac/signing.md +0 -52
  366. package/docs/platforms/mac/skills.md +0 -43
  367. package/docs/platforms/mac/voice-overlay.md +0 -66
  368. package/docs/platforms/mac/voicewake.md +0 -73
  369. package/docs/platforms/mac/webchat.md +0 -54
  370. package/docs/platforms/mac/xpc.md +0 -66
  371. package/docs/platforms/oracle.md +0 -12
  372. package/docs/platforms/raspberry-pi.md +0 -13
  373. package/docs/platforms/windows.md +0 -286
  374. package/docs/plugins/adding-capabilities.md +0 -146
  375. package/docs/plugins/admin-http-rpc.md +0 -216
  376. package/docs/plugins/agent-tools.md +0 -13
  377. package/docs/plugins/architecture-internals.md +0 -1196
  378. package/docs/plugins/architecture.md +0 -483
  379. package/docs/plugins/building-extensions.md +0 -13
  380. package/docs/plugins/building-plugins.md +0 -335
  381. package/docs/plugins/bundles.md +0 -310
  382. package/docs/plugins/cli-backend-plugins.md +0 -310
  383. package/docs/plugins/codex-computer-use.md +0 -297
  384. package/docs/plugins/codex-harness-reference.md +0 -470
  385. package/docs/plugins/codex-harness-runtime.md +0 -268
  386. package/docs/plugins/codex-harness.md +0 -780
  387. package/docs/plugins/codex-native-plugins.md +0 -276
  388. package/docs/plugins/community.md +0 -77
  389. package/docs/plugins/compatibility.md +0 -167
  390. package/docs/plugins/copilot.md +0 -356
  391. package/docs/plugins/dependency-resolution.md +0 -176
  392. package/docs/plugins/google-meet.md +0 -1737
  393. package/docs/plugins/hooks.md +0 -484
  394. package/docs/plugins/install-overrides.md +0 -80
  395. package/docs/plugins/manage-plugins.md +0 -210
  396. package/docs/plugins/manifest.md +0 -1457
  397. package/docs/plugins/memory-lancedb.md +0 -385
  398. package/docs/plugins/memory-wiki.md +0 -529
  399. package/docs/plugins/message-presentation.md +0 -473
  400. package/docs/plugins/oc-path.md +0 -166
  401. package/docs/plugins/plugin-inventory.md +0 -189
  402. package/docs/plugins/plugin-permission-requests.md +0 -193
  403. package/docs/plugins/reference/acpx.md +0 -23
  404. package/docs/plugins/reference/admin-http-rpc.md +0 -23
  405. package/docs/plugins/reference/alibaba.md +0 -23
  406. package/docs/plugins/reference/amazon-bedrock-mantle.md +0 -23
  407. package/docs/plugins/reference/amazon-bedrock.md +0 -23
  408. package/docs/plugins/reference/anthropic-vertex.md +0 -19
  409. package/docs/plugins/reference/anthropic.md +0 -23
  410. package/docs/plugins/reference/arcee.md +0 -23
  411. package/docs/plugins/reference/azure-speech.md +0 -23
  412. package/docs/plugins/reference/bonjour.md +0 -19
  413. package/docs/plugins/reference/brave.md +0 -23
  414. package/docs/plugins/reference/browser.md +0 -23
  415. package/docs/plugins/reference/byteplus.md +0 -19
  416. package/docs/plugins/reference/canvas.md +0 -19
  417. package/docs/plugins/reference/cerebras.md +0 -23
  418. package/docs/plugins/reference/chutes.md +0 -23
  419. package/docs/plugins/reference/clickclack.md +0 -23
  420. package/docs/plugins/reference/cloudflare-ai-gateway.md +0 -23
  421. package/docs/plugins/reference/codex-supervisor.md +0 -27
  422. package/docs/plugins/reference/codex.md +0 -23
  423. package/docs/plugins/reference/comfy.md +0 -23
  424. package/docs/plugins/reference/copilot-proxy.md +0 -19
  425. package/docs/plugins/reference/copilot.md +0 -23
  426. package/docs/plugins/reference/deepgram.md +0 -23
  427. package/docs/plugins/reference/deepinfra.md +0 -23
  428. package/docs/plugins/reference/deepseek.md +0 -23
  429. package/docs/plugins/reference/diagnostics-otel.md +0 -19
  430. package/docs/plugins/reference/diagnostics-prometheus.md +0 -19
  431. package/docs/plugins/reference/diffs-language-pack.md +0 -19
  432. package/docs/plugins/reference/diffs.md +0 -19
  433. package/docs/plugins/reference/discord.md +0 -23
  434. package/docs/plugins/reference/document-extract.md +0 -23
  435. package/docs/plugins/reference/duckduckgo.md +0 -23
  436. package/docs/plugins/reference/elevenlabs.md +0 -23
  437. package/docs/plugins/reference/exa.md +0 -23
  438. package/docs/plugins/reference/fal.md +0 -23
  439. package/docs/plugins/reference/feishu.md +0 -23
  440. package/docs/plugins/reference/file-transfer.md +0 -19
  441. package/docs/plugins/reference/firecrawl.md +0 -23
  442. package/docs/plugins/reference/fireworks.md +0 -23
  443. package/docs/plugins/reference/github-copilot.md +0 -23
  444. package/docs/plugins/reference/gmi.md +0 -23
  445. package/docs/plugins/reference/google-meet.md +0 -23
  446. package/docs/plugins/reference/google.md +0 -23
  447. package/docs/plugins/reference/googlechat.md +0 -23
  448. package/docs/plugins/reference/gradium.md +0 -23
  449. package/docs/plugins/reference/groq.md +0 -23
  450. package/docs/plugins/reference/huggingface.md +0 -23
  451. package/docs/plugins/reference/imessage.md +0 -23
  452. package/docs/plugins/reference/inworld.md +0 -23
  453. package/docs/plugins/reference/irc.md +0 -23
  454. package/docs/plugins/reference/kilocode.md +0 -23
  455. package/docs/plugins/reference/kimi.md +0 -23
  456. package/docs/plugins/reference/line.md +0 -23
  457. package/docs/plugins/reference/litellm.md +0 -23
  458. package/docs/plugins/reference/llm-task.md +0 -19
  459. package/docs/plugins/reference/lmstudio.md +0 -23
  460. package/docs/plugins/reference/lobster.md +0 -19
  461. package/docs/plugins/reference/matrix.md +0 -23
  462. package/docs/plugins/reference/mattermost.md +0 -23
  463. package/docs/plugins/reference/memory-core.md +0 -19
  464. package/docs/plugins/reference/memory-lancedb.md +0 -23
  465. package/docs/plugins/reference/memory-wiki.md +0 -23
  466. package/docs/plugins/reference/microsoft-foundry.md +0 -19
  467. package/docs/plugins/reference/microsoft.md +0 -19
  468. package/docs/plugins/reference/migrate-claude.md +0 -19
  469. package/docs/plugins/reference/migrate-hermes.md +0 -19
  470. package/docs/plugins/reference/minimax.md +0 -23
  471. package/docs/plugins/reference/mistral.md +0 -23
  472. package/docs/plugins/reference/moonshot.md +0 -23
  473. package/docs/plugins/reference/msteams.md +0 -23
  474. package/docs/plugins/reference/nextcloud-talk.md +0 -23
  475. package/docs/plugins/reference/nostr.md +0 -23
  476. package/docs/plugins/reference/novita.md +0 -23
  477. package/docs/plugins/reference/nvidia.md +0 -23
  478. package/docs/plugins/reference/oc-path.md +0 -23
  479. package/docs/plugins/reference/ollama.md +0 -23
  480. package/docs/plugins/reference/open-prose.md +0 -19
  481. package/docs/plugins/reference/openai.md +0 -23
  482. package/docs/plugins/reference/opencode-go.md +0 -23
  483. package/docs/plugins/reference/opencode.md +0 -23
  484. package/docs/plugins/reference/openrouter.md +0 -23
  485. package/docs/plugins/reference/openshell.md +0 -19
  486. package/docs/plugins/reference/perplexity.md +0 -23
  487. package/docs/plugins/reference/pixverse.md +0 -23
  488. package/docs/plugins/reference/policy.md +0 -72
  489. package/docs/plugins/reference/qa-channel.md +0 -23
  490. package/docs/plugins/reference/qa-lab.md +0 -19
  491. package/docs/plugins/reference/qa-matrix.md +0 -19
  492. package/docs/plugins/reference/qianfan.md +0 -23
  493. package/docs/plugins/reference/qqbot.md +0 -23
  494. package/docs/plugins/reference/qwen.md +0 -23
  495. package/docs/plugins/reference/runway.md +0 -23
  496. package/docs/plugins/reference/searxng.md +0 -19
  497. package/docs/plugins/reference/senseaudio.md +0 -23
  498. package/docs/plugins/reference/sglang.md +0 -23
  499. package/docs/plugins/reference/signal.md +0 -23
  500. package/docs/plugins/reference/skill-workshop.md +0 -23
  501. package/docs/plugins/reference/slack.md +0 -23
  502. package/docs/plugins/reference/stepfun.md +0 -23
  503. package/docs/plugins/reference/synology-chat.md +0 -23
  504. package/docs/plugins/reference/synthetic.md +0 -23
  505. package/docs/plugins/reference/tavily.md +0 -23
  506. package/docs/plugins/reference/telegram.md +0 -23
  507. package/docs/plugins/reference/tencent.md +0 -23
  508. package/docs/plugins/reference/tlon.md +0 -23
  509. package/docs/plugins/reference/together.md +0 -23
  510. package/docs/plugins/reference/tokenjuice.md +0 -23
  511. package/docs/plugins/reference/tts-local-cli.md +0 -19
  512. package/docs/plugins/reference/twitch.md +0 -23
  513. package/docs/plugins/reference/venice.md +0 -23
  514. package/docs/plugins/reference/vercel-ai-gateway.md +0 -23
  515. package/docs/plugins/reference/vllm.md +0 -23
  516. package/docs/plugins/reference/voice-call.md +0 -23
  517. package/docs/plugins/reference/volcengine.md +0 -23
  518. package/docs/plugins/reference/voyage.md +0 -19
  519. package/docs/plugins/reference/vydra.md +0 -23
  520. package/docs/plugins/reference/web-readability.md +0 -19
  521. package/docs/plugins/reference/webhooks.md +0 -23
  522. package/docs/plugins/reference/whatsapp.md +0 -23
  523. package/docs/plugins/reference/workboard.md +0 -23
  524. package/docs/plugins/reference/xai.md +0 -23
  525. package/docs/plugins/reference/xiaomi.md +0 -23
  526. package/docs/plugins/reference/zai.md +0 -23
  527. package/docs/plugins/reference/zalo.md +0 -23
  528. package/docs/plugins/reference/zalouser.md +0 -24
  529. package/docs/plugins/reference.md +0 -145
  530. package/docs/plugins/sdk-agent-harness.md +0 -338
  531. package/docs/plugins/sdk-channel-inbound.md +0 -70
  532. package/docs/plugins/sdk-channel-ingress.md +0 -137
  533. package/docs/plugins/sdk-channel-message.md +0 -18
  534. package/docs/plugins/sdk-channel-outbound.md +0 -113
  535. package/docs/plugins/sdk-channel-plugins.md +0 -765
  536. package/docs/plugins/sdk-channel-turn.md +0 -9
  537. package/docs/plugins/sdk-entrypoints.md +0 -344
  538. package/docs/plugins/sdk-migration.md +0 -979
  539. package/docs/plugins/sdk-overview.md +0 -511
  540. package/docs/plugins/sdk-provider-plugins.md +0 -846
  541. package/docs/plugins/sdk-runtime.md +0 -676
  542. package/docs/plugins/sdk-setup.md +0 -550
  543. package/docs/plugins/sdk-subpaths.md +0 -391
  544. package/docs/plugins/sdk-testing.md +0 -403
  545. package/docs/plugins/skill-workshop.md +0 -713
  546. package/docs/plugins/tool-plugins.md +0 -411
  547. package/docs/plugins/voice-call.md +0 -942
  548. package/docs/plugins/webhooks.md +0 -192
  549. package/docs/plugins/workboard.md +0 -252
  550. package/docs/plugins/zalouser.md +0 -86
  551. package/docs/prose.md +0 -137
  552. package/docs/providers/alibaba.md +0 -158
  553. package/docs/providers/anthropic.md +0 -381
  554. package/docs/providers/arcee.md +0 -144
  555. package/docs/providers/azure-speech.md +0 -119
  556. package/docs/providers/bedrock-mantle.md +0 -211
  557. package/docs/providers/bedrock.md +0 -414
  558. package/docs/providers/cerebras.md +0 -130
  559. package/docs/providers/chutes.md +0 -153
  560. package/docs/providers/claude-max-api-proxy.md +0 -191
  561. package/docs/providers/cloudflare-ai-gateway.md +0 -119
  562. package/docs/providers/comfy.md +0 -362
  563. package/docs/providers/deepgram.md +0 -184
  564. package/docs/providers/deepinfra.md +0 -92
  565. package/docs/providers/deepseek.md +0 -146
  566. package/docs/providers/ds4.md +0 -309
  567. package/docs/providers/elevenlabs.md +0 -130
  568. package/docs/providers/fal.md +0 -240
  569. package/docs/providers/fireworks.md +0 -144
  570. package/docs/providers/github-copilot.md +0 -257
  571. package/docs/providers/gmi.md +0 -92
  572. package/docs/providers/google.md +0 -472
  573. package/docs/providers/gradium.md +0 -123
  574. package/docs/providers/groq.md +0 -171
  575. package/docs/providers/huggingface.md +0 -235
  576. package/docs/providers/index.md +0 -105
  577. package/docs/providers/inferrs.md +0 -272
  578. package/docs/providers/inworld.md +0 -120
  579. package/docs/providers/kilocode.md +0 -135
  580. package/docs/providers/litellm.md +0 -234
  581. package/docs/providers/lmstudio.md +0 -224
  582. package/docs/providers/minimax.md +0 -505
  583. package/docs/providers/mistral.md +0 -235
  584. package/docs/providers/models.md +0 -64
  585. package/docs/providers/moonshot.md +0 -413
  586. package/docs/providers/novita.md +0 -92
  587. package/docs/providers/nvidia.md +0 -158
  588. package/docs/providers/ollama-cloud.md +0 -115
  589. package/docs/providers/ollama.md +0 -1225
  590. package/docs/providers/openai.md +0 -1093
  591. package/docs/providers/opencode-go.md +0 -123
  592. package/docs/providers/opencode.md +0 -149
  593. package/docs/providers/openrouter.md +0 -349
  594. package/docs/providers/perplexity-provider.md +0 -123
  595. package/docs/providers/pixverse.md +0 -165
  596. package/docs/providers/qianfan.md +0 -132
  597. package/docs/providers/qwen-oauth.md +0 -115
  598. package/docs/providers/qwen.md +0 -364
  599. package/docs/providers/runway.md +0 -103
  600. package/docs/providers/senseaudio.md +0 -68
  601. package/docs/providers/sglang.md +0 -161
  602. package/docs/providers/stepfun.md +0 -229
  603. package/docs/providers/synthetic.md +0 -154
  604. package/docs/providers/tencent.md +0 -130
  605. package/docs/providers/together.md +0 -140
  606. package/docs/providers/venice.md +0 -312
  607. package/docs/providers/vercel-ai-gateway.md +0 -128
  608. package/docs/providers/vllm.md +0 -407
  609. package/docs/providers/volcengine.md +0 -199
  610. package/docs/providers/vydra.md +0 -180
  611. package/docs/providers/xai.md +0 -571
  612. package/docs/providers/xiaomi.md +0 -262
  613. package/docs/providers/zai.md +0 -224
  614. package/docs/refactor/access.md +0 -9
  615. package/docs/refactor/acp.md +0 -298
  616. package/docs/refactor/canvas.md +0 -131
  617. package/docs/refactor/database-first.md +0 -2256
  618. package/docs/refactor/ingress-core.md +0 -341
  619. package/docs/reference/AGENTS.default.md +0 -131
  620. package/docs/reference/RELEASING.md +0 -799
  621. package/docs/reference/api-usage-costs.md +0 -208
  622. package/docs/reference/application-modernization-plan.md +0 -208
  623. package/docs/reference/code-mode.md +0 -773
  624. package/docs/reference/credits.md +0 -33
  625. package/docs/reference/device-models.md +0 -50
  626. package/docs/reference/fengming-sdk-api-design.md +0 -390
  627. package/docs/reference/full-release-validation.md +0 -202
  628. package/docs/reference/memory-config.md +0 -604
  629. package/docs/reference/prompt-caching.md +0 -358
  630. package/docs/reference/release-performance-sweep.md +0 -360
  631. package/docs/reference/rich-output-protocol.md +0 -101
  632. package/docs/reference/rpc.md +0 -43
  633. package/docs/reference/secret-placeholder-conventions.md +0 -33
  634. package/docs/reference/secretref-credential-surface.md +0 -159
  635. package/docs/reference/secretref-user-supplied-credentials-matrix.json +0 -663
  636. package/docs/reference/session-management-compaction.md +0 -474
  637. package/docs/reference/templates/AGENTS.dev.md +0 -90
  638. package/docs/reference/templates/AGENTS.md +0 -227
  639. package/docs/reference/templates/BOOT.md +0 -16
  640. package/docs/reference/templates/BOOTSTRAP.md +0 -66
  641. package/docs/reference/templates/CLAUDE.md +0 -1
  642. package/docs/reference/templates/HEARTBEAT.md +0 -24
  643. package/docs/reference/templates/IDENTITY.dev.md +0 -52
  644. package/docs/reference/templates/IDENTITY.md +0 -34
  645. package/docs/reference/templates/SOUL.dev.md +0 -82
  646. package/docs/reference/templates/SOUL.md +0 -49
  647. package/docs/reference/templates/TOOLS.dev.md +0 -29
  648. package/docs/reference/templates/TOOLS.md +0 -51
  649. package/docs/reference/templates/USER.dev.md +0 -23
  650. package/docs/reference/templates/USER.md +0 -28
  651. package/docs/reference/test.md +0 -247
  652. package/docs/reference/token-use.md +0 -246
  653. package/docs/reference/transcript-hygiene.md +0 -214
  654. package/docs/reference/wizard.md +0 -252
  655. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +0 -101
  656. package/docs/security/THREAT-MODEL-ATLAS.md +0 -611
  657. package/docs/security/formal-verification.md +0 -170
  658. package/docs/security/incident-response.md +0 -59
  659. package/docs/security/network-proxy.md +0 -268
  660. package/docs/snippets/plugin-publish/minimal-fengming.plugin.json +0 -12
  661. package/docs/snippets/plugin-publish/minimal-package.json +0 -16
  662. package/docs/specs/claw-supervisor.md +0 -247
  663. package/docs/start/bootstrapping.md +0 -49
  664. package/docs/start/docs-directory.md +0 -69
  665. package/docs/start/fengming.md +0 -252
  666. package/docs/start/getting-started.md +0 -152
  667. package/docs/start/hubs.md +0 -201
  668. package/docs/start/lore.md +0 -223
  669. package/docs/start/onboarding-overview.md +0 -72
  670. package/docs/start/onboarding.md +0 -98
  671. package/docs/start/quickstart.md +0 -25
  672. package/docs/start/setup.md +0 -178
  673. package/docs/start/showcase.md +0 -363
  674. package/docs/start/wizard-cli-automation.md +0 -232
  675. package/docs/start/wizard-cli-reference.md +0 -331
  676. package/docs/start/wizard.md +0 -141
  677. package/docs/style.css +0 -137
  678. package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +0 -316
  679. package/docs/tools/acp-agents-setup.md +0 -351
  680. package/docs/tools/acp-agents.md +0 -854
  681. package/docs/tools/agent-send.md +0 -130
  682. package/docs/tools/apply-patch.md +0 -64
  683. package/docs/tools/brave-search.md +0 -139
  684. package/docs/tools/browser-control.md +0 -391
  685. package/docs/tools/browser-linux-troubleshooting.md +0 -173
  686. package/docs/tools/browser-login.md +0 -77
  687. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +0 -219
  688. package/docs/tools/browser.md +0 -810
  689. package/docs/tools/btw.md +0 -159
  690. package/docs/tools/capability-cookbook.md +0 -12
  691. package/docs/tools/clawhub.md +0 -5
  692. package/docs/tools/code-execution.md +0 -173
  693. package/docs/tools/creating-skills.md +0 -158
  694. package/docs/tools/diffs.md +0 -525
  695. package/docs/tools/duckduckgo-search.md +0 -109
  696. package/docs/tools/elevated.md +0 -128
  697. package/docs/tools/exa-search.md +0 -152
  698. package/docs/tools/exec-approvals-advanced.md +0 -444
  699. package/docs/tools/exec-approvals.md +0 -494
  700. package/docs/tools/exec.md +0 -285
  701. package/docs/tools/firecrawl.md +0 -155
  702. package/docs/tools/gemini-search.md +0 -114
  703. package/docs/tools/goal.md +0 -217
  704. package/docs/tools/grok-search.md +0 -129
  705. package/docs/tools/image-generation.md +0 -493
  706. package/docs/tools/index.md +0 -178
  707. package/docs/tools/kimi-search.md +0 -105
  708. package/docs/tools/llm-task.md +0 -137
  709. package/docs/tools/lobster.md +0 -365
  710. package/docs/tools/loop-detection.md +0 -154
  711. package/docs/tools/media-overview.md +0 -160
  712. package/docs/tools/minimax-search.md +0 -102
  713. package/docs/tools/multi-agent-sandbox-tools.md +0 -409
  714. package/docs/tools/music-generation.md +0 -372
  715. package/docs/tools/ollama-search.md +0 -153
  716. package/docs/tools/pdf.md +0 -213
  717. package/docs/tools/perplexity-search.md +0 -220
  718. package/docs/tools/plugin.md +0 -363
  719. package/docs/tools/reactions.md +0 -100
  720. package/docs/tools/searxng-search.md +0 -141
  721. package/docs/tools/skills-config.md +0 -195
  722. package/docs/tools/skills.md +0 -569
  723. package/docs/tools/slash-commands.md +0 -487
  724. package/docs/tools/steer.md +0 -77
  725. package/docs/tools/subagents.md +0 -651
  726. package/docs/tools/tavily.md +0 -162
  727. package/docs/tools/thinking.md +0 -142
  728. package/docs/tools/tokenjuice.md +0 -84
  729. package/docs/tools/tool-search.md +0 -269
  730. package/docs/tools/trajectory.md +0 -229
  731. package/docs/tools/tts.md +0 -1009
  732. package/docs/tools/video-generation.md +0 -555
  733. package/docs/tools/web-fetch.md +0 -210
  734. package/docs/tools/web.md +0 -461
  735. package/docs/tts.md +0 -11
  736. package/docs/vps.md +0 -139
  737. package/docs/web/control-ui.md +0 -512
  738. package/docs/web/dashboard.md +0 -107
  739. package/docs/web/index.md +0 -133
  740. package/docs/web/tui.md +0 -250
  741. package/docs/web/webchat.md +0 -102
  742. package/npm-shrinkwrap.json +0 -12861
  743. package/patches/.gitkeep +0 -0
  744. package/patches/@agentclientprotocol__claude-agent-acp@0.37.0.patch +0 -41
  745. package/pnpm-workspace.yaml +0 -120
  746. package/scripts/crabbox-wrapper.mjs +0 -2004
  747. package/scripts/lib/official-external-channel-catalog.json +0 -560
  748. package/scripts/lib/official-external-plugin-catalog.json +0 -264
  749. package/scripts/lib/official-external-provider-catalog.json +0 -158
  750. package/scripts/lib/package-dist-imports.mjs +0 -171
  751. package/scripts/npm-runner.mjs +0 -91
  752. package/scripts/postinstall-bundled-plugins.mjs +0 -978
  753. package/scripts/preinstall-package-manager-warning.mjs +0 -64
  754. package/scripts/prepare-git-hooks.mjs +0 -72
  755. package/scripts/windows-cmd-helpers.mjs +0 -22
  756. package/skills/batch/SKILL.md +0 -118
  757. package/skills/code-review/SKILL.md +0 -107
  758. package/skills/debug/SKILL.md +0 -83
  759. package/skills/loop/SKILL.md +0 -118
  760. package/skills/run/SKILL.md +0 -79
  761. package/skills/run-skill-generator/SKILL.md +0 -179
  762. package/skills/verify/SKILL.md +0 -103
  763. package/src/agents/templates/HEARTBEAT.md +0 -3
@@ -1,185 +0,0 @@
1
- ---
2
- summary: "Agent loop lifecycle, streams, and wait semantics"
3
- read_when:
4
- - You need an exact walkthrough of the agent loop or lifecycle events
5
- - You are changing session queueing, transcript writes, or session write lock behavior
6
- title: "Agent loop"
7
- ---
8
-
9
- An agentic loop is the full "real" run of an agent: intake → context assembly → model inference →
10
- tool execution → streaming replies → persistence. It's the authoritative path that turns a message
11
- into actions and a final reply, while keeping session state consistent.
12
-
13
- In FengMing, a loop is a single, serialized run per session that emits lifecycle and stream events
14
- as the model thinks, calls tools, and streams output. This doc explains how that authentic loop is
15
- wired end-to-end.
16
-
17
- ## Entry points
18
-
19
- - Gateway RPC: `agent` and `agent.wait`.
20
- - CLI: `agent` command.
21
-
22
- ## How it works (high-level)
23
-
24
- 1. `agent` RPC validates params, resolves session (sessionKey/sessionId), persists session metadata, returns `{ runId, acceptedAt }` immediately.
25
- 2. `agentCommand` runs the agent:
26
- - resolves model + thinking/verbose/trace defaults
27
- - loads skills snapshot
28
- - calls `runEmbeddedAgent` (FengMing agent runtime)
29
- - emits **lifecycle end/error** if the embedded loop does not emit one
30
- 3. `runEmbeddedAgent`:
31
- - serializes runs via per-session + global queues
32
- - resolves model + auth profile and builds the FengMing session
33
- - subscribes to runtime events and streams assistant/tool deltas
34
- - enforces timeout -> aborts run if exceeded
35
- - for Codex app-server turns, aborts an accepted turn that stops producing app-server progress before a terminal event
36
- - returns payloads + usage metadata
37
- 4. `subscribeEmbeddedAgentSession` bridges agent runtime events to FengMing `agent` stream:
38
- - tool events => `stream: "tool"`
39
- - assistant deltas => `stream: "assistant"`
40
- - lifecycle events => `stream: "lifecycle"` (`phase: "start" | "end" | "error"`)
41
- 5. `agent.wait` uses `waitForAgentRun`:
42
- - waits for **lifecycle end/error** for `runId`
43
- - returns `{ status: ok|error|timeout, startedAt, endedAt, error? }`
44
-
45
- ## Queueing + concurrency
46
-
47
- - Runs are serialized per session key (session lane) and optionally through a global lane.
48
- - This prevents tool/session races and keeps session history consistent.
49
- - Messaging channels can choose queue modes (steer/followup/collect/interrupt) that feed this lane system.
50
- See [Command Queue](/concepts/queue).
51
- - Transcript writes are also protected by a session write lock on the session file. The lock is
52
- process-aware and file-based, so it catches writers that bypass the in-process queue or come from
53
- another process. Session transcript writers wait up to `session.writeLock.acquireTimeoutMs`
54
- before reporting the session as busy; the default is `60000` ms.
55
- - Session write locks are non-reentrant by default. If a helper intentionally nests acquisition of
56
- the same lock while preserving one logical writer, it must opt in explicitly with
57
- `allowReentrant: true`.
58
-
59
- ## Session + workspace preparation
60
-
61
- - Workspace is resolved and created; sandboxed runs may redirect to a sandbox workspace root.
62
- - Skills are loaded (or reused from a snapshot) and injected into env and prompt.
63
- - Bootstrap/context files are resolved and injected into the system prompt report.
64
- - A session write lock is acquired; `SessionManager` is opened and prepared before streaming. Any
65
- later transcript rewrite, compaction, or truncation path must take the same lock before opening or
66
- mutating the transcript file.
67
-
68
- ## Prompt assembly + system prompt
69
-
70
- - System prompt is built from FengMing's base prompt, skills prompt, bootstrap context, and per-run overrides.
71
- - Model-specific limits and compaction reserve tokens are enforced.
72
- - See [System prompt](/concepts/system-prompt) for what the model sees.
73
-
74
- ## Hook points (where you can intercept)
75
-
76
- FengMing has two hook systems:
77
-
78
- - **Internal hooks** (Gateway hooks): event-driven scripts for commands and lifecycle events.
79
- - **Plugin hooks**: extension points inside the agent/tool lifecycle and gateway pipeline.
80
-
81
- ### Internal hooks (Gateway hooks)
82
-
83
- - **`agent:bootstrap`**: runs while building bootstrap files before the system prompt is finalized.
84
- Use this to add/remove bootstrap context files.
85
- - **Command hooks**: `/new`, `/reset`, `/stop`, and other command events (see Hooks doc).
86
-
87
- See [Hooks](/automation/hooks) for setup and examples.
88
-
89
- ### Plugin hooks (agent + gateway lifecycle)
90
-
91
- These run inside the agent loop or gateway pipeline:
92
-
93
- - **`before_model_resolve`**: runs pre-session (no `messages`) to deterministically override provider/model before model resolution.
94
- - **`before_prompt_build`**: runs after session load (with `messages`) to inject `prependContext`, `systemPrompt`, `prependSystemContext`, or `appendSystemContext` before prompt submission. Use `prependContext` for per-turn dynamic text and system-context fields for stable guidance that should sit in system prompt space.
95
- - **`before_agent_start`**: legacy compatibility hook that may run in either phase; prefer the explicit hooks above.
96
- - **`before_agent_reply`**: runs after inline actions and before the LLM call, letting a plugin claim the turn and return a synthetic reply or silence the turn entirely.
97
- - **`agent_end`**: inspect the final message list and run metadata after completion.
98
- - **`before_compaction` / `after_compaction`**: observe or annotate compaction cycles.
99
- - **`before_tool_call` / `after_tool_call`**: intercept tool params/results.
100
- - **`before_install`**: inspect built-in scan findings and optionally block skill or plugin installs.
101
- - **`tool_result_persist`**: synchronously transform tool results before they are written to an FengMing-owned session transcript.
102
- - **`message_received` / `message_sending` / `message_sent`**: inbound + outbound message hooks.
103
- - **`session_start` / `session_end`**: session lifecycle boundaries.
104
- - **`gateway_start` / `gateway_stop`**: gateway lifecycle events.
105
-
106
- Hook decision rules for outbound/tool guards:
107
-
108
- - `before_tool_call`: `{ block: true }` is terminal and stops lower-priority handlers.
109
- - `before_tool_call`: `{ block: false }` is a no-op and does not clear a prior block.
110
- - `before_install`: `{ block: true }` is terminal and stops lower-priority handlers.
111
- - `before_install`: `{ block: false }` is a no-op and does not clear a prior block.
112
- - `message_sending`: `{ cancel: true }` is terminal and stops lower-priority handlers.
113
- - `message_sending`: `{ cancel: false }` is a no-op and does not clear a prior cancel.
114
-
115
- See [Plugin hooks](/plugins/hooks) for the hook API and registration details.
116
-
117
- Harnesses may adapt these hooks differently. The Codex app-server harness keeps
118
- FengMing plugin hooks as the compatibility contract for documented mirrored
119
- surfaces, while Codex native hooks remain a separate lower-level Codex mechanism.
120
-
121
- ## Streaming + partial replies
122
-
123
- - Assistant deltas are streamed from the agent runtime and emitted as `assistant` events.
124
- - Block streaming can emit partial replies either on `text_end` or `message_end`.
125
- - Reasoning streaming can be emitted as a separate stream or as block replies.
126
- - See [Streaming](/concepts/streaming) for chunking and block reply behavior.
127
-
128
- ## Tool execution + messaging tools
129
-
130
- - Tool start/update/end events are emitted on the `tool` stream.
131
- - Tool results are sanitized for size and image payloads before logging/emitting.
132
- - Messaging tool sends are tracked to suppress duplicate assistant confirmations.
133
-
134
- ## Reply shaping + suppression
135
-
136
- - Final payloads are assembled from:
137
- - assistant text (and optional reasoning)
138
- - inline tool summaries (when verbose + allowed)
139
- - assistant error text when the model errors
140
- - The exact silent token `NO_REPLY` / `no_reply` is filtered from outgoing
141
- payloads.
142
- - Messaging tool duplicates are removed from the final payload list.
143
- - If no renderable payloads remain and a tool errored, a fallback tool error reply is emitted
144
- (unless a messaging tool already sent a user-visible reply).
145
-
146
- ## Compaction + retries
147
-
148
- - Auto-compaction emits `compaction` stream events and can trigger a retry.
149
- - On retry, in-memory buffers and tool summaries are reset to avoid duplicate output.
150
- - See [Compaction](/concepts/compaction) for the compaction pipeline.
151
-
152
- ## Event streams (today)
153
-
154
- - `lifecycle`: emitted by `subscribeEmbeddedAgentSession` (and as a fallback by `agentCommand`)
155
- - `assistant`: streamed deltas from the agent runtime
156
- - `tool`: streamed tool events from the agent runtime
157
-
158
- ## Chat channel handling
159
-
160
- - Assistant deltas are buffered into chat `delta` messages.
161
- - A chat `final` is emitted on **lifecycle end/error**.
162
-
163
- ## Timeouts
164
-
165
- - `agent.wait` default: 30s (just the wait). `timeoutMs` param overrides.
166
- - Agent runtime: `agents.defaults.timeoutSeconds` default 172800s (48 hours); enforced in `runEmbeddedAgent` abort timer.
167
- - Cron runtime: isolated agent-turn `timeoutSeconds` is owned by cron. The scheduler starts that timer when execution begins, aborts the underlying run at the configured deadline, then runs bounded cleanup before recording the timeout so a stale child session cannot keep the lane stuck.
168
- - Session liveness diagnostics: with diagnostics enabled, `diagnostics.stuckSessionWarnMs` classifies long `processing` sessions that have no observed reply, tool, status, block, or ACP progress. Active embedded runs, model calls, and tool calls report as `session.long_running`; active work with no recent progress reports as `session.stalled`; `session.stuck` is reserved for recoverable stale session bookkeeping, including idle queued sessions with stale ownerless model/tool activity. Stale session bookkeeping releases the affected session lane immediately after recovery gates pass; stalled embedded runs are abort-drained only after `diagnostics.stuckSessionAbortMs` (default: at least 5 minutes and 3x the warning threshold) so queued work can resume without cutting off merely slow runs. Recovery emits structured requested/completed outcomes, and diagnostic state is marked idle only if the same processing generation is still current. Repeated `session.stuck` diagnostics back off while the session remains unchanged.
169
- - Model idle timeout: FengMing aborts a model request when no response chunks arrive before the idle window. `models.providers.<id>.timeoutSeconds` extends this idle watchdog for slow local/self-hosted providers, but it is still bounded by any lower `agents.defaults.timeoutSeconds` or run-specific timeout because those control the whole agent run. Otherwise FengMing uses `agents.defaults.timeoutSeconds` when configured, capped at 120s by default. Cron-triggered runs with no explicit model or agent timeout disable the idle watchdog and rely on the cron outer timeout.
170
- - Provider HTTP request timeout: `models.providers.<id>.timeoutSeconds` applies to that provider's model HTTP fetches, including connect, headers, body, SDK request timeout, total guarded-fetch abort handling, and model stream idle watchdog. Use this for slow local/self-hosted providers such as Ollama before raising the whole agent runtime timeout, and keep the agent/runtime timeout at least as high when the model request needs to run longer.
171
-
172
- ## Where things can end early
173
-
174
- - Agent timeout (abort)
175
- - AbortSignal (cancel)
176
- - Gateway disconnect or RPC timeout
177
- - `agent.wait` timeout (wait-only, does not stop agent)
178
-
179
- ## Related
180
-
181
- - [Tools](/tools) — available agent tools
182
- - [Hooks](/automation/hooks) — event-driven scripts triggered by agent lifecycle events
183
- - [Compaction](/concepts/compaction) — how long conversations are summarized
184
- - [Exec Approvals](/tools/exec-approvals) — approval gates for shell commands
185
- - [Thinking](/tools/thinking) — thinking/reasoning level configuration
@@ -1,276 +0,0 @@
1
- ---
2
- summary: "How FengMing separates model providers, models, channels, and agent runtimes"
3
- title: "Agent runtimes"
4
- read_when:
5
- - You are choosing between FengMing, Codex, ACP, or another native agent runtime
6
- - You are confused by provider/model/runtime labels in status or config
7
- - You are documenting support parity for a native harness
8
- ---
9
-
10
- An **agent runtime** is the component that owns one prepared model loop: it
11
- receives the prompt, drives model output, handles native tool calls, and returns
12
- the finished turn to FengMing.
13
-
14
- Runtimes are easy to confuse with providers because both show up near model
15
- configuration. They are different layers:
16
-
17
- | Layer | Examples | What it means |
18
- | ------------- | -------------------------------------------- | ------------------------------------------------------------------- |
19
- | Provider | `openai`, `anthropic`, `github-copilot` | How FengMing authenticates, discovers models, and names model refs. |
20
- | Model | `gpt-5.5`, `claude-opus-4-6` | The model selected for the agent turn. |
21
- | Agent runtime | `fengming`, `codex`, `copilot`, `claude-cli` | The low level loop or backend that executes the prepared turn. |
22
- | Channel | Telegram, Discord, Slack, WhatsApp | Where messages enter and leave FengMing. |
23
-
24
- You will also see the word **harness** in code. A harness is the implementation
25
- that provides an agent runtime. For example, the bundled Codex harness
26
- implements the `codex` runtime. Public config uses `agentRuntime.id` on
27
- provider or model entries; whole-agent runtime keys are legacy and ignored.
28
- `fengming doctor --fix` removes old whole-agent runtime pins and rewrites
29
- legacy runtime model refs to canonical provider/model refs plus model-scoped
30
- runtime policy where needed.
31
-
32
- There are two runtime families:
33
-
34
- - **Embedded harnesses** run inside FengMing's prepared agent loop. Today this
35
- is the built-in `fengming` runtime plus registered plugin harnesses such as
36
- `codex` and `copilot`.
37
- - **CLI backends** run a local CLI process while keeping the model ref
38
- canonical. For example, `anthropic/claude-opus-4-8` with
39
- a model-scoped `agentRuntime.id: "claude-cli"` means "select the Anthropic
40
- model, execute through Claude CLI." `claude-cli` is not an embedded harness id
41
- and must not be passed to AgentHarness selection.
42
-
43
- The `copilot` harness is a separate, opt-in external plugin harness for the
44
- GitHub Copilot CLI; see [GitHub Copilot agent runtime](/plugins/copilot)
45
- for the user-facing decision between PI, Codex, and GitHub Copilot agent runtime.
46
-
47
- ## Codex surfaces
48
-
49
- Most confusion comes from several different surfaces sharing the Codex name:
50
-
51
- | Surface | FengMing name/config | What it does |
52
- | ------------------------------------------------ | ------------------------------------ | -------------------------------------------------------------------------------------------------------------- |
53
- | Native Codex app-server runtime | `openai/*` model refs | Runs OpenAI embedded agent turns through Codex app-server. This is the usual ChatGPT/Codex subscription setup. |
54
- | Codex OAuth auth profiles | `openai` OAuth profiles | Stores ChatGPT/Codex subscription auth that the Codex app-server harness consumes. |
55
- | Codex ACP adapter | `runtime: "acp"`, `agentId: "codex"` | Runs Codex through the external ACP/acpx control plane. Use only when ACP/acpx is explicitly asked. |
56
- | Native Codex chat-control command set | `/codex ...` | Binds, resumes, steers, stops, and inspects Codex app-server threads from chat. |
57
- | OpenAI Platform API route for non-agent surfaces | `openai/*` plus API-key auth | Used for direct OpenAI APIs such as images, embeddings, speech, and realtime. |
58
-
59
- Those surfaces are intentionally independent. Enabling the `codex` plugin makes
60
- the native app-server features available; `fengming doctor --fix` owns legacy
61
- `openai-codex/*` route repair and stale session pin cleanup. Selecting
62
- `openai/*` for an agent model now means "run this through Codex" unless a
63
- non-agent OpenAI API surface is being used.
64
-
65
- The common ChatGPT/Codex subscription setup uses Codex OAuth for auth, but keeps
66
- the model ref as `openai/*` and selects the `codex` runtime:
67
-
68
- ```json5
69
- {
70
- agents: {
71
- defaults: {
72
- model: "openai/gpt-5.5",
73
- },
74
- },
75
- }
76
- ```
77
-
78
- That means FengMing selects an OpenAI model ref, then asks the Codex app-server
79
- runtime to run the embedded agent turn. It does not mean "use API billing," and
80
- it does not mean the channel, model provider catalog, or FengMing session store
81
- becomes Codex.
82
-
83
- When the bundled `codex` plugin is enabled, natural-language Codex control
84
- should use the native `/codex` command surface (`/codex bind`, `/codex threads`,
85
- `/codex resume`, `/codex steer`, `/codex stop`) instead of ACP. Use ACP for
86
- Codex only when the user explicitly asks for ACP/acpx or is testing the ACP
87
- adapter path. Claude Code, Gemini CLI, OpenCode, Cursor, and similar external
88
- harnesses still use ACP.
89
-
90
- This is the agent-facing decision tree:
91
-
92
- 1. If the user asks for **Codex bind/control/thread/resume/steer/stop**, use the
93
- native `/codex` command surface when the bundled `codex` plugin is enabled.
94
- 2. If the user asks for **Codex as the embedded runtime** or wants the normal
95
- subscription-backed Codex agent experience, use `openai/<model>`.
96
- 3. If the user explicitly chooses **FengMing for an OpenAI model**, keep the model ref
97
- as `openai/<model>` and set provider/model runtime policy to
98
- `agentRuntime.id: "fengming"`. A selected `openai` OAuth profile is routed
99
- internally through FengMing's Codex-auth transport.
100
- 4. If legacy config still contains **`openai-codex/*` model refs**, repair it to
101
- `openai/<model>` with `fengming doctor --fix`; doctor keeps the Codex auth
102
- route by adding provider/model-scoped `agentRuntime.id: "codex"` where the
103
- old model ref implied it.
104
- Legacy **`codex-cli/*` model refs** repair to the same `openai/<model>` Codex
105
- app-server route; FengMing no longer keeps a bundled Codex CLI backend.
106
- 5. If the user explicitly says **ACP**, **acpx**, or **Codex ACP adapter**, use
107
- ACP with `runtime: "acp"` and `agentId: "codex"`.
108
- 6. If the request is for **Claude Code, Gemini CLI, OpenCode, Cursor, Droid, or
109
- another external harness**, use ACP/acpx, not the native sub-agent runtime.
110
-
111
- | You mean... | Use... |
112
- | --------------------------------------- | -------------------------------------------- |
113
- | Codex app-server chat/thread control | `/codex ...` from the bundled `codex` plugin |
114
- | Codex app-server embedded agent runtime | `openai/*` agent model refs |
115
- | OpenAI Codex OAuth | `openai` OAuth profiles |
116
- | Claude Code or other external harness | ACP/acpx |
117
-
118
- For the OpenAI-family prefix split, see [OpenAI](/providers/openai) and
119
- [Model providers](/concepts/model-providers). For the Codex runtime support
120
- contract, see [Codex harness runtime](/plugins/codex-harness-runtime#v1-support-contract).
121
-
122
- ## Runtime ownership
123
-
124
- Different runtimes own different amounts of the loop.
125
-
126
- | Surface | FengMing embedded | Codex app-server |
127
- | --------------------------- | --------------------------------------------- | --------------------------------------------------------------------------- |
128
- | Model loop owner | FengMing through the FengMing embedded runner | Codex app-server |
129
- | Canonical thread state | FengMing transcript | Codex thread, plus FengMing transcript mirror |
130
- | FengMing dynamic tools | Native FengMing tool loop | Bridged through the Codex adapter |
131
- | Native shell and file tools | FengMing path | Codex-native tools, bridged through native hooks where supported |
132
- | Context engine | Native FengMing context assembly | FengMing projects assembled context into the Codex turn |
133
- | Compaction | FengMing or selected context engine | Codex-native compaction, with FengMing notifications and mirror maintenance |
134
- | Channel delivery | FengMing | FengMing |
135
-
136
- This ownership split is the main design rule:
137
-
138
- - If FengMing owns the surface, FengMing can provide normal plugin hook behavior.
139
- - If the native runtime owns the surface, FengMing needs runtime events or native hooks.
140
- - If the native runtime owns canonical thread state, FengMing should mirror and project context, not rewrite unsupported internals.
141
-
142
- ## Runtime selection
143
-
144
- FengMing chooses an embedded runtime after provider and model resolution:
145
-
146
- 1. Model-scoped runtime policy wins. This can live in a configured provider
147
- model entry or in `agents.defaults.models["provider/model"].agentRuntime` /
148
- `agents.list[].models["provider/model"].agentRuntime`. A provider wildcard
149
- such as `agents.defaults.models["vllm/*"].agentRuntime` applies after exact
150
- model policy, so dynamically discovered provider models can share one
151
- runtime without overriding exact per-model exceptions.
152
- 2. Provider-scoped runtime policy comes next at
153
- `models.providers.<provider>.agentRuntime`.
154
- 3. In `auto` mode, registered plugin runtimes can claim supported provider/model
155
- pairs.
156
- 4. If no runtime claims a turn in `auto` mode, FengMing uses `fengming` as the
157
- compatibility runtime. Use an explicit runtime id when the run must be
158
- strict.
159
-
160
- Whole-session and whole-agent runtime pins are ignored. That includes
161
- `FENGMING_AGENT_RUNTIME`, session `agentHarnessId`/`agentRuntimeOverride` state,
162
- `agents.defaults.agentRuntime`, and `agents.list[].agentRuntime`. Run
163
- `fengming doctor --fix` to remove stale whole-agent runtime config and convert
164
- legacy runtime model refs where FengMing can preserve the intent.
165
-
166
- Explicit provider/model plugin runtimes fail closed. For example,
167
- `agentRuntime.id: "codex"` on a provider or model means Codex or a clear
168
- selection/runtime error; it is never silently routed back to FengMing.
169
-
170
- CLI backend aliases are different from embedded harness ids. The preferred
171
- Claude CLI form is:
172
-
173
- ```json5
174
- {
175
- agents: {
176
- defaults: {
177
- model: "anthropic/claude-opus-4-8",
178
- models: {
179
- "anthropic/claude-opus-4-8": {
180
- agentRuntime: { id: "claude-cli" },
181
- },
182
- },
183
- },
184
- },
185
- }
186
- ```
187
-
188
- Legacy refs such as `claude-cli/claude-opus-4-7` remain supported for
189
- compatibility, but new config should keep the provider/model canonical and put
190
- the execution backend in provider/model runtime policy.
191
-
192
- Legacy `codex-cli/*` refs are different: doctor migrates them to `openai/*` so
193
- they run through the Codex app-server harness instead of preserving a Codex CLI
194
- backend.
195
-
196
- `auto` mode is intentionally conservative for most providers. OpenAI agent
197
- models are the exception: unset runtime and `auto` both resolve to the Codex
198
- harness. Explicit FengMing runtime config remains an opt-in compatibility route for
199
- `openai/*` agent turns; when paired with a selected `openai` OAuth profile,
200
- FengMing routes that path internally through the Codex-auth transport while
201
- keeping the public model ref as `openai/*`. Stale OpenAI runtime session pins are
202
- ignored by runtime selection and can be cleaned with `fengming doctor --fix`.
203
-
204
- If `fengming doctor` warns that the `codex` plugin is enabled while
205
- `openai-codex/*` remains in config, treat that as legacy route state. Run
206
- `fengming doctor --fix` to rewrite it to `openai/*` with the Codex runtime.
207
-
208
- ## GitHub Copilot agent runtime
209
-
210
- The external `@fengming/copilot` plugin registers an opt-in `copilot` runtime
211
- backed by the GitHub Copilot CLI (`@github/copilot-sdk`). It claims the
212
- canonical subscription `github-copilot` provider and is **never** selected by
213
- `auto`. Opt in per-model or per-provider via `agentRuntime.id`:
214
-
215
- ```json5
216
- {
217
- agents: {
218
- defaults: {
219
- model: "github-copilot/gpt-5.5",
220
- models: {
221
- "github-copilot/gpt-5.5": {
222
- agentRuntime: { id: "copilot" },
223
- },
224
- },
225
- },
226
- },
227
- }
228
- ```
229
-
230
- The harness claims its provider, runtime, CLI session key, and auth profile
231
- prefix in `extensions/copilot/doctor-contract-api.ts`, which
232
- `fengming doctor` auto-loads. For configuration, auth, transcript mirroring,
233
- compaction, the doctor probe surface, and the broader PI vs Codex vs Copilot
234
- SDK decision, see [GitHub Copilot agent runtime](/plugins/copilot).
235
-
236
- ## Compatibility contract
237
-
238
- When a runtime is not FengMing, it should document what FengMing surfaces it supports.
239
- Use this shape for runtime docs:
240
-
241
- | Question | Why it matters |
242
- | -------------------------------------- | ------------------------------------------------------------------------------------------------- |
243
- | Who owns the model loop? | Determines where retries, tool continuation, and final answer decisions happen. |
244
- | Who owns canonical thread history? | Determines whether FengMing can edit history or only mirror it. |
245
- | Do FengMing dynamic tools work? | Messaging, sessions, cron, and FengMing-owned tools rely on this. |
246
- | Do dynamic tool hooks work? | Plugins expect `before_tool_call`, `after_tool_call`, and middleware around FengMing-owned tools. |
247
- | Do native tool hooks work? | Shell, patch, and runtime-owned tools need native hook support for policy and observation. |
248
- | Does the context engine lifecycle run? | Memory and context plugins depend on assemble, ingest, after-turn, and compaction lifecycle. |
249
- | What compaction data is exposed? | Some plugins only need notifications, while others need kept/dropped metadata. |
250
- | What is intentionally unsupported? | Users should not assume FengMing equivalence where the native runtime owns more state. |
251
-
252
- The Codex runtime support contract is documented in
253
- [Codex harness runtime](/plugins/codex-harness-runtime#v1-support-contract).
254
-
255
- ## Status labels
256
-
257
- Status output may show both `Execution` and `Runtime` labels. Read them as
258
- diagnostics, not as provider names.
259
-
260
- - A model ref such as `openai/gpt-5.5` tells you the selected provider/model.
261
- - A runtime id such as `codex` tells you which loop is executing the turn.
262
- - A channel label such as Telegram or Discord tells you where the conversation is happening.
263
-
264
- If a run still shows an unexpected runtime, inspect the selected provider/model
265
- runtime policy first. Legacy session runtime pins no longer decide routing.
266
-
267
- ## Related
268
-
269
- - [Codex harness](/plugins/codex-harness)
270
- - [Codex harness runtime](/plugins/codex-harness-runtime)
271
- - [GitHub Copilot agent runtime](/plugins/copilot)
272
- - [OpenAI](/providers/openai)
273
- - [Agent harness plugins](/plugins/sdk-agent-harness)
274
- - [Agent loop](/concepts/agent-loop)
275
- - [Models](/concepts/models)
276
- - [Status](/cli/status)