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,774 +0,0 @@
1
- ---
2
- summary: "Tools config (policy, experimental toggles, provider-backed tools) and custom provider/base-URL setup"
3
- read_when:
4
- - Configuring `tools.*` policy, allowlists, or experimental features
5
- - Registering custom providers or overriding base URLs
6
- - Setting up OpenAI-compatible self-hosted endpoints
7
- title: "Configuration — tools and custom providers"
8
- sidebarTitle: "Tools and custom providers"
9
- ---
10
-
11
- `tools.*` config keys and custom provider / base-URL setup. For agents, channels, and other top-level config keys, see [Configuration reference](/gateway/configuration-reference).
12
-
13
- ## Tools
14
-
15
- ### Tool profiles
16
-
17
- `tools.profile` sets a base allowlist before `tools.allow`/`tools.deny`:
18
-
19
- <Note>
20
- Local onboarding defaults new local configs to `tools.profile: "coding"` when unset (existing explicit profiles are preserved).
21
- </Note>
22
-
23
- | Profile | Includes |
24
- | ----------- | ------------------------------------------------------------------------------------------------------------------------------- |
25
- | `minimal` | `session_status` only |
26
- | `coding` | `group:fs`, `group:runtime`, `group:web`, `group:sessions`, `group:memory`, `cron`, `image`, `image_generate`, `video_generate` |
27
- | `messaging` | `group:messaging`, `sessions_list`, `sessions_history`, `sessions_send`, `session_status` |
28
- | `full` | No restriction (same as unset) |
29
-
30
- ### Tool groups
31
-
32
- | Group | Tools |
33
- | ------------------ | ----------------------------------------------------------------------------------------------------------------------- |
34
- | `group:runtime` | `exec`, `process`, `code_execution` (`bash` is accepted as an alias for `exec`) |
35
- | `group:fs` | `read`, `write`, `edit`, `apply_patch` |
36
- | `group:sessions` | `sessions_list`, `sessions_history`, `sessions_send`, `sessions_spawn`, `sessions_yield`, `subagents`, `session_status` |
37
- | `group:memory` | `memory_search`, `memory_get` |
38
- | `group:web` | `web_search`, `x_search`, `web_fetch` |
39
- | `group:ui` | `browser`, `canvas` |
40
- | `group:automation` | `heartbeat_respond`, `cron`, `gateway` |
41
- | `group:messaging` | `message` |
42
- | `group:nodes` | `nodes` |
43
- | `group:agents` | `agents_list`, `update_plan` |
44
- | `group:media` | `image`, `image_generate`, `music_generate`, `video_generate`, `tts` |
45
- | `group:fengming` | All built-in tools (excludes provider plugins) |
46
- | `group:plugins` | Tools owned by loaded plugins, including configured MCP servers exposed through `bundle-mcp` |
47
-
48
- ### MCP and plugin tools inside sandbox tool policy
49
-
50
- Configured MCP servers are exposed as plugin-owned tools under the `bundle-mcp` plugin id. Normal tool profiles can allow them, but `tools.sandbox.tools` is an additional gate for sandboxed sessions. If sandbox mode is `"all"` or `"non-main"`, include one of these entries in the sandbox tool allowlist when MCP/plugin tools should be visible:
51
-
52
- - `bundle-mcp` for FengMing-managed MCP servers from `mcp.servers`
53
- - the plugin id for a specific native plugin
54
- - `group:plugins` for all loaded plugin-owned tools
55
- - exact MCP server tool names or server globs such as `outlook__send_mail` or `outlook__*` when you only want one server
56
-
57
- Server globs use the provider-safe MCP server prefix, not necessarily the raw `mcp.servers` key. Non-`[A-Za-z0-9_-]` characters become `-`, names that do not start with a letter get an `mcp-` prefix, and long or duplicate prefixes may be truncated or suffixed; for example, `mcp.servers["Outlook Graph"]` uses a glob like `outlook-graph__*`.
58
-
59
- ```json5
60
- {
61
- agents: { defaults: { sandbox: { mode: "all" } } },
62
- mcp: {
63
- servers: {
64
- outlook: { command: "node", args: ["./outlook-mcp.js"] },
65
- },
66
- },
67
- tools: {
68
- sandbox: {
69
- tools: {
70
- alsoAllow: ["web_search", "web_fetch", "memory_search", "memory_get", "bundle-mcp"],
71
- },
72
- },
73
- },
74
- }
75
- ```
76
-
77
- Without that sandbox-layer entry, the MCP server can still load successfully while its tools are filtered before the provider request. Use `fengming doctor` to catch this shape for FengMing-managed servers in `mcp.servers`. MCP servers loaded from bundled plugin manifests or Claude `.mcp.json` use the same sandbox gate, but this diagnostic does not enumerate those sources yet; use the same allowlist entries if their tools disappear in sandboxed turns.
78
-
79
- ### `tools.allow` / `tools.deny`
80
-
81
- Global tool allow/deny policy (deny wins). Case-insensitive, supports `*` wildcards. Applied even when Docker sandbox is off.
82
-
83
- ```json5
84
- {
85
- tools: { deny: ["browser", "canvas"] },
86
- }
87
- ```
88
-
89
- `write` and `apply_patch` are separate tool ids. `allow: ["write"]` also enables `apply_patch` for compatible models, but `deny: ["write"]` does not deny `apply_patch`. To block all file mutation, deny `group:fs` or list each mutating tool explicitly:
90
-
91
- ```json5
92
- {
93
- tools: { deny: ["write", "edit", "apply_patch"] },
94
- }
95
- ```
96
-
97
- ### `tools.byProvider`
98
-
99
- Further restrict tools for specific providers or models. Order: base profile → provider profile → allow/deny.
100
-
101
- ```json5
102
- {
103
- tools: {
104
- profile: "coding",
105
- byProvider: {
106
- "google-antigravity": { profile: "minimal" },
107
- "openai/gpt-5.4": { allow: ["group:fs", "sessions_list"] },
108
- },
109
- },
110
- }
111
- ```
112
-
113
- ### `tools.toolsBySender`
114
-
115
- Restricts tools for a specific requester identity. This is defense-in-depth on top of channel access control; sender values must come from the channel adapter, not message text.
116
-
117
- ```json5
118
- {
119
- tools: {
120
- toolsBySender: {
121
- "channel:discord:1234567890123": { alsoAllow: ["group:fs"] },
122
- "id:guest-user-id": { deny: ["group:runtime", "group:fs"] },
123
- "*": { deny: ["exec", "process", "write", "edit", "apply_patch"] },
124
- },
125
- },
126
- }
127
- ```
128
-
129
- Keys use explicit prefixes: `channel:<channelId>:<senderId>`, `id:<senderId>`, `e164:<phone>`, `username:<handle>`, `name:<displayName>`, or `"*"`. Channel ids are canonical FengMing ids; aliases such as `teams` normalize to `msteams`. Legacy unprefixed keys are accepted as `id:` only. Matching order is channel+id, id, e164, username, name, then wildcard.
130
-
131
- Per-agent `agents.list[].tools.toolsBySender` overrides the global sender match when it matches, even with an empty `{}` policy.
132
-
133
- ### `tools.elevated`
134
-
135
- Controls elevated exec access outside the sandbox:
136
-
137
- ```json5
138
- {
139
- tools: {
140
- elevated: {
141
- enabled: true,
142
- allowFrom: {
143
- whatsapp: ["+15555550123"],
144
- discord: ["1234567890123", "987654321098765432"],
145
- },
146
- },
147
- },
148
- }
149
- ```
150
-
151
- - Per-agent override (`agents.list[].tools.elevated`) can only further restrict.
152
- - `/elevated on|off|ask|full` stores state per session; inline directives apply to single message.
153
- - Elevated `exec` bypasses sandboxing and uses the configured escape path (`gateway` by default, or `node` when the exec target is `node`).
154
-
155
- ### `tools.exec`
156
-
157
- ```json5
158
- {
159
- tools: {
160
- exec: {
161
- backgroundMs: 10000,
162
- timeoutSec: 1800,
163
- cleanupMs: 1800000,
164
- notifyOnExit: true,
165
- notifyOnExitEmptySuccess: false,
166
- commandHighlighting: false,
167
- applyPatch: {
168
- enabled: false,
169
- allowModels: ["gpt-5.5"],
170
- },
171
- },
172
- },
173
- }
174
- ```
175
-
176
- ### `tools.loopDetection`
177
-
178
- Tool-loop safety checks are **disabled by default**. Set `enabled: true` to activate detection. Settings can be defined globally in `tools.loopDetection` and overridden per-agent at `agents.list[].tools.loopDetection`.
179
-
180
- ```json5
181
- {
182
- tools: {
183
- loopDetection: {
184
- enabled: true,
185
- historySize: 30,
186
- warningThreshold: 10,
187
- criticalThreshold: 20,
188
- globalCircuitBreakerThreshold: 30,
189
- detectors: {
190
- genericRepeat: true,
191
- knownPollNoProgress: true,
192
- pingPong: true,
193
- },
194
- },
195
- },
196
- }
197
- ```
198
-
199
- <ParamField path="historySize" type="number">
200
- Max tool-call history retained for loop analysis.
201
- </ParamField>
202
- <ParamField path="warningThreshold" type="number">
203
- Repeating no-progress pattern threshold for warnings.
204
- </ParamField>
205
- <ParamField path="criticalThreshold" type="number">
206
- Higher repeating threshold for blocking critical loops.
207
- </ParamField>
208
- <ParamField path="globalCircuitBreakerThreshold" type="number">
209
- Hard stop threshold for any no-progress run.
210
- </ParamField>
211
- <ParamField path="detectors.genericRepeat" type="boolean">
212
- Warn on repeated same-tool/same-args calls.
213
- </ParamField>
214
- <ParamField path="detectors.knownPollNoProgress" type="boolean">
215
- Warn/block on known poll tools (`process.poll`, `command_status`, etc.).
216
- </ParamField>
217
- <ParamField path="detectors.pingPong" type="boolean">
218
- Warn/block on alternating no-progress pair patterns.
219
- </ParamField>
220
-
221
- <Warning>
222
- If `warningThreshold >= criticalThreshold` or `criticalThreshold >= globalCircuitBreakerThreshold`, validation fails.
223
- </Warning>
224
-
225
- ### `tools.web`
226
-
227
- ```json5
228
- {
229
- tools: {
230
- web: {
231
- search: {
232
- enabled: true,
233
- apiKey: "brave_api_key", // or BRAVE_API_KEY env
234
- maxResults: 5,
235
- timeoutSeconds: 30,
236
- cacheTtlMinutes: 15,
237
- },
238
- fetch: {
239
- enabled: true,
240
- provider: "firecrawl", // optional; omit for auto-detect
241
- maxChars: 50000,
242
- maxCharsCap: 50000,
243
- maxResponseBytes: 2000000,
244
- timeoutSeconds: 30,
245
- cacheTtlMinutes: 15,
246
- maxRedirects: 3,
247
- readability: true,
248
- userAgent: "custom-ua",
249
- },
250
- },
251
- },
252
- }
253
- ```
254
-
255
- ### `tools.media`
256
-
257
- Configures inbound media understanding (image/audio/video):
258
-
259
- ```json5
260
- {
261
- tools: {
262
- media: {
263
- concurrency: 2,
264
- asyncCompletion: {
265
- directSend: false, // deprecated: completions stay agent-mediated
266
- },
267
- audio: {
268
- enabled: true,
269
- maxBytes: 20971520,
270
- scope: {
271
- default: "deny",
272
- rules: [{ action: "allow", match: { chatType: "direct" } }],
273
- },
274
- models: [
275
- { provider: "openai", model: "gpt-4o-mini-transcribe" },
276
- { type: "cli", command: "whisper", args: ["--model", "base", "{{MediaPath}}"] },
277
- ],
278
- },
279
- image: {
280
- enabled: true,
281
- timeoutSeconds: 180,
282
- models: [{ provider: "ollama", model: "gemma4:26b", timeoutSeconds: 300 }],
283
- },
284
- video: {
285
- enabled: true,
286
- maxBytes: 52428800,
287
- models: [{ provider: "google", model: "gemini-3-flash-preview" }],
288
- },
289
- },
290
- },
291
- }
292
- ```
293
-
294
- <AccordionGroup>
295
- <Accordion title="Media model entry fields">
296
- **Provider entry** (`type: "provider"` or omitted):
297
-
298
- - `provider`: API provider id (`openai`, `anthropic`, `google`/`gemini`, `groq`, etc.)
299
- - `model`: model id override
300
- - `profile` / `preferredProfile`: `auth-profiles.json` profile selection
301
-
302
- **CLI entry** (`type: "cli"`):
303
-
304
- - `command`: executable to run
305
- - `args`: templated args (supports `{{MediaPath}}`, `{{Prompt}}`, `{{MaxChars}}`, etc.; `fengming doctor --fix` migrates deprecated `{input}` placeholders to `{{MediaPath}}`)
306
-
307
- **Common fields:**
308
-
309
- - `capabilities`: optional list (`image`, `audio`, `video`). Defaults: `openai`/`anthropic`/`minimax` → image, `google` → image+audio+video, `groq` → audio.
310
- - `prompt`, `maxChars`, `maxBytes`, `timeoutSeconds`, `language`: per-entry overrides.
311
- - `tools.media.image.timeoutSeconds` and matching image model `timeoutSeconds` entries also apply when the agent calls the explicit `image` tool.
312
- - Failures fall back to the next entry.
313
-
314
- Provider auth follows standard order: `auth-profiles.json` → env vars → `models.providers.*.apiKey`.
315
-
316
- **Async completion fields:**
317
-
318
- - `asyncCompletion.directSend`: deprecated compatibility flag. Completed async media tasks stay requester-session mediated so the agent receives the result, decides how to tell the user, and uses the message tool when source delivery requires it.
319
-
320
- </Accordion>
321
- </AccordionGroup>
322
-
323
- ### `tools.agentToAgent`
324
-
325
- ```json5
326
- {
327
- tools: {
328
- agentToAgent: {
329
- enabled: false,
330
- allow: ["home", "work"],
331
- },
332
- },
333
- }
334
- ```
335
-
336
- ### `tools.sessions`
337
-
338
- Controls which sessions can be targeted by the session tools (`sessions_list`, `sessions_history`, `sessions_send`).
339
-
340
- Default: `tree` (current session + sessions spawned by it, such as subagents).
341
-
342
- ```json5
343
- {
344
- tools: {
345
- sessions: {
346
- // "self" | "tree" | "agent" | "all"
347
- visibility: "tree",
348
- },
349
- },
350
- }
351
- ```
352
-
353
- <AccordionGroup>
354
- <Accordion title="Visibility scopes">
355
- - `self`: only the current session key.
356
- - `tree`: current session + sessions spawned by the current session (subagents).
357
- - `agent`: any session belonging to the current agent id (can include other users if you run per-sender sessions under the same agent id).
358
- - `all`: any session. Cross-agent targeting still requires `tools.agentToAgent`.
359
- - Sandbox clamp: when the current session is sandboxed and `agents.defaults.sandbox.sessionToolsVisibility="spawned"`, visibility is forced to `tree` even if `tools.sessions.visibility="all"`.
360
- - When not `all`, `sessions_list` includes a compact `visibility` field
361
- describing the effective mode and a warning that some sessions may be
362
- omitted outside the current scope.
363
-
364
- </Accordion>
365
- </AccordionGroup>
366
-
367
- ### `tools.sessions_spawn`
368
-
369
- Controls inline attachment support for `sessions_spawn`.
370
-
371
- ```json5
372
- {
373
- tools: {
374
- sessions_spawn: {
375
- attachments: {
376
- enabled: false, // opt-in: set true to allow inline file attachments
377
- maxTotalBytes: 5242880, // 5 MB total across all files
378
- maxFiles: 50,
379
- maxFileBytes: 1048576, // 1 MB per file
380
- retainOnSessionKeep: false, // keep attachments when cleanup="keep"
381
- },
382
- },
383
- },
384
- }
385
- ```
386
-
387
- <AccordionGroup>
388
- <Accordion title="Attachment notes">
389
- - Attachments require `enabled: true`.
390
- - Subagent attachments are materialized into the child workspace at `.fengming/attachments/<uuid>/` with a `.manifest.json`.
391
- - ACP attachments are image-only and forwarded inline to the ACP runtime after the same file count, per-file byte, and total byte limits pass.
392
- - Attachment content is automatically redacted from transcript persistence.
393
- - Base64 inputs are validated with strict alphabet/padding checks and a pre-decode size guard.
394
- - Subagent attachment file permissions are `0700` for directories and `0600` for files.
395
- - Subagent cleanup follows the `cleanup` policy: `delete` always removes attachments; `keep` retains them only when `retainOnSessionKeep: true`.
396
-
397
- </Accordion>
398
- </AccordionGroup>
399
-
400
- <a id="toolsexperimental"></a>
401
-
402
- ### `tools.experimental`
403
-
404
- Experimental built-in tool flags. Default off unless a strict-agentic GPT-5 auto-enable rule applies.
405
-
406
- ```json5
407
- {
408
- tools: {
409
- experimental: {
410
- planTool: true, // enable experimental update_plan
411
- },
412
- },
413
- }
414
- ```
415
-
416
- - `planTool`: enables the structured `update_plan` tool for non-trivial multi-step work tracking.
417
- - Default: `false` unless `agents.defaults.embeddedAgent.executionContract` (or a per-agent override) is set to `"strict-agentic"` for an OpenAI or OpenAI Codex GPT-5-family run. Set `true` to force the tool on outside that scope, or `false` to keep it off even for strict-agentic GPT-5 runs.
418
- - When enabled, the system prompt also adds usage guidance so the model only uses it for substantial work and keeps at most one step `in_progress`.
419
-
420
- ### `agents.defaults.subagents`
421
-
422
- ```json5
423
- {
424
- agents: {
425
- defaults: {
426
- subagents: {
427
- allowAgents: ["research"],
428
- model: "minimax/MiniMax-M2.7",
429
- maxConcurrent: 8,
430
- runTimeoutSeconds: 900,
431
- announceTimeoutMs: 120000,
432
- archiveAfterMinutes: 60,
433
- },
434
- },
435
- },
436
- }
437
- ```
438
-
439
- - `model`: default model for spawned sub-agents. If omitted, sub-agents inherit the caller's model.
440
- - `allowAgents`: default allowlist of configured target agent ids for `sessions_spawn` when the requester agent does not set its own `subagents.allowAgents` (`["*"]` = any configured target; default: same agent only). Stale entries whose agent config was deleted are rejected by `sessions_spawn` and omitted from `agents_list`; run `fengming doctor --fix` to clean them up.
441
- - `runTimeoutSeconds`: default timeout (seconds) for `sessions_spawn` when the tool call omits `runTimeoutSeconds`. `0` means no timeout.
442
- - `announceTimeoutMs`: per-call timeout (milliseconds) for gateway `agent` announce delivery attempts. Default: `120000`. Transient retries can make the total announce wait longer than one configured timeout.
443
- - Per-subagent tool policy: `tools.subagents.tools.allow` / `tools.subagents.tools.deny`.
444
-
445
- ---
446
-
447
- ## Custom providers and base URLs
448
-
449
- Provider plugins publish their own model catalog rows. Add custom providers via `models.providers` in config or `~/.fengming/agents/<agentId>/agent/models.json`.
450
-
451
- Configuring a custom/local provider `baseUrl` is also the narrow network trust decision for model HTTP requests: FengMing allows that exact `scheme://host:port` origin through the guarded fetch path, without adding a separate config option or trusting other private origins.
452
-
453
- ```json5
454
- {
455
- models: {
456
- mode: "merge", // merge (default) | replace
457
- providers: {
458
- "custom-proxy": {
459
- baseUrl: "http://localhost:4000/v1",
460
- apiKey: "LITELLM_KEY",
461
- api: "openai-completions", // openai-completions | openai-responses | anthropic-messages | google-generative-ai
462
- models: [
463
- {
464
- id: "llama-3.1-8b",
465
- name: "Llama 3.1 8B",
466
- reasoning: false,
467
- input: ["text"],
468
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
469
- contextWindow: 128000,
470
- contextTokens: 96000,
471
- maxTokens: 32000,
472
- },
473
- ],
474
- },
475
- },
476
- },
477
- }
478
- ```
479
-
480
- <AccordionGroup>
481
- <Accordion title="Auth and merge precedence">
482
- - Use `authHeader: true` + `headers` for custom auth needs.
483
- - Override agent config root with `FENGMING_AGENT_DIR`.
484
- - Merge precedence for matching provider IDs:
485
- - Non-empty agent `models.json` `baseUrl` values win.
486
- - Non-empty agent `apiKey` values win only when that provider is not SecretRef-managed in current config/auth-profile context.
487
- - SecretRef-managed provider `apiKey` values are refreshed from source markers (`ENV_VAR_NAME` for env refs, `secretref-managed` for file/exec refs) instead of persisting resolved secrets.
488
- - SecretRef-managed provider header values are refreshed from source markers (`secretref-env:ENV_VAR_NAME` for env refs, `secretref-managed` for file/exec refs).
489
- - Empty or missing agent `apiKey`/`baseUrl` fall back to `models.providers` in config.
490
- - Matching model `contextWindow`/`maxTokens` use the higher value between explicit config and implicit catalog values.
491
- - Matching model `contextTokens` preserves an explicit runtime cap when present; use it to limit effective context without changing native model metadata.
492
- - Provider-plugin catalogs are stored as generated plugin-owned catalog shards under the agent's plugin state.
493
- - Use `models.mode: "replace"` when you want config to fully rewrite `models.json` and active plugin catalog shards.
494
- - Marker persistence is source-authoritative: markers are written from the active source config snapshot (pre-resolution), not from resolved runtime secret values.
495
-
496
- </Accordion>
497
- </AccordionGroup>
498
-
499
- ### Provider field details
500
-
501
- <AccordionGroup>
502
- <Accordion title="Top-level catalog">
503
- - `models.mode`: provider catalog behavior (`merge` or `replace`).
504
- - `models.providers`: custom provider map keyed by provider id.
505
- - Safe edits: use `fengming config set models.providers.<id> '<json>' --strict-json --merge` or `fengming config set models.providers.<id>.models '<json-array>' --strict-json --merge` for additive updates. `config set` refuses destructive replacements unless you pass `--replace`.
506
-
507
- </Accordion>
508
- <Accordion title="Provider connection and auth">
509
- - `models.providers.*.api`: request adapter (`openai-completions`, `openai-responses`, `anthropic-messages`, `google-generative-ai`, etc). For self-hosted `/v1/chat/completions` backends such as MLX, vLLM, SGLang, and most OpenAI-compatible local servers, use `openai-completions`. A custom provider with `baseUrl` but no `api` defaults to `openai-completions`; set `openai-responses` only when the backend supports `/v1/responses`.
510
- - `models.providers.*.apiKey`: provider credential (prefer SecretRef/env substitution).
511
- - `models.providers.*.auth`: auth strategy (`api-key`, `token`, `oauth`, `aws-sdk`).
512
- - `models.providers.*.contextWindow`: default native context window for models under this provider when the model entry does not set `contextWindow`.
513
- - `models.providers.*.contextTokens`: default effective runtime context cap for models under this provider when the model entry does not set `contextTokens`.
514
- - `models.providers.*.maxTokens`: default output-token cap for models under this provider when the model entry does not set `maxTokens`.
515
- - `models.providers.*.timeoutSeconds`: optional per-provider model HTTP request timeout in seconds, including connect, headers, body, and total request abort handling.
516
- - `models.providers.*.injectNumCtxForOpenAICompat`: for Ollama + `openai-completions`, inject `options.num_ctx` into requests (default: `true`).
517
- - `models.providers.*.authHeader`: force credential transport in the `Authorization` header when required.
518
- - `models.providers.*.baseUrl`: upstream API base URL.
519
- - `models.providers.*.headers`: extra static headers for proxy/tenant routing.
520
-
521
- </Accordion>
522
- <Accordion title="Request transport overrides">
523
- `models.providers.*.request`: transport overrides for model-provider HTTP requests.
524
-
525
- - `request.headers`: extra headers (merged with provider defaults). Values accept SecretRef.
526
- - `request.auth`: auth strategy override. Modes: `"provider-default"` (use provider's built-in auth), `"authorization-bearer"` (with `token`), `"header"` (with `headerName`, `value`, optional `prefix`).
527
- - `request.proxy`: HTTP proxy override. Modes: `"env-proxy"` (use `HTTP_PROXY`/`HTTPS_PROXY` env vars), `"explicit-proxy"` (with `url`). Both modes accept an optional `tls` sub-object.
528
- - `request.tls`: TLS override for direct connections. Fields: `ca`, `cert`, `key`, `passphrase` (all accept SecretRef), `serverName`, `insecureSkipVerify`.
529
- - `request.allowPrivateNetwork`: when `true`, allow model-provider HTTP requests to private, CGNAT, or similar ranges through the provider HTTP fetch guard. Custom/local provider base URLs already trust the exact configured origin, except metadata/link-local origins, which remain blocked without explicit opt-in. Set this to `false` to opt out of exact-origin trust. WebSocket uses the same `request` for headers/TLS but not that fetch SSRF gate. Default `false`.
530
-
531
- </Accordion>
532
- <Accordion title="Model catalog entries">
533
- - `models.providers.*.models`: explicit provider model catalog entries.
534
- - `models.providers.*.models.*.input`: model input modalities. Use `["text"]` for text-only models and `["text", "image"]` for native image/vision models. Image attachments are only injected into agent turns when the selected model is marked image-capable.
535
- - `models.providers.*.models.*.contextWindow`: native model context window metadata. This overrides provider-level `contextWindow` for that model.
536
- - `models.providers.*.models.*.contextTokens`: optional runtime context cap. This overrides provider-level `contextTokens`; use it when you want a smaller effective context budget than the model's native `contextWindow`; `fengming models list` shows both values when they differ.
537
- - `models.providers.*.models.*.compat.supportsDeveloperRole`: optional compatibility hint. For `api: "openai-completions"` with a non-empty non-native `baseUrl` (host not `api.openai.com`), FengMing forces this to `false` at runtime. Empty/omitted `baseUrl` keeps default OpenAI behavior.
538
- - `models.providers.*.models.*.compat.requiresStringContent`: optional compatibility hint for string-only OpenAI-compatible chat endpoints. When `true`, FengMing flattens pure text `messages[].content` arrays into plain strings before sending the request.
539
- - `models.providers.*.models.*.compat.strictMessageKeys`: optional compatibility hint for strict OpenAI-compatible chat endpoints. When `true`, FengMing strips outgoing Chat Completions message objects to `role` and `content` before sending the request.
540
- - `models.providers.*.models.*.compat.thinkingFormat`: optional thinking payload hint. Use `"together"` for Together-style `reasoning.enabled`, `"qwen"` for top-level `enable_thinking`, or `"qwen-chat-template"` for `chat_template_kwargs.enable_thinking` on Qwen-family OpenAI-compatible servers that support request-level chat-template kwargs, such as vLLM. Configured vLLM Qwen models expose binary `/think` choices (`off`, `on`) for these formats.
541
-
542
- </Accordion>
543
- <Accordion title="Amazon Bedrock discovery">
544
- - `plugins.entries.amazon-bedrock.config.discovery`: Bedrock auto-discovery settings root.
545
- - `plugins.entries.amazon-bedrock.config.discovery.enabled`: turn implicit discovery on/off.
546
- - `plugins.entries.amazon-bedrock.config.discovery.region`: AWS region for discovery.
547
- - `plugins.entries.amazon-bedrock.config.discovery.providerFilter`: optional provider-id filter for targeted discovery.
548
- - `plugins.entries.amazon-bedrock.config.discovery.refreshInterval`: polling interval for discovery refresh.
549
- - `plugins.entries.amazon-bedrock.config.discovery.defaultContextWindow`: fallback context window for discovered models.
550
- - `plugins.entries.amazon-bedrock.config.discovery.defaultMaxTokens`: fallback max output tokens for discovered models.
551
-
552
- </Accordion>
553
- </AccordionGroup>
554
-
555
- Interactive custom-provider onboarding infers image input for common vision model IDs such as GPT-4o, Claude, Gemini, Qwen-VL, LLaVA, Pixtral, InternVL, Mllama, MiniCPM-V, and GLM-4V, and skips the extra question for known text-only families. Unknown model IDs still prompt for image support. Non-interactive onboarding uses the same inference; pass `--custom-image-input` to force image-capable metadata or `--custom-text-input` to force text-only metadata.
556
-
557
- ### Provider examples
558
-
559
- <AccordionGroup>
560
- <Accordion title="Cerebras (GLM 4.7 / GPT OSS)">
561
- The bundled `cerebras` provider plugin can configure this via `fengming onboard --auth-choice cerebras-api-key`. Use explicit provider config only when overriding defaults.
562
-
563
- ```json5
564
- {
565
- env: { CEREBRAS_API_KEY: "sk-..." },
566
- agents: {
567
- defaults: {
568
- model: {
569
- primary: "cerebras/zai-glm-4.7",
570
- fallbacks: ["cerebras/gpt-oss-120b"],
571
- },
572
- models: {
573
- "cerebras/zai-glm-4.7": { alias: "GLM 4.7 (Cerebras)" },
574
- "cerebras/gpt-oss-120b": { alias: "GPT OSS 120B (Cerebras)" },
575
- },
576
- },
577
- },
578
- models: {
579
- mode: "merge",
580
- providers: {
581
- cerebras: {
582
- baseUrl: "https://api.cerebras.ai/v1",
583
- apiKey: "${CEREBRAS_API_KEY}",
584
- api: "openai-completions",
585
- models: [
586
- { id: "zai-glm-4.7", name: "GLM 4.7 (Cerebras)" },
587
- { id: "gpt-oss-120b", name: "GPT OSS 120B (Cerebras)" },
588
- ],
589
- },
590
- },
591
- },
592
- }
593
- ```
594
-
595
- Use `cerebras/zai-glm-4.7` for Cerebras; `zai/glm-4.7` for Z.AI direct.
596
-
597
- </Accordion>
598
- <Accordion title="Kimi Coding">
599
- ```json5
600
- {
601
- env: { KIMI_API_KEY: "sk-..." },
602
- agents: {
603
- defaults: {
604
- model: { primary: "kimi/kimi-for-coding" },
605
- models: { "kimi/kimi-for-coding": { alias: "Kimi Code" } },
606
- },
607
- },
608
- }
609
- ```
610
-
611
- Anthropic-compatible, built-in provider. Shortcut: `fengming onboard --auth-choice kimi-code-api-key`.
612
-
613
- </Accordion>
614
- <Accordion title="Local models (LM Studio)">
615
- See [Local Models](/gateway/local-models). TL;DR: run a large local model via LM Studio Responses API on serious hardware; keep hosted models merged for fallback.
616
- </Accordion>
617
- <Accordion title="MiniMax M2.7 (direct)">
618
- ```json5
619
- {
620
- agents: {
621
- defaults: {
622
- model: { primary: "minimax/MiniMax-M2.7" },
623
- models: {
624
- "minimax/MiniMax-M2.7": { alias: "Minimax" },
625
- },
626
- },
627
- },
628
- models: {
629
- mode: "merge",
630
- providers: {
631
- minimax: {
632
- baseUrl: "https://api.minimax.io/anthropic",
633
- apiKey: "${MINIMAX_API_KEY}",
634
- api: "anthropic-messages",
635
- models: [
636
- {
637
- id: "MiniMax-M2.7",
638
- name: "MiniMax M2.7",
639
- reasoning: true,
640
- input: ["text"],
641
- cost: { input: 0.3, output: 1.2, cacheRead: 0.06, cacheWrite: 0.375 },
642
- contextWindow: 204800,
643
- maxTokens: 131072,
644
- },
645
- ],
646
- },
647
- },
648
- },
649
- }
650
- ```
651
-
652
- Set `MINIMAX_API_KEY`. Shortcuts: `fengming onboard --auth-choice minimax-global-api` or `fengming onboard --auth-choice minimax-cn-api`. The model catalog defaults to M2.7 only. On the Anthropic-compatible streaming path, FengMing disables MiniMax thinking by default unless you explicitly set `thinking` yourself. `/fast on` or `params.fastMode: true` rewrites `MiniMax-M2.7` to `MiniMax-M2.7-highspeed`.
653
-
654
- </Accordion>
655
- <Accordion title="Moonshot AI (Kimi)">
656
- ```json5
657
- {
658
- env: { MOONSHOT_API_KEY: "sk-..." },
659
- agents: {
660
- defaults: {
661
- model: { primary: "moonshot/kimi-k2.6" },
662
- models: { "moonshot/kimi-k2.6": { alias: "Kimi K2.6" } },
663
- },
664
- },
665
- models: {
666
- mode: "merge",
667
- providers: {
668
- moonshot: {
669
- baseUrl: "https://api.moonshot.ai/v1",
670
- apiKey: "${MOONSHOT_API_KEY}",
671
- api: "openai-completions",
672
- models: [
673
- {
674
- id: "kimi-k2.6",
675
- name: "Kimi K2.6",
676
- reasoning: false,
677
- input: ["text", "image"],
678
- cost: { input: 0.95, output: 4, cacheRead: 0.16, cacheWrite: 0 },
679
- contextWindow: 262144,
680
- maxTokens: 262144,
681
- },
682
- ],
683
- },
684
- },
685
- },
686
- }
687
- ```
688
-
689
- For the China endpoint: `baseUrl: "https://api.moonshot.cn/v1"` or `fengming onboard --auth-choice moonshot-api-key-cn`.
690
-
691
- Native Moonshot endpoints advertise streaming usage compatibility on the shared `openai-completions` transport, and FengMing keys that off endpoint capabilities rather than the built-in provider id alone.
692
-
693
- </Accordion>
694
- <Accordion title="OpenCode">
695
- ```json5
696
- {
697
- agents: {
698
- defaults: {
699
- model: { primary: "opencode/claude-opus-4-6" },
700
- models: { "opencode/claude-opus-4-6": { alias: "Opus" } },
701
- },
702
- },
703
- }
704
- ```
705
-
706
- Set `OPENCODE_API_KEY` (or `OPENCODE_ZEN_API_KEY`). Use `opencode/...` refs for the Zen catalog or `opencode-go/...` refs for the Go catalog. Shortcut: `fengming onboard --auth-choice opencode-zen` or `fengming onboard --auth-choice opencode-go`.
707
-
708
- </Accordion>
709
- <Accordion title="Synthetic (Anthropic-compatible)">
710
- ```json5
711
- {
712
- env: { SYNTHETIC_API_KEY: "sk-..." },
713
- agents: {
714
- defaults: {
715
- model: { primary: "synthetic/hf:MiniMaxAI/MiniMax-M2.5" },
716
- models: { "synthetic/hf:MiniMaxAI/MiniMax-M2.5": { alias: "MiniMax M2.5" } },
717
- },
718
- },
719
- models: {
720
- mode: "merge",
721
- providers: {
722
- synthetic: {
723
- baseUrl: "https://api.synthetic.new/anthropic",
724
- apiKey: "${SYNTHETIC_API_KEY}",
725
- api: "anthropic-messages",
726
- models: [
727
- {
728
- id: "hf:MiniMaxAI/MiniMax-M2.5",
729
- name: "MiniMax M2.5",
730
- reasoning: true,
731
- input: ["text"],
732
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
733
- contextWindow: 192000,
734
- maxTokens: 65536,
735
- },
736
- ],
737
- },
738
- },
739
- },
740
- }
741
- ```
742
-
743
- Base URL should omit `/v1` (Anthropic client appends it). Shortcut: `fengming onboard --auth-choice synthetic-api-key`.
744
-
745
- </Accordion>
746
- <Accordion title="Z.AI (GLM-4.7)">
747
- ```json5
748
- {
749
- agents: {
750
- defaults: {
751
- model: { primary: "zai/glm-4.7" },
752
- models: { "zai/glm-4.7": {} },
753
- },
754
- },
755
- }
756
- ```
757
-
758
- Set `ZAI_API_KEY`. Model refs use the canonical `zai/*` provider ID. Shortcut: `fengming onboard --auth-choice zai-api-key`.
759
-
760
- - General endpoint: `https://api.z.ai/api/paas/v4`
761
- - Coding endpoint (default): `https://api.z.ai/api/coding/paas/v4`
762
- - For the general endpoint, define a custom provider with the base URL override.
763
-
764
- </Accordion>
765
- </AccordionGroup>
766
-
767
- ---
768
-
769
- ## Related
770
-
771
- - [Configuration — agents](/gateway/config-agents)
772
- - [Configuration — channels](/gateway/config-channels)
773
- - [Configuration reference](/gateway/configuration-reference) — other top-level keys
774
- - [Tools and plugins](/tools)