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,979 +0,0 @@
1
- ---
2
- summary: "Migrate from the legacy backwards-compatibility layer to the modern plugin SDK"
3
- title: "Plugin SDK migration"
4
- sidebarTitle: "Migrate to SDK"
5
- read_when:
6
- - You see the FENGMING_PLUGIN_SDK_COMPAT_DEPRECATED warning
7
- - You see the FENGMING_EXTENSION_API_DEPRECATED warning
8
- - You used api.registerEmbeddedExtensionFactory before FengMing 2026.4.25
9
- - You are updating a plugin to the modern plugin architecture
10
- - You maintain an external FengMing plugin
11
- ---
12
-
13
- FengMing has moved from a broad backwards-compatibility layer to a modern plugin
14
- architecture with focused, documented imports. If your plugin was built before
15
- the new architecture, this guide helps you migrate.
16
-
17
- ## What is changing
18
-
19
- The old plugin system provided two wide-open surfaces that let plugins import
20
- anything they needed from a single entry point:
21
-
22
- - **`fengming/plugin-sdk/compat`** - a single import that re-exported dozens of
23
- helpers. It was introduced to keep older hook-based plugins working while the
24
- new plugin architecture was being built.
25
- - **`fengming/plugin-sdk/infra-runtime`** - a broad runtime helper barrel that
26
- mixed system events, heartbeat state, delivery queues, fetch/proxy helpers,
27
- file helpers, approval types, and unrelated utilities.
28
- - **`fengming/plugin-sdk/config-runtime`** - a broad config compatibility barrel
29
- that still carries deprecated direct load/write helpers during the migration
30
- window.
31
- - **`fengming/extension-api`** - a bridge that gave plugins direct access to
32
- host-side helpers like the embedded agent runner.
33
- - **`api.registerEmbeddedExtensionFactory(...)`** - a removed embedded-runner-only bundled
34
- extension hook that could observe embedded-runner events such as
35
- `tool_result`.
36
-
37
- The broad import surfaces are now **deprecated**. They still work at runtime,
38
- but new plugins must not use them, and existing plugins should migrate before
39
- the next major release removes them. The embedded-runner-only extension factory
40
- registration API has been removed; use tool-result middleware instead.
41
-
42
- FengMing does not remove or reinterpret documented plugin behavior in the same
43
- change that introduces a replacement. Breaking contract changes must first go
44
- through a compatibility adapter, diagnostics, docs, and a deprecation window.
45
- That applies to SDK imports, manifest fields, setup APIs, hooks, and runtime
46
- registration behavior.
47
-
48
- <Warning>
49
- The backwards-compatibility layer will be removed in a future major release.
50
- Plugins that still import from these surfaces will break when that happens.
51
- Legacy embedded extension factory registrations already no longer load.
52
- </Warning>
53
-
54
- ## Why this changed
55
-
56
- The old approach caused problems:
57
-
58
- - **Slow startup** - importing one helper loaded dozens of unrelated modules
59
- - **Circular dependencies** - broad re-exports made it easy to create import cycles
60
- - **Unclear API surface** - no way to tell which exports were stable vs internal
61
-
62
- The modern plugin SDK fixes this: each import path (`fengming/plugin-sdk/\<subpath\>`)
63
- is a small, self-contained module with a clear purpose and documented contract.
64
-
65
- Legacy provider convenience seams for bundled channels are also gone.
66
- Channel-branded helper seams were private mono-repo shortcuts, not stable
67
- plugin contracts. Use narrow generic SDK subpaths instead. Inside the bundled
68
- plugin workspace, keep provider-owned helpers in that plugin's own `api.ts` or
69
- `runtime-api.ts`.
70
-
71
- Current bundled provider examples:
72
-
73
- - Anthropic keeps Claude-specific stream helpers in its own `api.ts` /
74
- `contract-api.ts` seam
75
- - OpenAI keeps provider builders, default-model helpers, and realtime provider
76
- builders in its own `api.ts`
77
- - OpenRouter keeps provider builder and onboarding/config helpers in its own
78
- `api.ts`
79
-
80
- ## Talk and realtime voice migration plan
81
-
82
- Realtime voice, telephony, meeting, and browser Talk code is moving from
83
- surface-local turn bookkeeping to a shared Talk session controller exported by
84
- `fengming/plugin-sdk/realtime-voice`. The new controller owns the common Talk
85
- event envelope, active turn state, capture state, output-audio state, recent
86
- event history, and stale-turn rejection. Provider plugins should keep owning
87
- vendor-specific realtime sessions; surface plugins should keep owning capture,
88
- playback, telephony, and meeting quirks.
89
-
90
- This Talk migration is intentionally breaking-clean:
91
-
92
- 1. Keep the shared controller/runtime primitives in
93
- `plugin-sdk/realtime-voice`.
94
- 2. Move bundled surfaces onto the shared controller: browser relay,
95
- managed-room handoff, voice-call realtime, voice-call streaming STT, Google
96
- Meet realtime, and native push-to-talk.
97
- 3. Replace old Talk RPC families with the final `talk.session.*` and
98
- `talk.client.*` API.
99
- 4. Advertise one live Talk event channel in Gateway
100
- `hello-ok.features.events`: `talk.event`.
101
- 5. Delete the old realtime HTTP endpoint and any request-time instruction
102
- override path.
103
-
104
- New code should not call `createTalkEventSequencer(...)` directly unless it is
105
- implementing a low-level adapter or test fixture. Prefer the shared controller
106
- so turn-scoped events cannot be emitted without a turn id, stale `turnEnd` /
107
- `turnCancel` calls cannot clear a newer active turn, and output-audio lifecycle
108
- events stay consistent across telephony, meetings, browser relay, managed-room
109
- handoff, and native Talk clients.
110
-
111
- The target public API shape is:
112
-
113
- ```typescript
114
- // Gateway-owned Talk session API.
115
- await gateway.request("talk.session.create", {
116
- mode: "realtime",
117
- transport: "gateway-relay",
118
- brain: "agent-consult",
119
- sessionKey: "main",
120
- });
121
- await gateway.request("talk.session.appendAudio", { sessionId, audioBase64 });
122
- await gateway.request("talk.session.cancelOutput", { sessionId, reason: "barge-in" });
123
- await gateway.request("talk.session.submitToolResult", {
124
- sessionId,
125
- callId,
126
- result: { status: "working" },
127
- options: { willContinue: true },
128
- });
129
- await gateway.request("talk.session.submitToolResult", {
130
- sessionId,
131
- callId,
132
- result: { status: "already_delivered" },
133
- options: { suppressResponse: true },
134
- });
135
- await gateway.request("talk.session.submitToolResult", { sessionId, callId, result });
136
- await gateway.request("talk.session.close", { sessionId });
137
-
138
- // Client-owned provider session API.
139
- await gateway.request("talk.client.create", {
140
- mode: "realtime",
141
- transport: "webrtc",
142
- brain: "agent-consult",
143
- sessionKey: "main",
144
- });
145
- await gateway.request("talk.client.toolCall", { sessionKey, callId, name, args });
146
- await gateway.request("talk.client.steer", { sessionKey, text, mode: "steer" });
147
- ```
148
-
149
- Browser-owned WebRTC/provider-websocket sessions use `talk.client.create`,
150
- because the browser owns the provider negotiation and media transport while the
151
- Gateway owns credentials, instructions, and tool policy. `talk.session.*` is the
152
- common Gateway-managed surface for gateway-relay realtime, gateway-relay
153
- transcription, and managed-room native STT/TTS sessions.
154
-
155
- Legacy configs that placed realtime selectors beside `talk.provider` /
156
- `talk.providers` should be repaired with `fengming doctor --fix`; runtime Talk
157
- does not reinterpret speech/TTS provider config as realtime provider config.
158
-
159
- The supported `talk.session.create` combinations are intentionally small:
160
-
161
- | Mode | Transport | Brain | Owner | Notes |
162
- | --------------- | --------------- | --------------- | ------------------ | ------------------------------------------------------------------------------------------------------------------ |
163
- | `realtime` | `gateway-relay` | `agent-consult` | Gateway | Full-duplex provider audio bridged through the Gateway; tool calls are routed through the agent-consult tool. |
164
- | `transcription` | `gateway-relay` | `none` | Gateway | Streaming STT only; callers send input audio and receive transcript events. |
165
- | `stt-tts` | `managed-room` | `agent-consult` | Native/client room | Push-to-talk and walkie-talkie style rooms where the client owns capture/playback and the Gateway owns turn state. |
166
- | `stt-tts` | `managed-room` | `direct-tools` | Native/client room | Admin-only room mode for trusted first-party surfaces that execute Gateway tool actions directly. |
167
-
168
- Removed method map:
169
-
170
- | Old | New |
171
- | -------------------------------- | -------------------------------------------------------- |
172
- | `talk.realtime.session` | `talk.client.create` |
173
- | `talk.realtime.toolCall` | `talk.client.toolCall` |
174
- | `talk.realtime.relayAudio` | `talk.session.appendAudio` |
175
- | `talk.realtime.relayCancel` | `talk.session.cancelOutput` or `talk.session.cancelTurn` |
176
- | `talk.realtime.relayToolResult` | `talk.session.submitToolResult` |
177
- | `talk.realtime.relayStop` | `talk.session.close` |
178
- | `talk.transcription.session` | `talk.session.create({ mode: "transcription" })` |
179
- | `talk.transcription.relayAudio` | `talk.session.appendAudio` |
180
- | `talk.transcription.relayCancel` | `talk.session.cancelTurn` |
181
- | `talk.transcription.relayStop` | `talk.session.close` |
182
- | `talk.handoff.create` | `talk.session.create({ transport: "managed-room" })` |
183
- | `talk.handoff.join` | `talk.session.join` |
184
- | `talk.handoff.revoke` | `talk.session.close` |
185
-
186
- The unified control vocabulary is also deliberately narrow:
187
-
188
- | Method | Applies to | Contract |
189
- | ------------------------------- | ------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
190
- | `talk.session.appendAudio` | `realtime/gateway-relay`, `transcription/gateway-relay` | Append a base64 PCM audio chunk to the provider session owned by the same Gateway connection. |
191
- | `talk.session.startTurn` | `stt-tts/managed-room` | Start a managed-room user turn. |
192
- | `talk.session.endTurn` | `stt-tts/managed-room` | End the active turn after stale-turn validation. |
193
- | `talk.session.cancelTurn` | all Gateway-owned sessions | Cancel active capture/provider/agent/TTS work for a turn. |
194
- | `talk.session.cancelOutput` | `realtime/gateway-relay` | Stop assistant audio output without necessarily ending the user turn. |
195
- | `talk.session.submitToolResult` | `realtime/gateway-relay` | Complete a provider tool call emitted by the relay; pass `options.willContinue` for interim output or `options.suppressResponse` to satisfy the call without another assistant response. |
196
- | `talk.session.steer` | agent-backed Talk sessions | Send spoken `status`, `steer`, `cancel`, or `followup` control to the active embedded run resolved from the Talk session. |
197
- | `talk.session.close` | all unified sessions | Stop relay sessions or revoke managed-room state, then forget the unified session id. |
198
-
199
- Do not introduce provider or platform special cases in core to make this work.
200
- Core owns Talk session semantics. Provider plugins own vendor session setup.
201
- Voice-call and Google Meet own telephony/meeting adapters. Browser and native
202
- apps own device capture/playback UX.
203
-
204
- ## Compatibility policy
205
-
206
- For external plugins, compatibility work follows this order:
207
-
208
- 1. add the new contract
209
- 2. keep the old behavior wired through a compatibility adapter
210
- 3. emit a diagnostic or warning that names the old path and replacement
211
- 4. cover both paths in tests
212
- 5. document the deprecation and migration path
213
- 6. remove only after the announced migration window, usually in a major release
214
-
215
- Maintainers can audit the current migration queue with
216
- `pnpm plugins:boundary-report`. Use `pnpm plugins:boundary-report:summary` for
217
- compact counts, `--owner <id>` for one plugin or compatibility owner, and
218
- `pnpm plugins:boundary-report:ci` when a CI gate should fail on due
219
- compatibility records, cross-owner reserved SDK imports, or unused reserved SDK
220
- subpaths. The report groups deprecated
221
- compatibility records by removal date, counts local code/docs references,
222
- surfaces cross-owner reserved SDK imports, and summarizes the private
223
- memory-host SDK bridge so compatibility cleanup stays explicit instead of
224
- relying on ad hoc searches. Reserved SDK subpaths must have tracked owner usage;
225
- unused reserved helper exports should be removed from the public SDK.
226
-
227
- If a manifest field is still accepted, plugin authors can keep using it until
228
- the docs and diagnostics say otherwise. New code should prefer the documented
229
- replacement, but existing plugins should not break during ordinary minor
230
- releases.
231
-
232
- ## How to migrate
233
-
234
- <Steps>
235
- <Step title="Migrate runtime config load/write helpers">
236
- Bundled plugins should stop calling
237
- `api.runtime.config.loadConfig()` and
238
- `api.runtime.config.writeConfigFile(...)` directly. Prefer config that was
239
- already passed into the active call path. Long-lived handlers that need the
240
- current process snapshot can use `api.runtime.config.current()`. Long-lived
241
- agent tools should use the tool context's `ctx.getRuntimeConfig()` inside
242
- `execute` so a tool created before a config write still sees the refreshed
243
- runtime config.
244
-
245
- Config writes must go through the transactional helpers and choose an
246
- after-write policy:
247
-
248
- ```typescript
249
- await api.runtime.config.mutateConfigFile({
250
- afterWrite: { mode: "auto" },
251
- mutate(draft) {
252
- draft.plugins ??= {};
253
- },
254
- });
255
- ```
256
-
257
- Use `afterWrite: { mode: "restart", reason: "..." }` when the caller knows
258
- the change requires a clean gateway restart, and
259
- `afterWrite: { mode: "none", reason: "..." }` only when the caller owns the
260
- follow-up and deliberately wants to suppress the reload planner.
261
- Mutation results include a typed `followUp` summary for tests and logging;
262
- the gateway remains responsible for applying or scheduling the restart.
263
- `loadConfig` and `writeConfigFile` remain as deprecated compatibility
264
- helpers for external plugins during the migration window and warn once with
265
- the `runtime-config-load-write` compatibility code. Bundled plugins and repo
266
- runtime code are protected by scanner guardrails in
267
- `pnpm check:deprecated-api-usage` and
268
- `pnpm check:no-runtime-action-load-config`: new production plugin usage
269
- fails outright, direct config writes fail, gateway server methods must use
270
- the request runtime snapshot, runtime channel send/action/client helpers
271
- must receive config from their boundary, and long-lived runtime modules have
272
- zero allowed ambient `loadConfig()` calls.
273
-
274
- New plugin code should also avoid importing the broad
275
- `fengming/plugin-sdk/config-runtime` compatibility barrel. Use the narrow
276
- SDK subpath that matches the job:
277
-
278
- | Need | Import |
279
- | --- | --- |
280
- | Config types such as `FengMingConfig` | `fengming/plugin-sdk/config-contracts` |
281
- | Already-loaded config assertions and plugin-entry config lookup | `fengming/plugin-sdk/plugin-config-runtime` |
282
- | Current runtime snapshot reads | `fengming/plugin-sdk/runtime-config-snapshot` |
283
- | Config writes | `fengming/plugin-sdk/config-mutation` |
284
- | Session store helpers | `fengming/plugin-sdk/session-store-runtime` |
285
- | Markdown table config | `fengming/plugin-sdk/markdown-table-runtime` |
286
- | Group policy runtime helpers | `fengming/plugin-sdk/runtime-group-policy` |
287
- | Secret input resolution | `fengming/plugin-sdk/secret-input-runtime` |
288
- | Model/session overrides | `fengming/plugin-sdk/model-session-runtime` |
289
-
290
- Bundled plugins and their tests are scanner-guarded against the broad
291
- barrel so imports and mocks stay local to the behavior they need. The broad
292
- barrel still exists for external compatibility, but new code should not
293
- depend on it.
294
-
295
- </Step>
296
-
297
- <Step title="Migrate embedded tool-result extensions to middleware">
298
- Bundled plugins must replace embedded-runner-only
299
- `api.registerEmbeddedExtensionFactory(...)` tool-result handlers with
300
- runtime-neutral middleware.
301
-
302
- ```typescript
303
- // FengMing and Codex runtime dynamic tools
304
- api.registerAgentToolResultMiddleware(async (event) => {
305
- return compactToolResult(event);
306
- }, {
307
- runtimes: ["fengming", "codex"],
308
- });
309
- ```
310
-
311
- Update the plugin manifest at the same time:
312
-
313
- ```json
314
- {
315
- "contracts": {
316
- "agentToolResultMiddleware": ["fengming", "codex"]
317
- }
318
- }
319
- ```
320
-
321
- External plugins cannot register tool-result middleware because it can
322
- rewrite high-trust tool output before the model sees it.
323
-
324
- </Step>
325
-
326
- <Step title="Migrate approval-native handlers to capability facts">
327
- Approval-capable channel plugins now expose native approval behavior through
328
- `approvalCapability.nativeRuntime` plus the shared runtime-context registry.
329
-
330
- Key changes:
331
-
332
- - Replace `approvalCapability.handler.loadRuntime(...)` with
333
- `approvalCapability.nativeRuntime`
334
- - Move approval-specific auth/delivery off legacy `plugin.auth` /
335
- `plugin.approvals` wiring and onto `approvalCapability`
336
- - `ChannelPlugin.approvals` has been removed from the public channel-plugin
337
- contract; move delivery/native/render fields onto `approvalCapability`
338
- - `plugin.auth` remains for channel login/logout flows only; approval auth
339
- hooks there are no longer read by core
340
- - Register channel-owned runtime objects such as clients, tokens, or Bolt
341
- apps through `fengming/plugin-sdk/channel-runtime-context`
342
- - Do not send plugin-owned reroute notices from native approval handlers;
343
- core now owns routed-elsewhere notices from actual delivery results
344
- - When passing `channelRuntime` into `createChannelManager(...)`, provide a
345
- real `createPluginRuntime().channel` surface. Partial stubs are rejected.
346
-
347
- See `/plugins/sdk-channel-plugins` for the current approval capability
348
- layout.
349
-
350
- </Step>
351
-
352
- <Step title="Audit Windows wrapper fallback behavior">
353
- If your plugin uses `fengming/plugin-sdk/windows-spawn`, unresolved Windows
354
- `.cmd`/`.bat` wrappers now fail closed unless you explicitly pass
355
- `allowShellFallback: true`.
356
-
357
- ```typescript
358
- // Before
359
- const program = applyWindowsSpawnProgramPolicy({ candidate });
360
-
361
- // After
362
- const program = applyWindowsSpawnProgramPolicy({
363
- candidate,
364
- // Only set this for trusted compatibility callers that intentionally
365
- // accept shell-mediated fallback.
366
- allowShellFallback: true,
367
- });
368
- ```
369
-
370
- If your caller does not intentionally rely on shell fallback, do not set
371
- `allowShellFallback` and handle the thrown error instead.
372
-
373
- </Step>
374
-
375
- <Step title="Find deprecated imports">
376
- Search your plugin for imports from either deprecated surface:
377
-
378
- ```bash
379
- grep -r "plugin-sdk/compat" my-plugin/
380
- grep -r "plugin-sdk/infra-runtime" my-plugin/
381
- grep -r "plugin-sdk/config-runtime" my-plugin/
382
- grep -r "fengming/extension-api" my-plugin/
383
- ```
384
-
385
- </Step>
386
-
387
- <Step title="Replace with focused imports">
388
- Each export from the old surface maps to a specific modern import path:
389
-
390
- ```typescript
391
- // Before (deprecated backwards-compatibility layer)
392
- import {
393
- createChannelReplyPipeline,
394
- createPluginRuntimeStore,
395
- resolveControlCommandGate,
396
- } from "fengming/plugin-sdk/compat";
397
-
398
- // After (modern focused imports)
399
- import { createChannelReplyPipeline } from "fengming/plugin-sdk/channel-reply-pipeline";
400
- import { createPluginRuntimeStore } from "fengming/plugin-sdk/runtime-store";
401
- import { resolveControlCommandGate } from "fengming/plugin-sdk/command-auth";
402
- ```
403
-
404
- For host-side helpers, use the injected plugin runtime instead of importing
405
- directly:
406
-
407
- ```typescript
408
- // Before (deprecated extension-api bridge)
409
- import { runEmbeddedAgent } from "fengming/extension-api";
410
- const result = await runEmbeddedAgent({ sessionId, prompt });
411
-
412
- // After (injected runtime)
413
- const result = await api.runtime.agent.runEmbeddedAgent({ sessionId, prompt });
414
- ```
415
-
416
- The same pattern applies to other legacy bridge helpers:
417
-
418
- | Old import | Modern equivalent |
419
- | --- | --- |
420
- | `resolveAgentDir` | `api.runtime.agent.resolveAgentDir` |
421
- | `resolveAgentWorkspaceDir` | `api.runtime.agent.resolveAgentWorkspaceDir` |
422
- | `resolveAgentIdentity` | `api.runtime.agent.resolveAgentIdentity` |
423
- | `resolveThinkingDefault` | `api.runtime.agent.resolveThinkingDefault` |
424
- | `resolveAgentTimeoutMs` | `api.runtime.agent.resolveAgentTimeoutMs` |
425
- | `ensureAgentWorkspace` | `api.runtime.agent.ensureAgentWorkspace` |
426
- | session store helpers | `api.runtime.agent.session.*` |
427
-
428
- </Step>
429
-
430
- <Step title="Replace broad infra-runtime imports">
431
- `fengming/plugin-sdk/infra-runtime` still exists for external
432
- compatibility, but new code should import the focused helper surface it
433
- actually needs:
434
-
435
- | Need | Import |
436
- | --- | --- |
437
- | System event queue helpers | `fengming/plugin-sdk/system-event-runtime` |
438
- | Heartbeat wake, event, and visibility helpers | `fengming/plugin-sdk/heartbeat-runtime` |
439
- | Pending delivery queue drain | `fengming/plugin-sdk/delivery-queue-runtime` |
440
- | Channel activity telemetry | `fengming/plugin-sdk/channel-activity-runtime` |
441
- | In-memory dedupe caches | `fengming/plugin-sdk/dedupe-runtime` |
442
- | Safe local-file/media path helpers | `fengming/plugin-sdk/file-access-runtime` |
443
- | Dispatcher-aware fetch | `fengming/plugin-sdk/runtime-fetch` |
444
- | Proxy and guarded fetch helpers | `fengming/plugin-sdk/fetch-runtime` |
445
- | SSRF dispatcher policy types | `fengming/plugin-sdk/ssrf-dispatcher` |
446
- | Approval request/resolution types | `fengming/plugin-sdk/approval-runtime` |
447
- | Approval reply payload and command helpers | `fengming/plugin-sdk/approval-reply-runtime` |
448
- | Error formatting helpers | `fengming/plugin-sdk/error-runtime` |
449
- | Transport readiness waits | `fengming/plugin-sdk/transport-ready-runtime` |
450
- | Secure token helpers | `fengming/plugin-sdk/secure-random-runtime` |
451
- | Bounded async task concurrency | `fengming/plugin-sdk/concurrency-runtime` |
452
- | Numeric coercion | `fengming/plugin-sdk/number-runtime` |
453
- | Process-local async lock | `fengming/plugin-sdk/async-lock-runtime` |
454
- | File locks | `fengming/plugin-sdk/file-lock` |
455
-
456
- Bundled plugins are scanner-guarded against `infra-runtime`, so repo code
457
- cannot regress to the broad barrel.
458
-
459
- </Step>
460
-
461
- <Step title="Migrate channel route helpers">
462
- New channel route code should use `fengming/plugin-sdk/channel-route`.
463
- The older route-key and comparable-target names remain as compatibility
464
- aliases during the migration window, but new plugins should use the route
465
- names that describe the behavior directly:
466
-
467
- | Old helper | Modern helper |
468
- | --- | --- |
469
- | `channelRouteIdentityKey(...)` | `channelRouteDedupeKey(...)` |
470
- | `channelRouteKey(...)` | `channelRouteCompactKey(...)` |
471
- | `ComparableChannelTarget` | `ChannelRouteParsedTarget` |
472
- | `comparableChannelTargetsMatch(...)` | `channelRouteTargetsMatchExact(...)` |
473
- | `comparableChannelTargetsShareRoute(...)` | `channelRouteTargetsShareConversation(...)` |
474
-
475
- The modern route helpers normalize `{ channel, to, accountId, threadId }`
476
- consistently across native approvals, reply suppression, inbound dedupe,
477
- cron delivery, and session routing.
478
-
479
- Do not add new uses of `ChannelMessagingAdapter.parseExplicitTarget` or
480
- the parser-backed loaded-route helpers (`parseExplicitTargetForLoadedChannel`
481
- or `resolveRouteTargetForLoadedChannel`) or
482
- `resolveChannelRouteTargetWithParser(...)` from `plugin-sdk/channel-route`.
483
- Those hooks are deprecated and remain only for older plugins during the
484
- migration window. New channel plugins should use
485
- `messaging.targetResolver.resolveTarget(...)` for target id normalization
486
- and directory-miss fallback, `messaging.inferTargetChatType(...)` when core
487
- needs an early peer kind, and `messaging.resolveOutboundSessionRoute(...)`
488
- for provider-native session and thread identity.
489
-
490
- </Step>
491
-
492
- <Step title="Build and test">
493
- ```bash
494
- pnpm build
495
- pnpm test -- my-plugin/
496
- ```
497
- </Step>
498
- </Steps>
499
-
500
- ## Import path reference
501
-
502
- <Accordion title="Common import path table">
503
- | Import path | Purpose | Key exports |
504
- | --- | --- | --- |
505
- | `plugin-sdk/plugin-entry` | Canonical plugin entry helper | `definePluginEntry` |
506
- | `plugin-sdk/core` | Legacy umbrella re-export for channel entry definitions/builders | `defineChannelPluginEntry`, `createChatChannelPlugin` |
507
- | `plugin-sdk/config-schema` | Root config schema export | `FengMingSchema` |
508
- | `plugin-sdk/provider-entry` | Single-provider entry helper | `defineSingleProviderPluginEntry` |
509
- | `plugin-sdk/channel-core` | Focused channel entry definitions and builders | `defineChannelPluginEntry`, `defineSetupPluginEntry`, `createChatChannelPlugin`, `createChannelPluginBase` |
510
- | `plugin-sdk/setup` | Shared setup wizard helpers | Setup translator, allowlist prompts, setup status builders |
511
- | `plugin-sdk/setup-runtime` | Setup-time runtime helpers | `createSetupTranslator`, import-safe setup patch adapters, lookup-note helpers, `promptResolvedAllowFrom`, `splitSetupEntries`, delegated setup proxies |
512
- | `plugin-sdk/setup-adapter-runtime` | Deprecated setup adapter alias | Use `plugin-sdk/setup-runtime` |
513
- | `plugin-sdk/setup-tools` | Setup tooling helpers | `formatCliCommand`, `detectBinary`, `extractArchive`, `resolveBrewExecutable`, `formatDocsLink`, `CONFIG_DIR` |
514
- | `plugin-sdk/account-core` | Multi-account helpers | Account list/config/action-gate helpers |
515
- | `plugin-sdk/account-id` | Account-id helpers | `DEFAULT_ACCOUNT_ID`, account-id normalization |
516
- | `plugin-sdk/account-resolution` | Account lookup helpers | Account lookup + default-fallback helpers |
517
- | `plugin-sdk/account-helpers` | Narrow account helpers | Account list/account-action helpers |
518
- | `plugin-sdk/channel-setup` | Setup wizard adapters | `createOptionalChannelSetupSurface`, `createOptionalChannelSetupAdapter`, `createOptionalChannelSetupWizard`, plus `DEFAULT_ACCOUNT_ID`, `createTopLevelChannelDmPolicy`, `setSetupChannelEnabled`, `splitSetupEntries` |
519
- | `plugin-sdk/channel-pairing` | DM pairing primitives | `createChannelPairingController` |
520
- | `plugin-sdk/channel-reply-pipeline` | Reply prefix, typing, and source-delivery wiring | `createChannelReplyPipeline`, `resolveChannelSourceReplyDeliveryMode` |
521
- | `plugin-sdk/channel-config-helpers` | Config adapter factories and DM access helpers | `createHybridChannelConfigAdapter`, `resolveChannelDmAccess`, `resolveChannelDmAllowFrom`, `resolveChannelDmPolicy`, `normalizeChannelDmPolicy`, `normalizeLegacyDmAliases` |
522
- | `plugin-sdk/channel-config-schema` | Config schema builders | Shared channel config schema primitives and the generic builder only |
523
- | `plugin-sdk/bundled-channel-config-schema` | Bundled config schemas | FengMing-maintained bundled plugins only; new plugins must define plugin-local schemas |
524
- | `plugin-sdk/channel-config-schema-legacy` | Deprecated bundled config schemas | Compatibility alias only; use `plugin-sdk/bundled-channel-config-schema` for maintained bundled plugins |
525
- | `plugin-sdk/telegram-command-config` | Telegram command config helpers | Command-name normalization, description trimming, duplicate/conflict validation |
526
- | `plugin-sdk/channel-policy` | Group/DM policy resolution | `resolveChannelGroupRequireMention` |
527
- | `plugin-sdk/channel-lifecycle` | Deprecated compatibility facade | Use `plugin-sdk/channel-outbound` |
528
- | `plugin-sdk/inbound-envelope` | Inbound envelope helpers | Shared route + envelope builder helpers |
529
- | `plugin-sdk/channel-inbound` | Inbound receive helpers | Context building, formatting, roots, runners, prepared reply dispatch, and dispatch predicates |
530
- | `plugin-sdk/messaging-targets` | Deprecated target parsing import path | Use `plugin-sdk/channel-targets` for generic target parsing helpers, `plugin-sdk/channel-route` for route comparison, and plugin-owned `messaging.targetResolver` / `messaging.resolveOutboundSessionRoute` for provider-specific target resolution |
531
- | `plugin-sdk/outbound-media` | Outbound media helpers | Shared outbound media loading |
532
- | `plugin-sdk/outbound-send-deps` | Deprecated compatibility facade | Use `plugin-sdk/channel-outbound` |
533
- | `plugin-sdk/channel-outbound` | Outbound message lifecycle helpers | Message adapters, receipts, durable send helpers, live preview/streaming helpers, reply options, lifecycle helpers, outbound identity, and payload planning |
534
- | `plugin-sdk/channel-streaming` | Deprecated compatibility facade | Use `plugin-sdk/channel-outbound` |
535
- | `plugin-sdk/outbound-runtime` | Deprecated compatibility facade | Use `plugin-sdk/channel-outbound` |
536
- | `plugin-sdk/thread-bindings-runtime` | Thread-binding helpers | Thread-binding lifecycle and adapter helpers |
537
- | `plugin-sdk/agent-media-payload` | Legacy media payload helpers | Agent media payload builder for legacy field layouts |
538
- | `plugin-sdk/channel-runtime` | Deprecated compatibility shim | Legacy channel runtime utilities only |
539
- | `plugin-sdk/channel-send-result` | Send result types | Reply result types |
540
- | `plugin-sdk/runtime-store` | Persistent plugin storage | `createPluginRuntimeStore` |
541
- | `plugin-sdk/runtime` | Broad runtime helpers | Runtime/logging/backup/plugin-install helpers |
542
- | `plugin-sdk/runtime-env` | Narrow runtime env helpers | Logger/runtime env, timeout, retry, and backoff helpers |
543
- | `plugin-sdk/plugin-runtime` | Shared plugin runtime helpers | Plugin commands/hooks/http/interactive helpers |
544
- | `plugin-sdk/hook-runtime` | Hook pipeline helpers | Shared webhook/internal hook pipeline helpers |
545
- | `plugin-sdk/lazy-runtime` | Lazy runtime helpers | `createLazyRuntimeModule`, `createLazyRuntimeMethod`, `createLazyRuntimeMethodBinder`, `createLazyRuntimeNamedExport`, `createLazyRuntimeSurface` |
546
- | `plugin-sdk/process-runtime` | Process helpers | Shared exec helpers |
547
- | `plugin-sdk/cli-runtime` | CLI runtime helpers | Command formatting, waits, version helpers |
548
- | `plugin-sdk/gateway-runtime` | Gateway helpers | Gateway client, event-loop-ready start helper, and channel-status patch helpers |
549
- | `plugin-sdk/config-runtime` | Deprecated config compatibility shim | Prefer `config-contracts`, `plugin-config-runtime`, `runtime-config-snapshot`, and `config-mutation` |
550
- | `plugin-sdk/telegram-command-config` | Telegram command helpers | Fallback-stable Telegram command validation helpers when the bundled Telegram contract surface is unavailable |
551
- | `plugin-sdk/approval-runtime` | Approval prompt helpers | Exec/plugin approval payload, approval capability/profile helpers, native approval routing/runtime helpers, and structured approval display path formatting |
552
- | `plugin-sdk/approval-auth-runtime` | Approval auth helpers | Approver resolution, same-chat action auth |
553
- | `plugin-sdk/approval-client-runtime` | Approval client helpers | Native exec approval profile/filter helpers |
554
- | `plugin-sdk/approval-delivery-runtime` | Approval delivery helpers | Native approval capability/delivery adapters |
555
- | `plugin-sdk/approval-gateway-runtime` | Approval gateway helpers | Shared approval gateway-resolution helper |
556
- | `plugin-sdk/approval-handler-adapter-runtime` | Approval adapter helpers | Lightweight native approval adapter loading helpers for hot channel entrypoints |
557
- | `plugin-sdk/approval-handler-runtime` | Approval handler helpers | Broader approval handler runtime helpers; prefer the narrower adapter/gateway seams when they are enough |
558
- | `plugin-sdk/approval-native-runtime` | Approval target helpers | Native approval target/account binding helpers |
559
- | `plugin-sdk/approval-reply-runtime` | Approval reply helpers | Exec/plugin approval reply payload helpers |
560
- | `plugin-sdk/channel-runtime-context` | Channel runtime-context helpers | Generic channel runtime-context register/get/watch helpers |
561
- | `plugin-sdk/security-runtime` | Security helpers | Shared trust, DM gating, root-bounded file/path helpers, external-content, and secret-collection helpers |
562
- | `plugin-sdk/ssrf-policy` | SSRF policy helpers | Host allowlist and private-network policy helpers |
563
- | `plugin-sdk/ssrf-runtime` | SSRF runtime helpers | Pinned-dispatcher, guarded fetch, SSRF policy helpers |
564
- | `plugin-sdk/system-event-runtime` | System event helpers | `enqueueSystemEvent`, `peekSystemEventEntries` |
565
- | `plugin-sdk/heartbeat-runtime` | Heartbeat helpers | Heartbeat wake, event, and visibility helpers |
566
- | `plugin-sdk/delivery-queue-runtime` | Delivery queue helpers | `drainPendingDeliveries` |
567
- | `plugin-sdk/channel-activity-runtime` | Channel activity helpers | `recordChannelActivity` |
568
- | `plugin-sdk/dedupe-runtime` | Dedupe helpers | In-memory dedupe caches |
569
- | `plugin-sdk/file-access-runtime` | File access helpers | Safe local-file/media path helpers |
570
- | `plugin-sdk/transport-ready-runtime` | Transport readiness helpers | `waitForTransportReady` |
571
- | `plugin-sdk/exec-approvals-runtime` | Exec approval policy helpers | `loadExecApprovals`, `resolveExecApprovalsFromFile`, `ExecApprovalsFile` |
572
- | `plugin-sdk/collection-runtime` | Bounded cache helpers | `pruneMapToMaxSize` |
573
- | `plugin-sdk/diagnostic-runtime` | Diagnostic gating helpers | `isDiagnosticFlagEnabled`, `isDiagnosticsEnabled` |
574
- | `plugin-sdk/error-runtime` | Error formatting helpers | `formatUncaughtError`, `isApprovalNotFoundError`, error graph helpers |
575
- | `plugin-sdk/fetch-runtime` | Wrapped fetch/proxy helpers | `resolveFetch`, proxy helpers, EnvHttpProxyAgent option helpers |
576
- | `plugin-sdk/host-runtime` | Host normalization helpers | `normalizeHostname`, `normalizeScpRemoteHost` |
577
- | `plugin-sdk/retry-runtime` | Retry helpers | `RetryConfig`, `retryAsync`, policy runners |
578
- | `plugin-sdk/allow-from` | Allowlist formatting and input mapping | `formatAllowFromLowercase`, `mapAllowlistResolutionInputs` |
579
- | `plugin-sdk/command-auth` | Command gating and command-surface helpers | `resolveControlCommandGate`, sender-authorization helpers, command registry helpers including dynamic argument menu formatting |
580
- | `plugin-sdk/command-status` | Command status/help renderers | `buildCommandsMessage`, `buildCommandsMessagePaginated`, `buildHelpMessage` |
581
- | `plugin-sdk/secret-input` | Secret input parsing | Secret input helpers |
582
- | `plugin-sdk/webhook-ingress` | Webhook request helpers | Webhook target utilities |
583
- | `plugin-sdk/webhook-request-guards` | Webhook body guard helpers | Request body read/limit helpers |
584
- | `plugin-sdk/reply-runtime` | Shared reply runtime | Inbound dispatch, heartbeat, reply planner, chunking |
585
- | `plugin-sdk/reply-dispatch-runtime` | Narrow reply dispatch helpers | Finalize, provider dispatch, and conversation-label helpers |
586
- | `plugin-sdk/reply-history` | Reply-history helpers | `createChannelHistoryWindow`; deprecated map-helper compatibility exports such as `buildPendingHistoryContextFromMap`, `recordPendingHistoryEntry`, and `clearHistoryEntriesIfEnabled` |
587
- | `plugin-sdk/reply-reference` | Reply reference planning | `createReplyReferencePlanner` |
588
- | `plugin-sdk/reply-chunking` | Reply chunk helpers | Text/markdown chunking helpers |
589
- | `plugin-sdk/session-store-runtime` | Session store helpers | Store path + updated-at helpers |
590
- | `plugin-sdk/state-paths` | State path helpers | State and OAuth dir helpers |
591
- | `plugin-sdk/routing` | Routing/session-key helpers | `resolveAgentRoute`, `buildAgentSessionKey`, `resolveDefaultAgentBoundAccountId`, session-key normalization helpers |
592
- | `plugin-sdk/status-helpers` | Channel status helpers | Channel/account status summary builders, runtime-state defaults, issue metadata helpers |
593
- | `plugin-sdk/target-resolver-runtime` | Target resolver helpers | Shared target resolver helpers |
594
- | `plugin-sdk/string-normalization-runtime` | String normalization helpers | Slug/string normalization helpers |
595
- | `plugin-sdk/request-url` | Request URL helpers | Extract string URLs from request-like inputs |
596
- | `plugin-sdk/run-command` | Timed command helpers | Timed command runner with normalized stdout/stderr |
597
- | `plugin-sdk/param-readers` | Param readers | Common tool/CLI param readers |
598
- | `plugin-sdk/tool-payload` | Tool payload extraction | Extract normalized payloads from tool result objects |
599
- | `plugin-sdk/tool-send` | Tool send extraction | Extract canonical send target fields from tool args |
600
- | `plugin-sdk/temp-path` | Temp path helpers | Shared temp-download path helpers |
601
- | `plugin-sdk/logging-core` | Logging helpers | Subsystem logger and redaction helpers |
602
- | `plugin-sdk/markdown-table-runtime` | Markdown-table helpers | Markdown table mode helpers |
603
- | `plugin-sdk/reply-payload` | Message reply types | Reply payload types |
604
- | `plugin-sdk/provider-setup` | Curated local/self-hosted provider setup helpers | Self-hosted provider discovery/config helpers |
605
- | `plugin-sdk/self-hosted-provider-setup` | Focused OpenAI-compatible self-hosted provider setup helpers | Same self-hosted provider discovery/config helpers |
606
- | `plugin-sdk/provider-auth-runtime` | Provider runtime auth helpers | Runtime API-key resolution helpers |
607
- | `plugin-sdk/provider-auth-api-key` | Provider API-key setup helpers | API-key onboarding/profile-write helpers |
608
- | `plugin-sdk/provider-auth-result` | Provider auth-result helpers | Standard OAuth auth-result builder |
609
- | `plugin-sdk/provider-selection-runtime` | Provider selection helpers | Configured-or-auto provider selection and raw provider config merging |
610
- | `plugin-sdk/provider-env-vars` | Provider env-var helpers | Provider auth env-var lookup helpers |
611
- | `plugin-sdk/provider-model-shared` | Shared provider model/replay helpers | `ProviderReplayFamily`, `buildProviderReplayFamilyHooks`, `normalizeModelCompat`, shared replay-policy builders, provider-endpoint helpers, and model-id normalization helpers |
612
- | `plugin-sdk/provider-catalog-shared` | Shared provider catalog helpers | `findCatalogTemplate`, `buildSingleProviderApiKeyCatalog`, `buildManifestModelProviderConfig`, `supportsNativeStreamingUsageCompat`, `applyProviderNativeStreamingUsageCompat` |
613
- | `plugin-sdk/provider-onboard` | Provider onboarding patches | Onboarding config helpers |
614
- | `plugin-sdk/provider-http` | Provider HTTP helpers | Generic provider HTTP/endpoint capability helpers, including audio transcription multipart form helpers |
615
- | `plugin-sdk/provider-web-fetch` | Provider web-fetch helpers | Web-fetch provider registration/cache helpers |
616
- | `plugin-sdk/provider-web-search-config-contract` | Provider web-search config helpers | Narrow web-search config/credential helpers for providers that do not need plugin-enable wiring |
617
- | `plugin-sdk/provider-web-search-contract` | Provider web-search contract helpers | Narrow web-search config/credential contract helpers such as `createWebSearchProviderContractFields`, `enablePluginInConfig`, `resolveProviderWebSearchPluginConfig`, and scoped credential setters/getters |
618
- | `plugin-sdk/provider-web-search` | Provider web-search helpers | Web-search provider registration/cache/runtime helpers |
619
- | `plugin-sdk/provider-tools` | Provider tool/schema compat helpers | `ProviderToolCompatFamily`, `buildProviderToolCompatFamilyHooks`, and DeepSeek/Gemini/OpenAI schema cleanup + diagnostics |
620
- | `plugin-sdk/provider-usage` | Provider usage helpers | `fetchClaudeUsage`, `fetchGeminiUsage`, `fetchGithubCopilotUsage`, and other provider usage helpers |
621
- | `plugin-sdk/provider-stream` | Provider stream wrapper helpers | `ProviderStreamFamily`, `buildProviderStreamFamilyHooks`, `composeProviderStreamWrappers`, stream wrapper types, and shared Anthropic/Bedrock/DeepSeek V4/Google/Kilocode/Moonshot/OpenAI/OpenRouter/Z.A.I/MiniMax/Copilot wrapper helpers |
622
- | `plugin-sdk/provider-transport-runtime` | Provider transport helpers | Native provider transport helpers such as guarded fetch, transport message transforms, and writable transport event streams |
623
- | `plugin-sdk/keyed-async-queue` | Ordered async queue | `KeyedAsyncQueue` |
624
- | `plugin-sdk/media-runtime` | Shared media helpers | Media fetch/transform/store helpers, ffprobe-backed video dimension probing, and media payload builders |
625
- | `plugin-sdk/media-generation-runtime` | Shared media-generation helpers | Shared failover helpers, candidate selection, and missing-model messaging for image/video/music generation |
626
- | `plugin-sdk/media-understanding` | Media-understanding helpers | Media understanding provider types plus provider-facing image/audio helper exports |
627
- | `plugin-sdk/text-runtime` | Deprecated broad text compatibility export | Use `string-coerce-runtime`, `text-chunking`, `text-utility-runtime`, and `logging-core` |
628
- | `plugin-sdk/text-chunking` | Text chunking helpers | Outbound text chunking helper |
629
- | `plugin-sdk/speech` | Speech helpers | Speech provider types plus provider-facing directive, registry, validation helpers, and OpenAI-compatible TTS builder |
630
- | `plugin-sdk/speech-core` | Shared speech core | Speech provider types, registry, directives, normalization |
631
- | `plugin-sdk/realtime-transcription` | Realtime transcription helpers | Provider types, registry helpers, and shared WebSocket session helper |
632
- | `plugin-sdk/realtime-voice` | Realtime voice helpers | Provider types, registry/resolution helpers, bridge session helpers, shared agent talk-back queues, active-run voice control, transcript/event health, echo suppression, consult question matching, forced-consult coordination, turn-context tracking, output activity tracking, and fast context consult helpers |
633
- | `plugin-sdk/image-generation` | Image-generation helpers | Image generation provider types plus image asset/data URL helpers and the OpenAI-compatible image provider builder |
634
- | `plugin-sdk/image-generation-core` | Shared image-generation core | Image-generation types, failover, auth, and registry helpers |
635
- | `plugin-sdk/music-generation` | Music-generation helpers | Music-generation provider/request/result types |
636
- | `plugin-sdk/music-generation-core` | Shared music-generation core | Music-generation types, failover helpers, provider lookup, and model-ref parsing |
637
- | `plugin-sdk/video-generation` | Video-generation helpers | Video-generation provider/request/result types |
638
- | `plugin-sdk/video-generation-core` | Shared video-generation core | Video-generation types, failover helpers, provider lookup, and model-ref parsing |
639
- | `plugin-sdk/interactive-runtime` | Interactive reply helpers | Interactive reply payload normalization/reduction |
640
- | `plugin-sdk/channel-config-primitives` | Channel config primitives | Narrow channel config-schema primitives |
641
- | `plugin-sdk/channel-config-writes` | Channel config-write helpers | Channel config-write authorization helpers |
642
- | `plugin-sdk/channel-plugin-common` | Shared channel prelude | Shared channel plugin prelude exports |
643
- | `plugin-sdk/channel-status` | Channel status helpers | Shared channel status snapshot/summary helpers |
644
- | `plugin-sdk/allowlist-config-edit` | Allowlist config helpers | Allowlist config edit/read helpers |
645
- | `plugin-sdk/group-access` | Group access helpers | Shared group-access decision helpers |
646
- | `plugin-sdk/direct-dm`, `plugin-sdk/direct-dm-access` | Deprecated compatibility facades | Use `plugin-sdk/channel-inbound` |
647
- | `plugin-sdk/direct-dm-guard-policy` | Direct-DM guard helpers | Narrow pre-crypto guard policy helpers |
648
- | `plugin-sdk/extension-shared` | Shared extension helpers | Passive-channel/status and ambient proxy helper primitives |
649
- | `plugin-sdk/webhook-targets` | Webhook target helpers | Webhook target registry and route-install helpers |
650
- | `plugin-sdk/webhook-path` | Deprecated webhook path alias | Use `plugin-sdk/webhook-ingress` |
651
- | `plugin-sdk/web-media` | Shared web media helpers | Remote/local media loading helpers |
652
- | `plugin-sdk/zod` | Deprecated Zod compatibility re-export | Import `zod` from `zod` directly |
653
- | `plugin-sdk/memory-core` | Bundled memory-core helpers | Memory manager/config/file/CLI helper surface |
654
- | `plugin-sdk/memory-core-engine-runtime` | Memory engine runtime facade | Memory index/search runtime facade |
655
- | `plugin-sdk/memory-core-host-engine-foundation` | Memory host foundation engine | Memory host foundation engine exports |
656
- | `plugin-sdk/memory-core-host-engine-embeddings` | Memory host embedding engine | Memory embedding contracts, registry access, local provider, and generic batch/remote helpers; concrete remote providers live in their owning plugins |
657
- | `plugin-sdk/memory-core-host-engine-qmd` | Memory host QMD engine | Memory host QMD engine exports |
658
- | `plugin-sdk/memory-core-host-engine-storage` | Memory host storage engine | Memory host storage engine exports |
659
- | `plugin-sdk/memory-core-host-multimodal` | Memory host multimodal helpers | Memory host multimodal helpers |
660
- | `plugin-sdk/memory-core-host-query` | Memory host query helpers | Memory host query helpers |
661
- | `plugin-sdk/memory-core-host-secret` | Memory host secret helpers | Memory host secret helpers |
662
- | `plugin-sdk/memory-core-host-events` | Deprecated memory event alias | Use `plugin-sdk/memory-host-events` |
663
- | `plugin-sdk/memory-core-host-status` | Memory host status helpers | Memory host status helpers |
664
- | `plugin-sdk/memory-core-host-runtime-cli` | Memory host CLI runtime | Memory host CLI runtime helpers |
665
- | `plugin-sdk/memory-core-host-runtime-core` | Memory host core runtime | Memory host core runtime helpers |
666
- | `plugin-sdk/memory-core-host-runtime-files` | Memory host file/runtime helpers | Memory host file/runtime helpers |
667
- | `plugin-sdk/memory-host-core` | Memory host core runtime alias | Vendor-neutral alias for memory host core runtime helpers |
668
- | `plugin-sdk/memory-host-events` | Memory host event journal alias | Vendor-neutral alias for memory host event journal helpers |
669
- | `plugin-sdk/memory-host-files` | Deprecated memory file/runtime alias | Use `plugin-sdk/memory-core-host-runtime-files` |
670
- | `plugin-sdk/memory-host-markdown` | Managed markdown helpers | Shared managed-markdown helpers for memory-adjacent plugins |
671
- | `plugin-sdk/memory-host-search` | Active memory search facade | Lazy active-memory search-manager runtime facade |
672
- | `plugin-sdk/memory-host-status` | Deprecated memory host status alias | Use `plugin-sdk/memory-core-host-status` |
673
- | `plugin-sdk/testing` | Test utilities | Repo-local deprecated compatibility barrel; use focused repo-local test subpaths such as `plugin-sdk/plugin-test-runtime`, `plugin-sdk/channel-test-helpers`, `plugin-sdk/channel-target-testing`, `plugin-sdk/test-env`, and `plugin-sdk/test-fixtures` |
674
- </Accordion>
675
-
676
- This table is intentionally the common migration subset, not the full SDK
677
- surface. The compiler entrypoint inventory lives in
678
- `scripts/lib/plugin-sdk-entrypoints.json`; package exports are generated from
679
- the public subset.
680
-
681
- Reserved bundled-plugin helper seams have been retired from the public SDK
682
- export map except for explicitly documented compatibility facades such as the
683
- deprecated `plugin-sdk/discord` shim retained for the published
684
- `@fengming/discord@2026.3.13` package. Owner-specific helpers live inside the
685
- owning plugin package; shared host behavior should move through generic SDK
686
- contracts such as `plugin-sdk/gateway-runtime`, `plugin-sdk/security-runtime`,
687
- and `plugin-sdk/plugin-config-runtime`.
688
-
689
- Use the narrowest import that matches the job. If you cannot find an export,
690
- check the source at `src/plugin-sdk/` or ask maintainers which generic contract
691
- should own it.
692
-
693
- ## Active deprecations
694
-
695
- Narrower deprecations that apply across the plugin SDK, provider contract,
696
- runtime surface, and manifest. Each one still works today but will be removed
697
- in a future major release. The entry below every item maps the old API to its
698
- canonical replacement.
699
-
700
- <AccordionGroup>
701
- <Accordion title="command-auth help builders → command-status">
702
- **Old (`fengming/plugin-sdk/command-auth`)**: `buildCommandsMessage`,
703
- `buildCommandsMessagePaginated`, `buildHelpMessage`.
704
-
705
- **New (`fengming/plugin-sdk/command-status`)**: same signatures, same
706
- exports - just imported from the narrower subpath. `command-auth`
707
- re-exports them as compat stubs.
708
-
709
- ```typescript
710
- // Before
711
- import { buildHelpMessage } from "fengming/plugin-sdk/command-auth";
712
-
713
- // After
714
- import { buildHelpMessage } from "fengming/plugin-sdk/command-status";
715
- ```
716
-
717
- </Accordion>
718
-
719
- <Accordion title="Mention gating helpers → resolveInboundMentionDecision">
720
- **Old**: `resolveInboundMentionRequirement({ facts, policy })` and
721
- `shouldDropInboundForMention(...)` from
722
- `fengming/plugin-sdk/channel-inbound` or
723
- `fengming/plugin-sdk/channel-mention-gating`.
724
-
725
- **New**: `resolveInboundMentionDecision({ facts, policy })` - returns a
726
- single decision object instead of two split calls.
727
-
728
- Downstream channel plugins (Slack, Discord, Matrix, MS Teams) have already
729
- switched.
730
-
731
- </Accordion>
732
-
733
- <Accordion title="Channel runtime shim and channel actions helpers">
734
- `fengming/plugin-sdk/channel-runtime` is a compatibility shim for older
735
- channel plugins. Do not import it from new code; use
736
- `fengming/plugin-sdk/channel-runtime-context` for registering runtime
737
- objects.
738
-
739
- `channelActions*` helpers in `fengming/plugin-sdk/channel-actions` are
740
- deprecated alongside raw "actions" channel exports. Expose capabilities
741
- through the semantic `presentation` surface instead - channel plugins
742
- declare what they render (cards, buttons, selects) rather than which raw
743
- action names they accept.
744
-
745
- </Accordion>
746
-
747
- <Accordion title="Web search provider tool() helper → createTool() on the plugin">
748
- **Old**: `tool()` factory from `fengming/plugin-sdk/provider-web-search`.
749
-
750
- **New**: implement `createTool(...)` directly on the provider plugin.
751
- FengMing no longer needs the SDK helper to register the tool wrapper.
752
-
753
- </Accordion>
754
-
755
- <Accordion title="Plaintext channel envelopes → BodyForAgent">
756
- **Old**: `formatInboundEnvelope(...)` (and
757
- `ChannelMessageForAgent.channelEnvelope`) to build a flat plaintext prompt
758
- envelope from inbound channel messages.
759
-
760
- **New**: `BodyForAgent` plus structured user-context blocks. Channel
761
- plugins attach routing metadata (thread, topic, reply-to, reactions) as
762
- typed fields instead of concatenating them into a prompt string. The
763
- `formatAgentEnvelope(...)` helper is still supported for synthesized
764
- assistant-facing envelopes, but inbound plaintext envelopes are on the
765
- way out.
766
-
767
- Affected areas: `inbound_claim`, `message_received`, and any custom
768
- channel plugin that post-processed `channelEnvelope` text.
769
-
770
- </Accordion>
771
-
772
- <Accordion title="deactivate hook → gateway_stop">
773
- **Old**: `api.on("deactivate", handler)`.
774
-
775
- **New**: `api.on("gateway_stop", handler)`. The event and context are the
776
- same shutdown cleanup contract; only the hook name changes.
777
-
778
- ```typescript
779
- // Before
780
- api.on("deactivate", async (event, ctx) => {
781
- await stopPluginService(ctx);
782
- });
783
-
784
- // After
785
- api.on("gateway_stop", async (event, ctx) => {
786
- await stopPluginService(ctx);
787
- });
788
- ```
789
-
790
- `deactivate` remains wired as a deprecated compatibility alias until after
791
- 2026-08-16.
792
-
793
- </Accordion>
794
-
795
- <Accordion title="Provider discovery types → provider catalog types">
796
- Four discovery type aliases are now thin wrappers over the
797
- catalog-era types:
798
-
799
- | Old alias | New type |
800
- | ------------------------- | ------------------------- |
801
- | `ProviderDiscoveryOrder` | `ProviderCatalogOrder` |
802
- | `ProviderDiscoveryContext`| `ProviderCatalogContext` |
803
- | `ProviderDiscoveryResult` | `ProviderCatalogResult` |
804
- | `ProviderPluginDiscovery` | `ProviderPluginCatalog` |
805
-
806
- Plus the legacy `ProviderCapabilities` static bag - provider plugins
807
- should use explicit provider hooks such as `buildReplayPolicy`,
808
- `normalizeToolSchemas`, and `wrapStreamFn` rather than a static object.
809
-
810
- </Accordion>
811
-
812
- <Accordion title="Thinking policy hooks → resolveThinkingProfile">
813
- **Old** (three separate hooks on `ProviderThinkingPolicy`):
814
- `isBinaryThinking(ctx)`, `supportsXHighThinking(ctx)`, and
815
- `resolveDefaultThinkingLevel(ctx)`.
816
-
817
- **New**: a single `resolveThinkingProfile(ctx)` that returns a
818
- `ProviderThinkingProfile` with the canonical `id`, optional `label`, and
819
- ranked level list. FengMing downgrades stale stored values by profile
820
- rank automatically.
821
-
822
- The context includes `provider`, `modelId`, optional merged `reasoning`,
823
- and optional merged model `compat` facts. Provider plugins can use those
824
- catalog facts to expose a model-specific profile only when the configured
825
- request contract supports it.
826
-
827
- Implement one hook instead of three. The legacy hooks keep working during
828
- the deprecation window but are not composed with the profile result.
829
-
830
- </Accordion>
831
-
832
- <Accordion title="External auth providers → contracts.externalAuthProviders">
833
- **Old**: implementing external auth hooks without declaring the provider
834
- in the plugin manifest.
835
-
836
- **New**: declare `contracts.externalAuthProviders` in the plugin manifest
837
- **and** implement `resolveExternalAuthProfiles(...)`.
838
-
839
- ```json
840
- {
841
- "contracts": {
842
- "externalAuthProviders": ["anthropic", "openai"]
843
- }
844
- }
845
- ```
846
-
847
- </Accordion>
848
-
849
- <Accordion title="Provider env-var lookup → setup.providers[].envVars">
850
- **Old** manifest field: `providerAuthEnvVars: { anthropic: ["ANTHROPIC_API_KEY"] }`.
851
-
852
- **New**: mirror the same env-var lookup into `setup.providers[].envVars`
853
- on the manifest. This consolidates setup/status env metadata in one
854
- place and avoids booting the plugin runtime just to answer env-var
855
- lookups.
856
-
857
- `providerAuthEnvVars` remains supported through a compatibility adapter
858
- until the deprecation window closes.
859
-
860
- </Accordion>
861
-
862
- <Accordion title="Memory plugin registration → registerMemoryCapability">
863
- **Old**: three separate calls -
864
- `api.registerMemoryPromptSection(...)`,
865
- `api.registerMemoryFlushPlan(...)`,
866
- `api.registerMemoryRuntime(...)`.
867
-
868
- **New**: one call on the memory-state API -
869
- `registerMemoryCapability(pluginId, { promptBuilder, flushPlanResolver, runtime })`.
870
-
871
- Same slots, single registration call. Additive prompt and corpus helpers
872
- (`registerMemoryPromptSupplement`, `registerMemoryCorpusSupplement`) are
873
- not affected.
874
-
875
- </Accordion>
876
-
877
- <Accordion title="Memory embedding provider API">
878
- **Old**: `api.registerMemoryEmbeddingProvider(...)` plus
879
- `contracts.memoryEmbeddingProviders`.
880
-
881
- **New**: `api.registerEmbeddingProvider(...)` plus
882
- `contracts.embeddingProviders`.
883
-
884
- The generic embedding provider contract is reusable outside memory and is
885
- the supported path for new providers. The memory-specific registration API
886
- remains wired as deprecated compatibility while existing providers migrate.
887
- Plugin inspection reports non-bundled usage as compatibility debt.
888
-
889
- </Accordion>
890
-
891
- <Accordion title="Subagent session messages types renamed">
892
- Two legacy type aliases still exported from `src/plugins/runtime/types.ts`:
893
-
894
- | Old | New |
895
- | ----------------------------- | ------------------------------- |
896
- | `SubagentReadSessionParams` | `SubagentGetSessionMessagesParams` |
897
- | `SubagentReadSessionResult` | `SubagentGetSessionMessagesResult` |
898
-
899
- The runtime method `readSession` is deprecated in favor of
900
- `getSessionMessages`. Same signature; the old method calls through to the
901
- new one.
902
-
903
- </Accordion>
904
-
905
- <Accordion title="runtime.tasks.flow → runtime.tasks.managedFlows">
906
- **Old**: `runtime.tasks.flow` (singular) returned a live task-flow accessor.
907
-
908
- **New**: `runtime.tasks.managedFlows` keeps the managed TaskFlow mutation
909
- runtime for plugins that create, update, cancel, or run child tasks from a
910
- flow. Use `runtime.tasks.flows` when the plugin only needs DTO-based reads.
911
-
912
- ```typescript
913
- // Before
914
- const flow = api.runtime.tasks.flow.fromToolContext(ctx);
915
- // After
916
- const flow = api.runtime.tasks.managedFlows.fromToolContext(ctx);
917
- ```
918
-
919
- </Accordion>
920
-
921
- <Accordion title="Embedded extension factories → agent tool-result middleware">
922
- Covered in "How to migrate → Migrate embedded tool-result extensions to
923
- middleware" above. Included here for completeness: the removed embedded-runner-only
924
- `api.registerEmbeddedExtensionFactory(...)` path is replaced by
925
- `api.registerAgentToolResultMiddleware(...)` with an explicit runtime
926
- list in `contracts.agentToolResultMiddleware`.
927
- </Accordion>
928
-
929
- <Accordion title="FengMingSchemaType alias → FengMingConfig">
930
- `FengMingSchemaType` re-exported from `fengming/plugin-sdk` is now a
931
- one-line alias for `FengMingConfig`. Prefer the canonical name.
932
-
933
- ```typescript
934
- // Before
935
- import type { FengMingSchemaType } from "fengming/plugin-sdk";
936
- // After
937
- import type { FengMingConfig } from "fengming/plugin-sdk/config-schema";
938
- ```
939
-
940
- </Accordion>
941
- </AccordionGroup>
942
-
943
- <Note>
944
- Extension-level deprecations (inside bundled channel/provider plugins under
945
- `extensions/`) are tracked inside their own `api.ts` and `runtime-api.ts`
946
- barrels. They do not affect third-party plugin contracts and are not listed
947
- here. If you consume a bundled plugin's local barrel directly, read the
948
- deprecation comments in that barrel before upgrading.
949
- </Note>
950
-
951
- ## Removal timeline
952
-
953
- | When | What happens |
954
- | ---------------------- | ----------------------------------------------------------------------- |
955
- | **Now** | Deprecated surfaces emit runtime warnings |
956
- | **Next major release** | Deprecated surfaces will be removed; plugins still using them will fail |
957
-
958
- All core plugins have already been migrated. External plugins should migrate
959
- before the next major release.
960
-
961
- ## Suppressing the warnings temporarily
962
-
963
- Set these environment variables while you work on migrating:
964
-
965
- ```bash
966
- FENGMING_SUPPRESS_PLUGIN_SDK_COMPAT_WARNING=1 fengming gateway run
967
- FENGMING_SUPPRESS_EXTENSION_API_WARNING=1 fengming gateway run
968
- ```
969
-
970
- This is a temporary escape hatch, not a permanent solution.
971
-
972
- ## Related
973
-
974
- - [Getting Started](/plugins/building-plugins) - build your first plugin
975
- - [SDK Overview](/plugins/sdk-overview) - full subpath import reference
976
- - [Channel Plugins](/plugins/sdk-channel-plugins) - building channel plugins
977
- - [Provider Plugins](/plugins/sdk-provider-plugins) - building provider plugins
978
- - [Plugin Internals](/plugins/architecture) - architecture deep dive
979
- - [Plugin Manifest](/plugins/manifest) - manifest schema reference