vilvona 1.0.0

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 (812) hide show
  1. package/CHANGELOG.md +12331 -0
  2. package/LICENSE +24 -0
  3. package/README.md +314 -0
  4. package/THIRD_PARTY_NOTICES.md +37 -0
  5. package/docs/.i18n/README.md +81 -0
  6. package/docs/.i18n/ar-navigation.json +18 -0
  7. package/docs/.i18n/de-navigation.json +18 -0
  8. package/docs/.i18n/es-navigation.json +18 -0
  9. package/docs/.i18n/fr-navigation.json +18 -0
  10. package/docs/.i18n/glossary.ar.json +82 -0
  11. package/docs/.i18n/glossary.de.json +82 -0
  12. package/docs/.i18n/glossary.es.json +82 -0
  13. package/docs/.i18n/glossary.fa.json +82 -0
  14. package/docs/.i18n/glossary.fr.json +82 -0
  15. package/docs/.i18n/glossary.id.json +82 -0
  16. package/docs/.i18n/glossary.it.json +82 -0
  17. package/docs/.i18n/glossary.ja-JP.json +102 -0
  18. package/docs/.i18n/glossary.ko.json +82 -0
  19. package/docs/.i18n/glossary.nl.json +82 -0
  20. package/docs/.i18n/glossary.pl.json +82 -0
  21. package/docs/.i18n/glossary.pt-BR.json +82 -0
  22. package/docs/.i18n/glossary.th.json +82 -0
  23. package/docs/.i18n/glossary.tr.json +82 -0
  24. package/docs/.i18n/glossary.uk.json +82 -0
  25. package/docs/.i18n/glossary.vi.json +82 -0
  26. package/docs/.i18n/glossary.zh-CN.json +1182 -0
  27. package/docs/.i18n/glossary.zh-TW.json +162 -0
  28. package/docs/.i18n/id-navigation.json +18 -0
  29. package/docs/.i18n/it-navigation.json +18 -0
  30. package/docs/.i18n/ja-navigation.json +18 -0
  31. package/docs/.i18n/ko-navigation.json +18 -0
  32. package/docs/.i18n/pl-navigation.json +18 -0
  33. package/docs/.i18n/pt-BR-navigation.json +18 -0
  34. package/docs/.i18n/tr-navigation.json +18 -0
  35. package/docs/.i18n/translation-workflow.md +111 -0
  36. package/docs/.i18n/zh-Hans-navigation.json +552 -0
  37. package/docs/AGENTS.md +36 -0
  38. package/docs/agent-runtime-architecture.md +48 -0
  39. package/docs/announcements/bluebubbles-imessage.md +79 -0
  40. package/docs/auth-credential-semantics.md +124 -0
  41. package/docs/automation/auth-monitoring.md +11 -0
  42. package/docs/automation/clawflow.md +12 -0
  43. package/docs/automation/cron-jobs.md +569 -0
  44. package/docs/automation/cron-vs-heartbeat.md +11 -0
  45. package/docs/automation/gmail-pubsub.md +11 -0
  46. package/docs/automation/hooks.md +387 -0
  47. package/docs/automation/index.md +135 -0
  48. package/docs/automation/poll.md +12 -0
  49. package/docs/automation/standing-orders.md +250 -0
  50. package/docs/automation/taskflow.md +155 -0
  51. package/docs/automation/tasks.md +374 -0
  52. package/docs/automation/troubleshooting.md +12 -0
  53. package/docs/automation/webhook.md +12 -0
  54. package/docs/brave-search.md +11 -0
  55. package/docs/channels/access-groups.md +201 -0
  56. package/docs/channels/ambient-room-events.md +214 -0
  57. package/docs/channels/bot-loop-protection.md +131 -0
  58. package/docs/channels/broadcast-groups.md +472 -0
  59. package/docs/channels/channel-routing.md +162 -0
  60. package/docs/channels/clickclack.md +146 -0
  61. package/docs/channels/discord.md +1758 -0
  62. package/docs/channels/feishu.md +654 -0
  63. package/docs/channels/googlechat.md +286 -0
  64. package/docs/channels/group-messages.md +95 -0
  65. package/docs/channels/groups.md +610 -0
  66. package/docs/channels/imessage-from-bluebubbles.md +259 -0
  67. package/docs/channels/imessage.md +864 -0
  68. package/docs/channels/index.md +65 -0
  69. package/docs/channels/irc.md +253 -0
  70. package/docs/channels/line.md +243 -0
  71. package/docs/channels/location.md +71 -0
  72. package/docs/channels/matrix-migration.md +375 -0
  73. package/docs/channels/matrix-presentation.md +77 -0
  74. package/docs/channels/matrix-push-rules.md +150 -0
  75. package/docs/channels/matrix.md +935 -0
  76. package/docs/channels/mattermost.md +542 -0
  77. package/docs/channels/msteams.md +1097 -0
  78. package/docs/channels/nextcloud-talk.md +176 -0
  79. package/docs/channels/nostr.md +253 -0
  80. package/docs/channels/pairing.md +214 -0
  81. package/docs/channels/qqbot.md +317 -0
  82. package/docs/channels/signal.md +417 -0
  83. package/docs/channels/slack.md +1623 -0
  84. package/docs/channels/sms.md +380 -0
  85. package/docs/channels/synology-chat.md +187 -0
  86. package/docs/channels/telegram.md +1121 -0
  87. package/docs/channels/tlon.md +296 -0
  88. package/docs/channels/troubleshooting.md +162 -0
  89. package/docs/channels/twitch.md +431 -0
  90. package/docs/channels/wechat.md +171 -0
  91. package/docs/channels/whatsapp.md +796 -0
  92. package/docs/channels/yuanbao.md +416 -0
  93. package/docs/channels/zalo.md +253 -0
  94. package/docs/channels/zalouser.md +217 -0
  95. package/docs/ci.md +665 -0
  96. package/docs/clawhub/cli.md +82 -0
  97. package/docs/clawhub/publishing.md +96 -0
  98. package/docs/cli/acp.md +370 -0
  99. package/docs/cli/agent.md +109 -0
  100. package/docs/cli/agents.md +253 -0
  101. package/docs/cli/approvals.md +193 -0
  102. package/docs/cli/backup.md +98 -0
  103. package/docs/cli/browser.md +322 -0
  104. package/docs/cli/channels.md +154 -0
  105. package/docs/cli/clawbot.md +25 -0
  106. package/docs/cli/commitments.md +90 -0
  107. package/docs/cli/completion.md +39 -0
  108. package/docs/cli/config.md +504 -0
  109. package/docs/cli/configure.md +77 -0
  110. package/docs/cli/crestodian.md +337 -0
  111. package/docs/cli/cron.md +344 -0
  112. package/docs/cli/daemon.md +67 -0
  113. package/docs/cli/dashboard.md +33 -0
  114. package/docs/cli/devices.md +240 -0
  115. package/docs/cli/directory.md +68 -0
  116. package/docs/cli/dns.md +53 -0
  117. package/docs/cli/docs.md +63 -0
  118. package/docs/cli/doctor.md +254 -0
  119. package/docs/cli/flows.md +52 -0
  120. package/docs/cli/gateway.md +572 -0
  121. package/docs/cli/health.md +43 -0
  122. package/docs/cli/hooks.md +345 -0
  123. package/docs/cli/index.md +406 -0
  124. package/docs/cli/infer.md +364 -0
  125. package/docs/cli/logs.md +68 -0
  126. package/docs/cli/mcp.md +851 -0
  127. package/docs/cli/memory.md +183 -0
  128. package/docs/cli/message.md +317 -0
  129. package/docs/cli/migrate.md +334 -0
  130. package/docs/cli/models.md +239 -0
  131. package/docs/cli/node.md +178 -0
  132. package/docs/cli/nodes.md +76 -0
  133. package/docs/cli/onboard.md +251 -0
  134. package/docs/cli/pairing.md +77 -0
  135. package/docs/cli/path.md +511 -0
  136. package/docs/cli/plugins.md +480 -0
  137. package/docs/cli/policy.md +929 -0
  138. package/docs/cli/proxy.md +89 -0
  139. package/docs/cli/qr.md +56 -0
  140. package/docs/cli/reset.md +39 -0
  141. package/docs/cli/sandbox.md +208 -0
  142. package/docs/cli/secrets.md +202 -0
  143. package/docs/cli/security.md +135 -0
  144. package/docs/cli/sessions.md +178 -0
  145. package/docs/cli/setup.md +60 -0
  146. package/docs/cli/skills.md +156 -0
  147. package/docs/cli/status.md +45 -0
  148. package/docs/cli/system.md +89 -0
  149. package/docs/cli/tasks.md +111 -0
  150. package/docs/cli/transcripts.md +151 -0
  151. package/docs/cli/tui.md +92 -0
  152. package/docs/cli/uninstall.md +45 -0
  153. package/docs/cli/update.md +283 -0
  154. package/docs/cli/voicecall.md +204 -0
  155. package/docs/cli/webhooks.md +117 -0
  156. package/docs/cli/wiki.md +256 -0
  157. package/docs/cli/workboard.md +228 -0
  158. package/docs/concepts/active-memory.md +856 -0
  159. package/docs/concepts/agent-loop.md +185 -0
  160. package/docs/concepts/agent-runtimes.md +276 -0
  161. package/docs/concepts/agent-workspace.md +230 -0
  162. package/docs/concepts/agent.md +142 -0
  163. package/docs/concepts/architecture.md +154 -0
  164. package/docs/concepts/channel-docking.md +145 -0
  165. package/docs/concepts/commitments.md +150 -0
  166. package/docs/concepts/compaction.md +203 -0
  167. package/docs/concepts/context-engine.md +347 -0
  168. package/docs/concepts/context.md +199 -0
  169. package/docs/concepts/delegate-architecture.md +319 -0
  170. package/docs/concepts/dreaming.md +279 -0
  171. package/docs/concepts/experimental-features.md +111 -0
  172. package/docs/concepts/features.md +91 -0
  173. package/docs/concepts/mantis-slack-desktop-runbook.md +231 -0
  174. package/docs/concepts/mantis.md +744 -0
  175. package/docs/concepts/markdown-formatting.md +139 -0
  176. package/docs/concepts/memory-builtin.md +151 -0
  177. package/docs/concepts/memory-honcho.md +144 -0
  178. package/docs/concepts/memory-qmd.md +277 -0
  179. package/docs/concepts/memory-search.md +175 -0
  180. package/docs/concepts/memory.md +299 -0
  181. package/docs/concepts/message-lifecycle-refactor.md +1126 -0
  182. package/docs/concepts/messages.md +216 -0
  183. package/docs/concepts/model-failover.md +405 -0
  184. package/docs/concepts/model-providers.md +719 -0
  185. package/docs/concepts/models.md +371 -0
  186. package/docs/concepts/multi-agent.md +625 -0
  187. package/docs/concepts/oauth.md +218 -0
  188. package/docs/concepts/parallel-specialist-lanes.md +127 -0
  189. package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
  190. package/docs/concepts/presence.md +117 -0
  191. package/docs/concepts/progress-drafts.md +406 -0
  192. package/docs/concepts/qa-e2e-automation.md +979 -0
  193. package/docs/concepts/qa-matrix.md +139 -0
  194. package/docs/concepts/queue-steering.md +90 -0
  195. package/docs/concepts/queue.md +136 -0
  196. package/docs/concepts/retry.md +86 -0
  197. package/docs/concepts/session-pruning.md +104 -0
  198. package/docs/concepts/session-tool.md +201 -0
  199. package/docs/concepts/session.md +164 -0
  200. package/docs/concepts/soul.md +116 -0
  201. package/docs/concepts/streaming.md +258 -0
  202. package/docs/concepts/system-prompt.md +330 -0
  203. package/docs/concepts/timezone.md +47 -0
  204. package/docs/concepts/typebox.md +309 -0
  205. package/docs/concepts/typing-indicators.md +88 -0
  206. package/docs/concepts/usage-tracking.md +72 -0
  207. package/docs/date-time.md +126 -0
  208. package/docs/debug/node-issue.md +90 -0
  209. package/docs/diagnostics/flags.md +182 -0
  210. package/docs/docs.json +1885 -0
  211. package/docs/gateway/authentication.md +286 -0
  212. package/docs/gateway/background-process.md +147 -0
  213. package/docs/gateway/bonjour.md +303 -0
  214. package/docs/gateway/bridge-protocol.md +97 -0
  215. package/docs/gateway/cli-backends.md +463 -0
  216. package/docs/gateway/config-agents.md +1525 -0
  217. package/docs/gateway/config-channels.md +942 -0
  218. package/docs/gateway/config-tools.md +806 -0
  219. package/docs/gateway/configuration-examples.md +706 -0
  220. package/docs/gateway/configuration-reference.md +1449 -0
  221. package/docs/gateway/configuration.md +748 -0
  222. package/docs/gateway/diagnostics.md +213 -0
  223. package/docs/gateway/discovery.md +154 -0
  224. package/docs/gateway/doctor.md +576 -0
  225. package/docs/gateway/external-apps.md +86 -0
  226. package/docs/gateway/gateway-lock.md +37 -0
  227. package/docs/gateway/health.md +73 -0
  228. package/docs/gateway/heartbeat.md +498 -0
  229. package/docs/gateway/index.md +385 -0
  230. package/docs/gateway/local-model-services.md +205 -0
  231. package/docs/gateway/local-models.md +355 -0
  232. package/docs/gateway/logging.md +149 -0
  233. package/docs/gateway/multiple-gateways.md +178 -0
  234. package/docs/gateway/network-model.md +15 -0
  235. package/docs/gateway/openai-http-api.md +379 -0
  236. package/docs/gateway/openresponses-http-api.md +349 -0
  237. package/docs/gateway/openshell.md +316 -0
  238. package/docs/gateway/opentelemetry.md +440 -0
  239. package/docs/gateway/operator-scopes.md +119 -0
  240. package/docs/gateway/pairing.md +207 -0
  241. package/docs/gateway/prometheus.md +249 -0
  242. package/docs/gateway/protocol.md +839 -0
  243. package/docs/gateway/remote-gateway-readme.md +169 -0
  244. package/docs/gateway/remote.md +280 -0
  245. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +148 -0
  246. package/docs/gateway/sandboxing.md +546 -0
  247. package/docs/gateway/secrets-plan-contract.md +159 -0
  248. package/docs/gateway/secrets.md +805 -0
  249. package/docs/gateway/security/audit-checks.md +127 -0
  250. package/docs/gateway/security/exposure-runbook.md +212 -0
  251. package/docs/gateway/security/index.md +1344 -0
  252. package/docs/gateway/security/secure-file-operations.md +76 -0
  253. package/docs/gateway/security/shrinkwrap.md +111 -0
  254. package/docs/gateway/tailscale.md +180 -0
  255. package/docs/gateway/tools-invoke-http-api.md +175 -0
  256. package/docs/gateway/troubleshooting.md +881 -0
  257. package/docs/gateway/trusted-proxy-auth.md +483 -0
  258. package/docs/help/debugging.md +341 -0
  259. package/docs/help/environment.md +240 -0
  260. package/docs/help/faq-first-run.md +872 -0
  261. package/docs/help/faq-models.md +557 -0
  262. package/docs/help/faq.md +2115 -0
  263. package/docs/help/index.md +39 -0
  264. package/docs/help/scripts.md +56 -0
  265. package/docs/help/testing-live.md +592 -0
  266. package/docs/help/testing-updates-plugins.md +299 -0
  267. package/docs/help/testing.md +977 -0
  268. package/docs/help/troubleshooting.md +500 -0
  269. package/docs/index.md +196 -0
  270. package/docs/install/ansible.md +233 -0
  271. package/docs/install/azure.md +315 -0
  272. package/docs/install/bun.md +59 -0
  273. package/docs/install/clawdock.md +112 -0
  274. package/docs/install/development-channels.md +148 -0
  275. package/docs/install/digitalocean.md +174 -0
  276. package/docs/install/docker-vm-runtime.md +154 -0
  277. package/docs/install/docker.md +564 -0
  278. package/docs/install/exe-dev.md +201 -0
  279. package/docs/install/fly.md +524 -0
  280. package/docs/install/gcp.md +418 -0
  281. package/docs/install/hetzner.md +285 -0
  282. package/docs/install/hostinger.md +98 -0
  283. package/docs/install/index.md +236 -0
  284. package/docs/install/installer.md +447 -0
  285. package/docs/install/kubernetes.md +196 -0
  286. package/docs/install/macos-vm.md +281 -0
  287. package/docs/install/migrating-claude.md +165 -0
  288. package/docs/install/migrating-hermes.md +178 -0
  289. package/docs/install/migrating.md +137 -0
  290. package/docs/install/nix.md +112 -0
  291. package/docs/install/node.md +142 -0
  292. package/docs/install/northflank.mdx +44 -0
  293. package/docs/install/oracle.md +218 -0
  294. package/docs/install/podman.md +216 -0
  295. package/docs/install/railway.mdx +92 -0
  296. package/docs/install/raspberry-pi.md +234 -0
  297. package/docs/install/render.mdx +167 -0
  298. package/docs/install/uninstall.md +140 -0
  299. package/docs/install/updating.md +284 -0
  300. package/docs/install/upstash.md +96 -0
  301. package/docs/logging.md +322 -0
  302. package/docs/maturity-scores.yaml +5361 -0
  303. package/docs/nav-tabs-underline.js +104 -0
  304. package/docs/network.md +72 -0
  305. package/docs/nodes/audio.md +216 -0
  306. package/docs/nodes/camera.md +166 -0
  307. package/docs/nodes/images.md +77 -0
  308. package/docs/nodes/index.md +444 -0
  309. package/docs/nodes/location-command.md +102 -0
  310. package/docs/nodes/media-understanding.md +495 -0
  311. package/docs/nodes/talk.md +160 -0
  312. package/docs/nodes/troubleshooting.md +123 -0
  313. package/docs/nodes/voicewake.md +93 -0
  314. package/docs/openclaw-agent-runtime.md +82 -0
  315. package/docs/perplexity.md +11 -0
  316. package/docs/plan/codex-context-engine-harness.md +624 -0
  317. package/docs/plan/ui-channels.md +284 -0
  318. package/docs/platforms/android.md +286 -0
  319. package/docs/platforms/digitalocean.md +12 -0
  320. package/docs/platforms/easyrunner.md +109 -0
  321. package/docs/platforms/index.md +65 -0
  322. package/docs/platforms/ios.md +287 -0
  323. package/docs/platforms/linux.md +141 -0
  324. package/docs/platforms/mac/bundled-gateway.md +79 -0
  325. package/docs/platforms/mac/canvas.md +128 -0
  326. package/docs/platforms/mac/child-process.md +72 -0
  327. package/docs/platforms/mac/dev-setup.md +112 -0
  328. package/docs/platforms/mac/health.md +39 -0
  329. package/docs/platforms/mac/icon.md +36 -0
  330. package/docs/platforms/mac/logging.md +62 -0
  331. package/docs/platforms/mac/menu-bar.md +93 -0
  332. package/docs/platforms/mac/peekaboo.md +96 -0
  333. package/docs/platforms/mac/permissions.md +73 -0
  334. package/docs/platforms/mac/remote.md +123 -0
  335. package/docs/platforms/mac/signing.md +52 -0
  336. package/docs/platforms/mac/skills.md +45 -0
  337. package/docs/platforms/mac/voice-overlay.md +66 -0
  338. package/docs/platforms/mac/voicewake.md +79 -0
  339. package/docs/platforms/mac/webchat.md +54 -0
  340. package/docs/platforms/mac/xpc.md +66 -0
  341. package/docs/platforms/macos.md +228 -0
  342. package/docs/platforms/oracle.md +12 -0
  343. package/docs/platforms/raspberry-pi.md +13 -0
  344. package/docs/platforms/windows.md +304 -0
  345. package/docs/plugins/adding-capabilities.md +146 -0
  346. package/docs/plugins/admin-http-rpc.md +216 -0
  347. package/docs/plugins/agent-tools.md +13 -0
  348. package/docs/plugins/architecture-internals.md +1203 -0
  349. package/docs/plugins/architecture.md +483 -0
  350. package/docs/plugins/building-extensions.md +13 -0
  351. package/docs/plugins/building-plugins.md +343 -0
  352. package/docs/plugins/bundles.md +310 -0
  353. package/docs/plugins/cli-backend-plugins.md +328 -0
  354. package/docs/plugins/codex-computer-use.md +297 -0
  355. package/docs/plugins/codex-harness-reference.md +480 -0
  356. package/docs/plugins/codex-harness-runtime.md +268 -0
  357. package/docs/plugins/codex-harness.md +800 -0
  358. package/docs/plugins/codex-native-plugins.md +280 -0
  359. package/docs/plugins/community.md +77 -0
  360. package/docs/plugins/compatibility.md +198 -0
  361. package/docs/plugins/copilot.md +355 -0
  362. package/docs/plugins/dependency-resolution.md +176 -0
  363. package/docs/plugins/google-meet.md +1737 -0
  364. package/docs/plugins/hooks.md +525 -0
  365. package/docs/plugins/install-overrides.md +80 -0
  366. package/docs/plugins/llama-cpp.md +58 -0
  367. package/docs/plugins/manage-plugins.md +214 -0
  368. package/docs/plugins/manifest.md +1468 -0
  369. package/docs/plugins/memory-lancedb.md +385 -0
  370. package/docs/plugins/memory-wiki.md +529 -0
  371. package/docs/plugins/message-presentation.md +487 -0
  372. package/docs/plugins/oc-path.md +166 -0
  373. package/docs/plugins/plugin-inventory.md +318 -0
  374. package/docs/plugins/plugin-permission-requests.md +193 -0
  375. package/docs/plugins/reference/acpx.md +23 -0
  376. package/docs/plugins/reference/admin-http-rpc.md +23 -0
  377. package/docs/plugins/reference/alibaba.md +23 -0
  378. package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
  379. package/docs/plugins/reference/amazon-bedrock.md +23 -0
  380. package/docs/plugins/reference/anthropic-vertex.md +29 -0
  381. package/docs/plugins/reference/anthropic.md +23 -0
  382. package/docs/plugins/reference/arcee.md +23 -0
  383. package/docs/plugins/reference/azure-speech.md +23 -0
  384. package/docs/plugins/reference/bonjour.md +19 -0
  385. package/docs/plugins/reference/brave.md +23 -0
  386. package/docs/plugins/reference/browser.md +23 -0
  387. package/docs/plugins/reference/byteplus.md +19 -0
  388. package/docs/plugins/reference/canvas.md +19 -0
  389. package/docs/plugins/reference/cerebras.md +23 -0
  390. package/docs/plugins/reference/chutes.md +23 -0
  391. package/docs/plugins/reference/clickclack.md +23 -0
  392. package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
  393. package/docs/plugins/reference/codex-supervisor.md +27 -0
  394. package/docs/plugins/reference/codex.md +23 -0
  395. package/docs/plugins/reference/comfy.md +23 -0
  396. package/docs/plugins/reference/copilot-proxy.md +19 -0
  397. package/docs/plugins/reference/copilot.md +23 -0
  398. package/docs/plugins/reference/deepgram.md +23 -0
  399. package/docs/plugins/reference/deepinfra.md +23 -0
  400. package/docs/plugins/reference/deepseek.md +23 -0
  401. package/docs/plugins/reference/diagnostics-otel.md +19 -0
  402. package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
  403. package/docs/plugins/reference/diffs-language-pack.md +31 -0
  404. package/docs/plugins/reference/diffs.md +19 -0
  405. package/docs/plugins/reference/discord.md +23 -0
  406. package/docs/plugins/reference/document-extract.md +23 -0
  407. package/docs/plugins/reference/duckduckgo.md +23 -0
  408. package/docs/plugins/reference/elevenlabs.md +23 -0
  409. package/docs/plugins/reference/exa.md +23 -0
  410. package/docs/plugins/reference/fal.md +23 -0
  411. package/docs/plugins/reference/feishu.md +23 -0
  412. package/docs/plugins/reference/file-transfer.md +19 -0
  413. package/docs/plugins/reference/firecrawl.md +23 -0
  414. package/docs/plugins/reference/fireworks.md +23 -0
  415. package/docs/plugins/reference/github-copilot.md +23 -0
  416. package/docs/plugins/reference/gmi.md +23 -0
  417. package/docs/plugins/reference/google-meet.md +23 -0
  418. package/docs/plugins/reference/google.md +23 -0
  419. package/docs/plugins/reference/googlechat.md +23 -0
  420. package/docs/plugins/reference/gradium.md +23 -0
  421. package/docs/plugins/reference/groq.md +23 -0
  422. package/docs/plugins/reference/huggingface.md +23 -0
  423. package/docs/plugins/reference/imessage.md +23 -0
  424. package/docs/plugins/reference/inworld.md +23 -0
  425. package/docs/plugins/reference/irc.md +23 -0
  426. package/docs/plugins/reference/kilocode.md +23 -0
  427. package/docs/plugins/reference/kimi.md +23 -0
  428. package/docs/plugins/reference/line.md +23 -0
  429. package/docs/plugins/reference/litellm.md +23 -0
  430. package/docs/plugins/reference/llama-cpp.md +23 -0
  431. package/docs/plugins/reference/llm-task.md +19 -0
  432. package/docs/plugins/reference/lmstudio.md +23 -0
  433. package/docs/plugins/reference/lobster.md +19 -0
  434. package/docs/plugins/reference/matrix.md +23 -0
  435. package/docs/plugins/reference/mattermost.md +23 -0
  436. package/docs/plugins/reference/memory-core.md +19 -0
  437. package/docs/plugins/reference/memory-lancedb.md +23 -0
  438. package/docs/plugins/reference/memory-wiki.md +23 -0
  439. package/docs/plugins/reference/microsoft-foundry.md +113 -0
  440. package/docs/plugins/reference/microsoft.md +19 -0
  441. package/docs/plugins/reference/migrate-claude.md +19 -0
  442. package/docs/plugins/reference/migrate-hermes.md +19 -0
  443. package/docs/plugins/reference/minimax.md +23 -0
  444. package/docs/plugins/reference/mistral.md +23 -0
  445. package/docs/plugins/reference/moonshot.md +23 -0
  446. package/docs/plugins/reference/msteams.md +23 -0
  447. package/docs/plugins/reference/nextcloud-talk.md +23 -0
  448. package/docs/plugins/reference/nostr.md +23 -0
  449. package/docs/plugins/reference/novita.md +23 -0
  450. package/docs/plugins/reference/nvidia.md +23 -0
  451. package/docs/plugins/reference/oc-path.md +23 -0
  452. package/docs/plugins/reference/ollama.md +24 -0
  453. package/docs/plugins/reference/open-prose.md +19 -0
  454. package/docs/plugins/reference/openai.md +23 -0
  455. package/docs/plugins/reference/opencode-go.md +23 -0
  456. package/docs/plugins/reference/opencode.md +23 -0
  457. package/docs/plugins/reference/openrouter.md +23 -0
  458. package/docs/plugins/reference/openshell.md +19 -0
  459. package/docs/plugins/reference/perplexity.md +23 -0
  460. package/docs/plugins/reference/pixverse.md +23 -0
  461. package/docs/plugins/reference/policy.md +79 -0
  462. package/docs/plugins/reference/qa-channel.md +23 -0
  463. package/docs/plugins/reference/qa-lab.md +19 -0
  464. package/docs/plugins/reference/qa-matrix.md +19 -0
  465. package/docs/plugins/reference/qianfan.md +23 -0
  466. package/docs/plugins/reference/qqbot.md +23 -0
  467. package/docs/plugins/reference/qwen.md +24 -0
  468. package/docs/plugins/reference/runway.md +23 -0
  469. package/docs/plugins/reference/searxng.md +19 -0
  470. package/docs/plugins/reference/senseaudio.md +23 -0
  471. package/docs/plugins/reference/sglang.md +23 -0
  472. package/docs/plugins/reference/signal.md +23 -0
  473. package/docs/plugins/reference/slack.md +23 -0
  474. package/docs/plugins/reference/sms.md +23 -0
  475. package/docs/plugins/reference/stepfun.md +23 -0
  476. package/docs/plugins/reference/synology-chat.md +23 -0
  477. package/docs/plugins/reference/synthetic.md +23 -0
  478. package/docs/plugins/reference/tavily.md +23 -0
  479. package/docs/plugins/reference/telegram.md +23 -0
  480. package/docs/plugins/reference/tencent.md +23 -0
  481. package/docs/plugins/reference/tlon.md +23 -0
  482. package/docs/plugins/reference/together.md +23 -0
  483. package/docs/plugins/reference/tokenjuice.md +23 -0
  484. package/docs/plugins/reference/tts-local-cli.md +19 -0
  485. package/docs/plugins/reference/twitch.md +23 -0
  486. package/docs/plugins/reference/venice.md +23 -0
  487. package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
  488. package/docs/plugins/reference/vllm.md +23 -0
  489. package/docs/plugins/reference/voice-call.md +23 -0
  490. package/docs/plugins/reference/volcengine.md +23 -0
  491. package/docs/plugins/reference/voyage.md +19 -0
  492. package/docs/plugins/reference/vydra.md +23 -0
  493. package/docs/plugins/reference/web-readability.md +19 -0
  494. package/docs/plugins/reference/webhooks.md +23 -0
  495. package/docs/plugins/reference/whatsapp.md +23 -0
  496. package/docs/plugins/reference/workboard.md +23 -0
  497. package/docs/plugins/reference/xai.md +23 -0
  498. package/docs/plugins/reference/xiaomi.md +23 -0
  499. package/docs/plugins/reference/zai.md +23 -0
  500. package/docs/plugins/reference/zalo.md +23 -0
  501. package/docs/plugins/reference/zalouser.md +24 -0
  502. package/docs/plugins/reference.md +19 -0
  503. package/docs/plugins/sdk-agent-harness.md +339 -0
  504. package/docs/plugins/sdk-channel-inbound.md +70 -0
  505. package/docs/plugins/sdk-channel-ingress.md +137 -0
  506. package/docs/plugins/sdk-channel-message.md +18 -0
  507. package/docs/plugins/sdk-channel-outbound.md +113 -0
  508. package/docs/plugins/sdk-channel-plugins.md +770 -0
  509. package/docs/plugins/sdk-channel-turn.md +9 -0
  510. package/docs/plugins/sdk-entrypoints.md +344 -0
  511. package/docs/plugins/sdk-migration.md +1011 -0
  512. package/docs/plugins/sdk-overview.md +525 -0
  513. package/docs/plugins/sdk-provider-plugins.md +1019 -0
  514. package/docs/plugins/sdk-runtime.md +683 -0
  515. package/docs/plugins/sdk-setup.md +550 -0
  516. package/docs/plugins/sdk-subpaths.md +401 -0
  517. package/docs/plugins/sdk-testing.md +403 -0
  518. package/docs/plugins/tool-plugins.md +411 -0
  519. package/docs/plugins/voice-call.md +942 -0
  520. package/docs/plugins/webhooks.md +192 -0
  521. package/docs/plugins/workboard.md +402 -0
  522. package/docs/plugins/zalouser.md +86 -0
  523. package/docs/prose.md +191 -0
  524. package/docs/providers/alibaba.md +158 -0
  525. package/docs/providers/anthropic.md +386 -0
  526. package/docs/providers/arcee.md +144 -0
  527. package/docs/providers/azure-speech.md +119 -0
  528. package/docs/providers/bedrock-mantle.md +224 -0
  529. package/docs/providers/bedrock.md +433 -0
  530. package/docs/providers/cerebras.md +130 -0
  531. package/docs/providers/chutes.md +153 -0
  532. package/docs/providers/claude-max-api-proxy.md +191 -0
  533. package/docs/providers/cloudflare-ai-gateway.md +119 -0
  534. package/docs/providers/comfy.md +362 -0
  535. package/docs/providers/deepgram.md +184 -0
  536. package/docs/providers/deepinfra.md +92 -0
  537. package/docs/providers/deepseek.md +146 -0
  538. package/docs/providers/ds4.md +309 -0
  539. package/docs/providers/elevenlabs.md +130 -0
  540. package/docs/providers/fal.md +240 -0
  541. package/docs/providers/fireworks.md +144 -0
  542. package/docs/providers/github-copilot.md +257 -0
  543. package/docs/providers/gmi.md +92 -0
  544. package/docs/providers/google.md +472 -0
  545. package/docs/providers/gradium.md +123 -0
  546. package/docs/providers/groq.md +171 -0
  547. package/docs/providers/huggingface.md +235 -0
  548. package/docs/providers/index.md +105 -0
  549. package/docs/providers/inferrs.md +272 -0
  550. package/docs/providers/inworld.md +120 -0
  551. package/docs/providers/kilocode.md +135 -0
  552. package/docs/providers/litellm.md +234 -0
  553. package/docs/providers/lmstudio.md +224 -0
  554. package/docs/providers/minimax.md +518 -0
  555. package/docs/providers/mistral.md +235 -0
  556. package/docs/providers/models.md +64 -0
  557. package/docs/providers/moonshot.md +413 -0
  558. package/docs/providers/novita.md +92 -0
  559. package/docs/providers/nvidia.md +208 -0
  560. package/docs/providers/ollama-cloud.md +115 -0
  561. package/docs/providers/ollama.md +1225 -0
  562. package/docs/providers/openai.md +1091 -0
  563. package/docs/providers/opencode-go.md +123 -0
  564. package/docs/providers/opencode.md +149 -0
  565. package/docs/providers/openrouter.md +390 -0
  566. package/docs/providers/perplexity-provider.md +123 -0
  567. package/docs/providers/pixverse.md +165 -0
  568. package/docs/providers/qianfan.md +132 -0
  569. package/docs/providers/qwen-oauth.md +115 -0
  570. package/docs/providers/qwen.md +364 -0
  571. package/docs/providers/runway.md +103 -0
  572. package/docs/providers/senseaudio.md +68 -0
  573. package/docs/providers/sglang.md +161 -0
  574. package/docs/providers/stepfun.md +229 -0
  575. package/docs/providers/synthetic.md +154 -0
  576. package/docs/providers/tencent.md +130 -0
  577. package/docs/providers/together.md +140 -0
  578. package/docs/providers/venice.md +312 -0
  579. package/docs/providers/vercel-ai-gateway.md +128 -0
  580. package/docs/providers/vllm.md +407 -0
  581. package/docs/providers/volcengine.md +199 -0
  582. package/docs/providers/vydra.md +180 -0
  583. package/docs/providers/xai.md +571 -0
  584. package/docs/providers/xiaomi.md +286 -0
  585. package/docs/providers/zai.md +224 -0
  586. package/docs/refactor/access.md +9 -0
  587. package/docs/refactor/acp.md +298 -0
  588. package/docs/refactor/canvas.md +131 -0
  589. package/docs/refactor/database-first.md +2263 -0
  590. package/docs/refactor/ingress-core.md +341 -0
  591. package/docs/reference/AGENTS.default.md +131 -0
  592. package/docs/reference/RELEASING.md +844 -0
  593. package/docs/reference/api-usage-costs.md +208 -0
  594. package/docs/reference/application-modernization-plan.md +208 -0
  595. package/docs/reference/code-mode.md +1058 -0
  596. package/docs/reference/credits.md +33 -0
  597. package/docs/reference/device-models.md +50 -0
  598. package/docs/reference/full-release-validation.md +206 -0
  599. package/docs/reference/memory-config.md +630 -0
  600. package/docs/reference/prompt-caching.md +358 -0
  601. package/docs/reference/release-performance-sweep.md +347 -0
  602. package/docs/reference/rich-output-protocol.md +93 -0
  603. package/docs/reference/rpc.md +43 -0
  604. package/docs/reference/secret-placeholder-conventions.md +33 -0
  605. package/docs/reference/secretref-credential-surface.md +163 -0
  606. package/docs/reference/secretref-user-supplied-credentials-matrix.json +691 -0
  607. package/docs/reference/session-management-compaction.md +474 -0
  608. package/docs/reference/templates/AGENTS.dev.md +90 -0
  609. package/docs/reference/templates/AGENTS.md +227 -0
  610. package/docs/reference/templates/BOOT.md +16 -0
  611. package/docs/reference/templates/BOOTSTRAP.md +66 -0
  612. package/docs/reference/templates/HEARTBEAT.md +24 -0
  613. package/docs/reference/templates/IDENTITY.dev.md +52 -0
  614. package/docs/reference/templates/IDENTITY.md +34 -0
  615. package/docs/reference/templates/SOUL.dev.md +82 -0
  616. package/docs/reference/templates/SOUL.md +49 -0
  617. package/docs/reference/templates/TOOLS.dev.md +29 -0
  618. package/docs/reference/templates/TOOLS.md +51 -0
  619. package/docs/reference/templates/USER.dev.md +23 -0
  620. package/docs/reference/templates/USER.md +28 -0
  621. package/docs/reference/test.md +248 -0
  622. package/docs/reference/token-use.md +246 -0
  623. package/docs/reference/transcript-hygiene.md +226 -0
  624. package/docs/reference/wizard.md +252 -0
  625. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
  626. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  627. package/docs/security/formal-verification.md +170 -0
  628. package/docs/security/incident-response.md +59 -0
  629. package/docs/security/network-proxy.md +268 -0
  630. package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
  631. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  632. package/docs/specs/claw-supervisor.md +247 -0
  633. package/docs/start/bootstrapping.md +49 -0
  634. package/docs/start/docs-directory.md +69 -0
  635. package/docs/start/getting-started.md +152 -0
  636. package/docs/start/hubs.md +201 -0
  637. package/docs/start/lore.md +223 -0
  638. package/docs/start/onboarding-overview.md +72 -0
  639. package/docs/start/onboarding.md +98 -0
  640. package/docs/start/openclaw.md +246 -0
  641. package/docs/start/quickstart.md +25 -0
  642. package/docs/start/setup.md +178 -0
  643. package/docs/start/showcase.md +371 -0
  644. package/docs/start/wizard-cli-automation.md +232 -0
  645. package/docs/start/wizard-cli-reference.md +331 -0
  646. package/docs/start/wizard.md +142 -0
  647. package/docs/style.css +137 -0
  648. package/docs/tools/acp-agents-setup.md +356 -0
  649. package/docs/tools/acp-agents.md +865 -0
  650. package/docs/tools/agent-send.md +130 -0
  651. package/docs/tools/apply-patch.md +64 -0
  652. package/docs/tools/brave-search.md +139 -0
  653. package/docs/tools/browser-control.md +405 -0
  654. package/docs/tools/browser-linux-troubleshooting.md +173 -0
  655. package/docs/tools/browser-login.md +77 -0
  656. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
  657. package/docs/tools/browser.md +866 -0
  658. package/docs/tools/btw.md +159 -0
  659. package/docs/tools/capability-cookbook.md +12 -0
  660. package/docs/tools/clawhub.md +5 -0
  661. package/docs/tools/code-execution.md +173 -0
  662. package/docs/tools/creating-skills.md +271 -0
  663. package/docs/tools/diffs.md +527 -0
  664. package/docs/tools/duckduckgo-search.md +109 -0
  665. package/docs/tools/elevated.md +128 -0
  666. package/docs/tools/exa-search.md +152 -0
  667. package/docs/tools/exec-approvals-advanced.md +457 -0
  668. package/docs/tools/exec-approvals.md +520 -0
  669. package/docs/tools/exec.md +294 -0
  670. package/docs/tools/firecrawl.md +155 -0
  671. package/docs/tools/gemini-search.md +114 -0
  672. package/docs/tools/goal.md +217 -0
  673. package/docs/tools/grok-search.md +129 -0
  674. package/docs/tools/image-generation.md +538 -0
  675. package/docs/tools/index.md +176 -0
  676. package/docs/tools/kimi-search.md +105 -0
  677. package/docs/tools/llm-task.md +137 -0
  678. package/docs/tools/lobster.md +365 -0
  679. package/docs/tools/loop-detection.md +154 -0
  680. package/docs/tools/media-overview.md +161 -0
  681. package/docs/tools/minimax-search.md +102 -0
  682. package/docs/tools/multi-agent-sandbox-tools.md +409 -0
  683. package/docs/tools/music-generation.md +372 -0
  684. package/docs/tools/ollama-search.md +153 -0
  685. package/docs/tools/parallel-search.md +154 -0
  686. package/docs/tools/pdf.md +213 -0
  687. package/docs/tools/permission-modes.md +111 -0
  688. package/docs/tools/perplexity-search.md +220 -0
  689. package/docs/tools/plugin.md +378 -0
  690. package/docs/tools/reactions.md +100 -0
  691. package/docs/tools/searxng-search.md +141 -0
  692. package/docs/tools/skill-workshop.md +283 -0
  693. package/docs/tools/skills-config.md +457 -0
  694. package/docs/tools/skills.md +591 -0
  695. package/docs/tools/slash-commands.md +518 -0
  696. package/docs/tools/steer.md +77 -0
  697. package/docs/tools/subagents.md +652 -0
  698. package/docs/tools/tavily.md +162 -0
  699. package/docs/tools/thinking.md +142 -0
  700. package/docs/tools/tokenjuice.md +84 -0
  701. package/docs/tools/tool-search.md +269 -0
  702. package/docs/tools/trajectory.md +229 -0
  703. package/docs/tools/tts.md +1013 -0
  704. package/docs/tools/video-generation.md +555 -0
  705. package/docs/tools/web-fetch.md +210 -0
  706. package/docs/tools/web.md +476 -0
  707. package/docs/tts.md +11 -0
  708. package/docs/vps.md +139 -0
  709. package/docs/web/control-ui.md +530 -0
  710. package/docs/web/dashboard.md +107 -0
  711. package/docs/web/index.md +133 -0
  712. package/docs/web/tui.md +258 -0
  713. package/docs/web/webchat.md +102 -0
  714. package/npm-shrinkwrap.json +3485 -0
  715. package/openclaw.mjs +661 -0
  716. package/package.json +1971 -0
  717. package/patches/.gitkeep +0 -0
  718. package/patches/@agentclientprotocol__claude-agent-acp@0.39.0.patch +40 -0
  719. package/pnpm-workspace.yaml +124 -0
  720. package/scripts/crabbox-wrapper.mjs +2470 -0
  721. package/scripts/lib/official-external-channel-catalog.json +570 -0
  722. package/scripts/lib/official-external-plugin-catalog.json +284 -0
  723. package/scripts/lib/official-external-provider-catalog.json +158 -0
  724. package/scripts/lib/package-dist-imports.mjs +174 -0
  725. package/scripts/npm-runner.mjs +95 -0
  726. package/scripts/postinstall-bundled-plugins.mjs +978 -0
  727. package/scripts/preinstall-package-manager-warning.mjs +74 -0
  728. package/scripts/prepare-git-hooks.mjs +73 -0
  729. package/scripts/windows-cmd-helpers.mjs +29 -0
  730. package/skills/1password/SKILL.md +70 -0
  731. package/skills/1password/references/cli-examples.md +29 -0
  732. package/skills/1password/references/get-started.md +17 -0
  733. package/skills/apple-notes/SKILL.md +77 -0
  734. package/skills/apple-reminders/SKILL.md +118 -0
  735. package/skills/bear-notes/SKILL.md +107 -0
  736. package/skills/blogwatcher/SKILL.md +69 -0
  737. package/skills/blucli/SKILL.md +47 -0
  738. package/skills/camsnap/SKILL.md +45 -0
  739. package/skills/canvas/SKILL.md +78 -0
  740. package/skills/clawhub/SKILL.md +77 -0
  741. package/skills/coding-agent/SKILL.md +143 -0
  742. package/skills/diagram-maker/SKILL.md +53 -0
  743. package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
  744. package/skills/diagram-maker/references/svg-template.md +112 -0
  745. package/skills/discord/SKILL.md +136 -0
  746. package/skills/eightctl/SKILL.md +50 -0
  747. package/skills/gemini/SKILL.md +47 -0
  748. package/skills/gh-issues/SKILL.md +213 -0
  749. package/skills/gifgrep/SKILL.md +85 -0
  750. package/skills/github/SKILL.md +84 -0
  751. package/skills/gog/SKILL.md +116 -0
  752. package/skills/goplaces/SKILL.md +52 -0
  753. package/skills/healthcheck/SKILL.md +105 -0
  754. package/skills/himalaya/SKILL.md +80 -0
  755. package/skills/himalaya/references/configuration.md +184 -0
  756. package/skills/himalaya/references/message-composition.md +199 -0
  757. package/skills/imsg/SKILL.md +122 -0
  758. package/skills/mcporter/SKILL.md +61 -0
  759. package/skills/meme-maker/SKILL.md +42 -0
  760. package/skills/meme-maker/references/templates.json +358 -0
  761. package/skills/meme-maker/scripts/meme.mjs +398 -0
  762. package/skills/model-usage/SKILL.md +71 -0
  763. package/skills/model-usage/references/codexbar-cli.md +33 -0
  764. package/skills/model-usage/scripts/model_usage.py +319 -0
  765. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  766. package/skills/nano-pdf/SKILL.md +38 -0
  767. package/skills/node-connect/SKILL.md +143 -0
  768. package/skills/node-inspect-debugger/SKILL.md +85 -0
  769. package/skills/notion/SKILL.md +150 -0
  770. package/skills/obsidian/SKILL.md +119 -0
  771. package/skills/openai-whisper/SKILL.md +38 -0
  772. package/skills/openai-whisper-api/SKILL.md +71 -0
  773. package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
  774. package/skills/openhue/SKILL.md +112 -0
  775. package/skills/oracle/SKILL.md +126 -0
  776. package/skills/ordercli/SKILL.md +78 -0
  777. package/skills/peekaboo/SKILL.md +198 -0
  778. package/skills/pyproject.toml +10 -0
  779. package/skills/python-debugpy/SKILL.md +73 -0
  780. package/skills/sag/SKILL.md +87 -0
  781. package/skills/session-logs/SKILL.md +151 -0
  782. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  783. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  784. package/skills/skill-creator/SKILL.md +78 -0
  785. package/skills/skill-creator/license.txt +202 -0
  786. package/skills/skill-creator/scripts/init_skill.py +378 -0
  787. package/skills/skill-creator/scripts/package_skill.py +144 -0
  788. package/skills/skill-creator/scripts/quick_validate.py +169 -0
  789. package/skills/skill-creator/scripts/test_package_skill.py +199 -0
  790. package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
  791. package/skills/slack/SKILL.md +78 -0
  792. package/skills/songsee/SKILL.md +49 -0
  793. package/skills/sonoscli/SKILL.md +65 -0
  794. package/skills/spike/SKILL.md +51 -0
  795. package/skills/spotify-player/SKILL.md +64 -0
  796. package/skills/summarize/SKILL.md +87 -0
  797. package/skills/taskflow/SKILL.md +149 -0
  798. package/skills/taskflow/examples/inbox-triage.lobster +33 -0
  799. package/skills/taskflow/examples/pr-intake.lobster +32 -0
  800. package/skills/taskflow-inbox-triage/SKILL.md +119 -0
  801. package/skills/things-mac/SKILL.md +86 -0
  802. package/skills/tmux/SKILL.md +91 -0
  803. package/skills/tmux/scripts/find-sessions.sh +112 -0
  804. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  805. package/skills/trello/SKILL.md +108 -0
  806. package/skills/video-frames/SKILL.md +46 -0
  807. package/skills/video-frames/scripts/frame.sh +81 -0
  808. package/skills/voice-call/SKILL.md +45 -0
  809. package/skills/wacli/SKILL.md +72 -0
  810. package/skills/weather/SKILL.md +87 -0
  811. package/skills/xurl/SKILL.md +120 -0
  812. package/src/agents/templates/HEARTBEAT.md +5 -0
@@ -0,0 +1,1225 @@
1
+ ---
2
+ summary: "Run OpenClaw with Ollama (cloud and local models)"
3
+ read_when:
4
+ - You want to run OpenClaw with cloud or local models via Ollama
5
+ - You need Ollama setup and configuration guidance
6
+ - You want Ollama vision models for image understanding
7
+ title: "Ollama"
8
+ ---
9
+
10
+ OpenClaw integrates with Ollama's native API (`/api/chat`) for hosted cloud models and local/self-hosted Ollama servers. You can use Ollama in three modes: `Cloud + Local` through a reachable Ollama host, `Cloud only` against `https://ollama.com`, or `Local only` against a reachable Ollama host.
11
+
12
+ OpenClaw also registers `ollama-cloud` as a first-class hosted provider id for
13
+ direct Ollama Cloud use. Use refs like `ollama-cloud/kimi-k2.5:cloud` when you
14
+ want cloud-only routing without sharing the local `ollama` provider id.
15
+
16
+ For the dedicated cloud-only setup page, see [Ollama Cloud](/providers/ollama-cloud).
17
+
18
+ <Warning>
19
+ **Remote Ollama users**: Do not use the `/v1` OpenAI-compatible URL (`http://host:11434/v1`) with OpenClaw. This breaks tool calling and models may output raw tool JSON as plain text. Use the native Ollama API URL instead: `baseUrl: "http://host:11434"` (no `/v1`).
20
+ </Warning>
21
+
22
+ Ollama provider config uses `baseUrl` as the canonical key. OpenClaw also accepts `baseURL` for compatibility with OpenAI SDK-style examples, but new config should prefer `baseUrl`.
23
+
24
+ ## Auth rules
25
+
26
+ <AccordionGroup>
27
+ <Accordion title="Local and LAN hosts">
28
+ Local and LAN Ollama hosts do not need a real bearer token. OpenClaw uses the local `ollama-local` marker only for loopback, private-network, `.local`, and bare-hostname Ollama base URLs.
29
+ </Accordion>
30
+ <Accordion title="Remote and Ollama Cloud hosts">
31
+ Remote public hosts and Ollama Cloud (`https://ollama.com`) require a real credential through `OLLAMA_API_KEY`, an auth profile, or the provider's `apiKey`. For direct hosted use, prefer provider `ollama-cloud`.
32
+ </Accordion>
33
+ <Accordion title="Custom provider ids">
34
+ Custom provider ids that set `api: "ollama"` follow the same rules. For example, an `ollama-remote` provider that points at a private LAN Ollama host can use `apiKey: "ollama-local"` and sub-agents will resolve that marker through the Ollama provider hook instead of treating it as a missing credential. Memory search can also set `agents.defaults.memorySearch.provider` to that custom provider id so embeddings use the matching Ollama endpoint.
35
+ </Accordion>
36
+ <Accordion title="Auth profiles">
37
+ `auth-profiles.json` stores the credential for a provider id. Put endpoint settings (`baseUrl`, `api`, model ids, headers, timeouts) in `models.providers.<id>`. Older flat auth-profile files such as `{ "ollama-windows": { "apiKey": "ollama-local" } }` are not a runtime format; run `openclaw doctor --fix` to rewrite them to the canonical `ollama-windows:default` API-key profile with a backup. `baseUrl` in that file is compatibility noise and should be moved to provider config.
38
+ </Accordion>
39
+ <Accordion title="Memory embedding scope">
40
+ When Ollama is used for memory embeddings, bearer auth is scoped to the host where it was declared:
41
+
42
+ - A provider-level key is sent only to that provider's Ollama host.
43
+ - `agents.*.memorySearch.remote.apiKey` is sent only to its remote embedding host.
44
+ - A pure `OLLAMA_API_KEY` env value is treated as the Ollama Cloud convention, not sent to local or self-hosted hosts by default.
45
+
46
+ </Accordion>
47
+ </AccordionGroup>
48
+
49
+ ## Getting started
50
+
51
+ Choose your preferred setup method and mode.
52
+
53
+ <Tabs>
54
+ <Tab title="Onboarding (recommended)">
55
+ **Best for:** fastest path to a working Ollama cloud or local setup.
56
+
57
+ <Steps>
58
+ <Step title="Run onboarding">
59
+ ```bash
60
+ openclaw onboard
61
+ ```
62
+
63
+ Select **Ollama** from the provider list.
64
+ </Step>
65
+ <Step title="Choose your mode">
66
+ - **Cloud + Local** — local Ollama host plus cloud models routed through that host
67
+ - **Cloud only** — hosted Ollama models via `https://ollama.com`
68
+ - **Local only** — local models only
69
+
70
+ </Step>
71
+ <Step title="Select a model">
72
+ `Cloud only` prompts for `OLLAMA_API_KEY` and suggests hosted cloud defaults. `Cloud + Local` and `Local only` ask for an Ollama base URL, discover available models, and auto-pull the selected local model if it is not available yet. When Ollama reports an installed `:latest` tag such as `gemma4:latest`, setup shows that installed model once instead of showing both `gemma4` and `gemma4:latest` or pulling the bare alias again. `Cloud + Local` also checks whether that Ollama host is signed in for cloud access.
73
+ </Step>
74
+ <Step title="Verify the model is available">
75
+ ```bash
76
+ openclaw models list --provider ollama
77
+ ```
78
+ </Step>
79
+ </Steps>
80
+
81
+ ### Non-interactive mode
82
+
83
+ ```bash
84
+ openclaw onboard --non-interactive \
85
+ --auth-choice ollama \
86
+ --accept-risk
87
+ ```
88
+
89
+ Optionally specify a custom base URL or model:
90
+
91
+ ```bash
92
+ openclaw onboard --non-interactive \
93
+ --auth-choice ollama \
94
+ --custom-base-url "http://ollama-host:11434" \
95
+ --custom-model-id "qwen3.5:27b" \
96
+ --accept-risk
97
+ ```
98
+
99
+ </Tab>
100
+
101
+ <Tab title="Manual setup">
102
+ **Best for:** full control over cloud or local setup.
103
+
104
+ <Steps>
105
+ <Step title="Choose cloud or local">
106
+ - **Cloud + Local**: install Ollama, sign in with `ollama signin`, and route cloud requests through that host
107
+ - **Cloud only**: use `https://ollama.com` with an `OLLAMA_API_KEY`
108
+ - **Local only**: install Ollama from [ollama.com/download](https://ollama.com/download)
109
+
110
+ </Step>
111
+ <Step title="Pull a local model (local only)">
112
+ ```bash
113
+ ollama pull gemma4
114
+ # or
115
+ ollama pull gpt-oss:20b
116
+ # or
117
+ ollama pull llama3.3
118
+ ```
119
+ </Step>
120
+ <Step title="Enable Ollama for OpenClaw">
121
+ For `Cloud only`, use your real `OLLAMA_API_KEY`. For host-backed setups, any placeholder value works:
122
+
123
+ ```bash
124
+ # Cloud
125
+ export OLLAMA_API_KEY="your-ollama-api-key"
126
+
127
+ # Local-only
128
+ export OLLAMA_API_KEY="ollama-local"
129
+
130
+ # Or configure in your config file
131
+ openclaw config set models.providers.ollama.apiKey "OLLAMA_API_KEY"
132
+ ```
133
+ </Step>
134
+ <Step title="Inspect and set your model">
135
+ ```bash
136
+ openclaw models list
137
+ openclaw models set ollama/gemma4
138
+ ```
139
+
140
+ Or set the default in config:
141
+
142
+ ```json5
143
+ {
144
+ agents: {
145
+ defaults: {
146
+ model: { primary: "ollama/gemma4" },
147
+ },
148
+ },
149
+ }
150
+ ```
151
+ </Step>
152
+ </Steps>
153
+
154
+ </Tab>
155
+ </Tabs>
156
+
157
+ ## Cloud models
158
+
159
+ <Tabs>
160
+ <Tab title="Cloud + Local">
161
+ `Cloud + Local` uses a reachable Ollama host as the control point for both local and cloud models. This is Ollama's preferred hybrid flow.
162
+
163
+ Use **Cloud + Local** during setup. OpenClaw prompts for the Ollama base URL, discovers local models from that host, and checks whether the host is signed in for cloud access with `ollama signin`. When the host is signed in, OpenClaw also suggests hosted cloud defaults such as `kimi-k2.5:cloud`, `minimax-m2.7:cloud`, and `glm-5.1:cloud`.
164
+
165
+ If the host is not signed in yet, OpenClaw keeps the setup local-only until you run `ollama signin`.
166
+
167
+ </Tab>
168
+
169
+ <Tab title="Cloud only">
170
+ `Cloud only` runs against Ollama's hosted API at `https://ollama.com`.
171
+
172
+ Use **Cloud only** during setup. OpenClaw prompts for `OLLAMA_API_KEY`, sets `baseUrl: "https://ollama.com"`, and seeds the hosted cloud model list. This path does **not** require a local Ollama server or `ollama signin`.
173
+
174
+ The cloud model list shown during `openclaw onboard` is populated live from `https://ollama.com/api/tags`, capped at 500 entries, so the picker reflects the current hosted catalog rather than a static seed. If `ollama.com` is unreachable or returns no models at setup time, OpenClaw falls back to the previous hardcoded suggestions so onboarding still completes.
175
+
176
+ You can also configure the first-class cloud provider directly:
177
+
178
+ ```bash
179
+ openclaw onboard --auth-choice ollama-cloud
180
+ openclaw models set ollama-cloud/kimi-k2.5:cloud
181
+ ```
182
+
183
+ </Tab>
184
+
185
+ <Tab title="Local only">
186
+ In local-only mode, OpenClaw discovers models from the configured Ollama instance. This path is for local or self-hosted Ollama servers.
187
+
188
+ OpenClaw currently suggests `gemma4` as the local default.
189
+
190
+ </Tab>
191
+ </Tabs>
192
+
193
+ ## Model discovery (implicit provider)
194
+
195
+ When you set `OLLAMA_API_KEY` (or an auth profile) and **do not** define `models.providers.ollama` or another custom remote provider with `api: "ollama"`, OpenClaw discovers models from the local Ollama instance at `http://127.0.0.1:11434`.
196
+
197
+ | Behavior | Detail |
198
+ | -------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
199
+ | Catalog query | Queries `/api/tags` |
200
+ | Capability detection | Uses best-effort `/api/show` lookups to read `contextWindow`, expanded `num_ctx` Modelfile parameters, and capabilities including vision/tools |
201
+ | Vision models | Models with a `vision` capability reported by `/api/show` are marked as image-capable (`input: ["text", "image"]`), so OpenClaw auto-injects images into the prompt |
202
+ | Reasoning detection | Uses `/api/show` capabilities when available, including `thinking`; falls back to a model-name heuristic (`r1`, `reasoning`, `think`) when Ollama omits capabilities |
203
+ | Token limits | Sets `maxTokens` to the default Ollama max-token cap used by OpenClaw |
204
+ | Costs | Sets all costs to `0` |
205
+
206
+ This avoids manual model entries while keeping the catalog aligned with the local Ollama instance. You can use a full ref such as `ollama/<pulled-model>:latest` in local `infer model run`; OpenClaw resolves that installed model from Ollama's live catalog without requiring a hand-written `models.json` entry.
207
+
208
+ For signed-in Ollama hosts, some `:cloud` models may be usable through `/api/chat`
209
+ and `/api/show` before they appear in `/api/tags`. When you explicitly select a
210
+ full `ollama/<model>:cloud` ref, OpenClaw validates that exact missing model with
211
+ `/api/show` and adds it to the runtime catalog only if Ollama confirms model
212
+ metadata. Typos still fail as unknown models instead of being auto-created.
213
+
214
+ ```bash
215
+ # See what models are available
216
+ ollama list
217
+ openclaw models list
218
+ ```
219
+
220
+ For a narrow text-generation smoke test that avoids the full agent tool surface,
221
+ use local `infer model run` with a full Ollama model ref:
222
+
223
+ ```bash
224
+ OLLAMA_API_KEY=ollama-local \
225
+ openclaw infer model run \
226
+ --local \
227
+ --model ollama/llama3.2:latest \
228
+ --prompt "Reply with exactly: pong" \
229
+ --json
230
+ ```
231
+
232
+ That path still uses OpenClaw's configured provider, auth, and native Ollama
233
+ transport, but it does not start a chat-agent turn or load MCP/tool context. If
234
+ this succeeds while normal agent replies fail, troubleshoot the model's agent
235
+ prompt/tool capacity next.
236
+
237
+ For a narrow vision-model smoke test on the same lean path, add one or more
238
+ image files to `infer model run`. This sends the prompt and image directly to
239
+ the selected Ollama vision model without loading chat tools, memory, or prior
240
+ session context:
241
+
242
+ ```bash
243
+ OLLAMA_API_KEY=ollama-local \
244
+ openclaw infer model run \
245
+ --local \
246
+ --model ollama/qwen2.5vl:7b \
247
+ --prompt "Describe this image in one sentence." \
248
+ --file ./photo.jpg \
249
+ --json
250
+ ```
251
+
252
+ `model run --file` accepts files detected as `image/*`, including common PNG,
253
+ JPEG, and WebP inputs. Non-image files are rejected before Ollama is called.
254
+ For speech recognition, use `openclaw infer audio transcribe` instead.
255
+
256
+ When you switch a conversation with `/model ollama/<model>`, OpenClaw treats
257
+ that as an exact user selection. If the configured Ollama `baseUrl` is
258
+ unreachable, the next reply fails with the provider error instead of silently
259
+ answering from another configured fallback model.
260
+
261
+ Isolated cron jobs do one extra local safety check before they start the agent
262
+ turn. If the selected model resolves to a local, private-network, or `.local`
263
+ Ollama provider and `/api/tags` is unreachable, OpenClaw records that cron run
264
+ as `skipped` with the selected `ollama/<model>` in the error text. The endpoint
265
+ preflight is cached for 5 minutes, so multiple cron jobs pointed at the same
266
+ stopped Ollama daemon do not all launch failing model requests.
267
+
268
+ Live-verify the local text path, native stream path, and embeddings against
269
+ local Ollama with:
270
+
271
+ ```bash
272
+ OPENCLAW_LIVE_TEST=1 OPENCLAW_LIVE_OLLAMA=1 OPENCLAW_LIVE_OLLAMA_WEB_SEARCH=0 \
273
+ pnpm test:live -- extensions/ollama/ollama.live.test.ts
274
+ ```
275
+
276
+ For Ollama Cloud API-key smoke tests, point the live test at `https://ollama.com`
277
+ and choose a hosted model from the current catalog:
278
+
279
+ ```bash
280
+ export OLLAMA_API_KEY='<your-ollama-cloud-api-key>'
281
+
282
+ OPENCLAW_LIVE_TEST=1 \
283
+ OPENCLAW_LIVE_OLLAMA=1 \
284
+ OPENCLAW_LIVE_OLLAMA_BASE_URL=https://ollama.com \
285
+ OPENCLAW_LIVE_OLLAMA_MODEL=glm-5.1:cloud \
286
+ OPENCLAW_LIVE_OLLAMA_WEB_SEARCH=1 \
287
+ pnpm test:live -- extensions/ollama/ollama.live.test.ts
288
+ ```
289
+
290
+ The cloud smoke runs text, native stream, and web search. It skips embeddings by
291
+ default for `https://ollama.com` because Ollama Cloud API keys may not authorize
292
+ `/api/embed`. Set `OPENCLAW_LIVE_OLLAMA_EMBEDDINGS=1` when you explicitly want
293
+ the live test to fail if the configured cloud key cannot use the embed endpoint.
294
+
295
+ To add a new model, simply pull it with Ollama:
296
+
297
+ ```bash
298
+ ollama pull mistral
299
+ ```
300
+
301
+ The new model will be automatically discovered and available to use.
302
+
303
+ <Note>
304
+ If you set `models.providers.ollama` explicitly, or configure a custom remote provider such as `models.providers.ollama-cloud` with `api: "ollama"`, auto-discovery is skipped and you must define models manually. Loopback custom providers such as `http://127.0.0.2:11434` are still treated as local. See the explicit config section below.
305
+ </Note>
306
+
307
+ ## Vision and image description
308
+
309
+ The bundled Ollama plugin registers Ollama as an image-capable media-understanding provider. This lets OpenClaw route explicit image-description requests and configured image-model defaults through local or hosted Ollama vision models.
310
+
311
+ For local vision, pull a model that supports images:
312
+
313
+ ```bash
314
+ ollama pull qwen2.5vl:7b
315
+ export OLLAMA_API_KEY="ollama-local"
316
+ ```
317
+
318
+ Then verify with the infer CLI:
319
+
320
+ ```bash
321
+ openclaw infer image describe \
322
+ --file ./photo.jpg \
323
+ --model ollama/qwen2.5vl:7b \
324
+ --json
325
+ ```
326
+
327
+ `--model` must be a full `<provider/model>` ref. When it is set, `openclaw infer image describe` runs that model directly instead of skipping description because the model supports native vision.
328
+
329
+ Use `infer image describe` when you want OpenClaw's image-understanding provider flow, configured `agents.defaults.imageModel`, and image-description output shape. Use `infer model run --file` when you want a raw multimodal model probe with a custom prompt and one or more images.
330
+
331
+ To make Ollama the default image-understanding model for inbound media, configure `agents.defaults.imageModel`:
332
+
333
+ ```json5
334
+ {
335
+ agents: {
336
+ defaults: {
337
+ imageModel: {
338
+ primary: "ollama/qwen2.5vl:7b",
339
+ },
340
+ },
341
+ },
342
+ }
343
+ ```
344
+
345
+ Prefer the full `ollama/<model>` ref. If the same model is listed under `models.providers.ollama.models` with `input: ["text", "image"]` and no other configured image provider exposes that bare model ID, OpenClaw also normalizes a bare `imageModel` ref such as `qwen2.5vl:7b` to `ollama/qwen2.5vl:7b`. If more than one configured image provider has the same bare ID, use the provider prefix explicitly.
346
+
347
+ Slow local vision models can need a longer image-understanding timeout than cloud models. They can also crash or stop when Ollama tries to allocate the full advertised vision context on constrained hardware. Set a capability timeout, and cap `num_ctx` on the model entry when you only need a normal image-description turn:
348
+
349
+ ```json5
350
+ {
351
+ models: {
352
+ providers: {
353
+ ollama: {
354
+ models: [
355
+ {
356
+ id: "qwen2.5vl:7b",
357
+ name: "qwen2.5vl:7b",
358
+ input: ["text", "image"],
359
+ params: { num_ctx: 2048, keep_alive: "1m" },
360
+ },
361
+ ],
362
+ },
363
+ },
364
+ },
365
+ tools: {
366
+ media: {
367
+ image: {
368
+ timeoutSeconds: 180,
369
+ models: [{ provider: "ollama", model: "qwen2.5vl:7b", timeoutSeconds: 300 }],
370
+ },
371
+ },
372
+ },
373
+ }
374
+ ```
375
+
376
+ This timeout applies to inbound image understanding and to the explicit `image` tool the agent can call during a turn. Provider-level `models.providers.ollama.timeoutSeconds` still controls the underlying Ollama HTTP request guard for normal model calls.
377
+
378
+ Live-verify the explicit image tool against local Ollama with:
379
+
380
+ ```bash
381
+ OPENCLAW_LIVE_TEST=1 OPENCLAW_LIVE_OLLAMA_IMAGE=1 \
382
+ pnpm test:live -- src/agents/tools/image-tool.ollama.live.test.ts
383
+ ```
384
+
385
+ If you define `models.providers.ollama.models` manually, mark vision models with image input support:
386
+
387
+ ```json5
388
+ {
389
+ id: "qwen2.5vl:7b",
390
+ name: "qwen2.5vl:7b",
391
+ input: ["text", "image"],
392
+ contextWindow: 128000,
393
+ maxTokens: 8192,
394
+ }
395
+ ```
396
+
397
+ OpenClaw rejects image-description requests for models that are not marked image-capable. With implicit discovery, OpenClaw reads this from Ollama when `/api/show` reports a vision capability.
398
+
399
+ ## Configuration
400
+
401
+ <Tabs>
402
+ <Tab title="Basic (implicit discovery)">
403
+ The simplest local-only enablement path is via environment variable:
404
+
405
+ ```bash
406
+ export OLLAMA_API_KEY="ollama-local"
407
+ ```
408
+
409
+ <Tip>
410
+ If `OLLAMA_API_KEY` is set, you can omit `apiKey` in the provider entry and OpenClaw will fill it for availability checks.
411
+ </Tip>
412
+
413
+ </Tab>
414
+
415
+ <Tab title="Explicit (manual models)">
416
+ Use explicit config when you want hosted cloud setup, Ollama runs on another host/port, you want to force specific context windows or model lists, or you want fully manual model definitions.
417
+
418
+ ```json5
419
+ {
420
+ models: {
421
+ providers: {
422
+ ollama: {
423
+ baseUrl: "https://ollama.com",
424
+ apiKey: "OLLAMA_API_KEY",
425
+ api: "ollama",
426
+ models: [
427
+ {
428
+ id: "kimi-k2.5:cloud",
429
+ name: "kimi-k2.5:cloud",
430
+ reasoning: false,
431
+ input: ["text", "image"],
432
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
433
+ contextWindow: 128000,
434
+ maxTokens: 8192
435
+ }
436
+ ]
437
+ }
438
+ }
439
+ }
440
+ }
441
+ ```
442
+
443
+ </Tab>
444
+
445
+ <Tab title="Custom base URL">
446
+ If Ollama is running on a different host or port (explicit config disables auto-discovery, so define models manually):
447
+
448
+ ```json5
449
+ {
450
+ models: {
451
+ providers: {
452
+ ollama: {
453
+ apiKey: "ollama-local",
454
+ baseUrl: "http://ollama-host:11434", // No /v1 - use native Ollama API URL
455
+ api: "ollama", // Set explicitly to guarantee native tool-calling behavior
456
+ timeoutSeconds: 300, // Optional: give cold local models longer to connect and stream
457
+ models: [
458
+ {
459
+ id: "qwen3:32b",
460
+ name: "qwen3:32b",
461
+ params: {
462
+ keep_alive: "15m", // Optional: keep the model loaded between turns
463
+ },
464
+ },
465
+ ],
466
+ },
467
+ },
468
+ },
469
+ }
470
+ ```
471
+
472
+ <Warning>
473
+ Do not add `/v1` to the URL. The `/v1` path uses OpenAI-compatible mode, where tool calling is not reliable. Use the base Ollama URL without a path suffix.
474
+ </Warning>
475
+
476
+ </Tab>
477
+ </Tabs>
478
+
479
+ ## Common recipes
480
+
481
+ Use these as starting points and replace model IDs with the exact names from `ollama list` or `openclaw models list --provider ollama`.
482
+
483
+ <AccordionGroup>
484
+ <Accordion title="Local model with auto-discovery">
485
+ Use this when Ollama runs on the same machine as the Gateway and you want OpenClaw to discover the installed models automatically.
486
+
487
+ ```bash
488
+ ollama serve
489
+ ollama pull gemma4
490
+ export OLLAMA_API_KEY="ollama-local"
491
+ openclaw models list --provider ollama
492
+ openclaw models set ollama/gemma4
493
+ ```
494
+
495
+ This path keeps config minimal. Do not add a `models.providers.ollama` block unless you want to define models manually.
496
+
497
+ </Accordion>
498
+
499
+ <Accordion title="LAN Ollama host with manual models">
500
+ Use native Ollama URLs for LAN hosts. Do not add `/v1`.
501
+
502
+ ```json5
503
+ {
504
+ models: {
505
+ providers: {
506
+ ollama: {
507
+ baseUrl: "http://gpu-box.local:11434",
508
+ apiKey: "ollama-local",
509
+ api: "ollama",
510
+ timeoutSeconds: 300,
511
+ contextWindow: 32768,
512
+ maxTokens: 8192,
513
+ models: [
514
+ {
515
+ id: "qwen3.5:9b",
516
+ name: "qwen3.5:9b",
517
+ reasoning: true,
518
+ input: ["text"],
519
+ params: {
520
+ num_ctx: 32768,
521
+ thinking: false,
522
+ keep_alive: "15m",
523
+ },
524
+ },
525
+ ],
526
+ },
527
+ },
528
+ },
529
+ agents: {
530
+ defaults: {
531
+ model: { primary: "ollama/qwen3.5:9b" },
532
+ },
533
+ },
534
+ }
535
+ ```
536
+
537
+ `contextWindow` is the OpenClaw-side context budget. `params.num_ctx` is sent to Ollama for the request. Keep them aligned when your hardware cannot run the model's full advertised context.
538
+
539
+ </Accordion>
540
+
541
+ <Accordion title="Ollama Cloud only">
542
+ Use this when you do not run a local daemon and want hosted Ollama models directly.
543
+
544
+ ```bash
545
+ export OLLAMA_API_KEY="your-ollama-api-key"
546
+ ```
547
+
548
+ ```json5
549
+ {
550
+ models: {
551
+ providers: {
552
+ ollama: {
553
+ baseUrl: "https://ollama.com",
554
+ apiKey: "OLLAMA_API_KEY",
555
+ api: "ollama",
556
+ models: [
557
+ {
558
+ id: "kimi-k2.5:cloud",
559
+ name: "kimi-k2.5:cloud",
560
+ reasoning: false,
561
+ input: ["text", "image"],
562
+ contextWindow: 128000,
563
+ maxTokens: 8192,
564
+ },
565
+ ],
566
+ },
567
+ },
568
+ },
569
+ agents: {
570
+ defaults: {
571
+ model: { primary: "ollama/kimi-k2.5:cloud" },
572
+ },
573
+ },
574
+ }
575
+ ```
576
+
577
+ </Accordion>
578
+
579
+ <Accordion title="Cloud plus local through a signed-in daemon">
580
+ Use this when a local or LAN Ollama daemon is signed in with `ollama signin` and should serve both local models and `:cloud` models.
581
+
582
+ ```bash
583
+ ollama signin
584
+ ollama pull gemma4
585
+ ```
586
+
587
+ ```json5
588
+ {
589
+ models: {
590
+ providers: {
591
+ ollama: {
592
+ baseUrl: "http://127.0.0.1:11434",
593
+ apiKey: "ollama-local",
594
+ api: "ollama",
595
+ timeoutSeconds: 300,
596
+ models: [
597
+ { id: "gemma4", name: "gemma4", input: ["text"] },
598
+ { id: "kimi-k2.5:cloud", name: "kimi-k2.5:cloud", input: ["text", "image"] },
599
+ ],
600
+ },
601
+ },
602
+ },
603
+ agents: {
604
+ defaults: {
605
+ model: {
606
+ primary: "ollama/gemma4",
607
+ fallbacks: ["ollama/kimi-k2.5:cloud"],
608
+ },
609
+ },
610
+ },
611
+ }
612
+ ```
613
+
614
+ </Accordion>
615
+
616
+ <Accordion title="Multiple Ollama hosts">
617
+ Use custom provider IDs when you have more than one Ollama server. Each provider gets its own host, models, auth, timeout, and model refs.
618
+
619
+ ```json5
620
+ {
621
+ models: {
622
+ providers: {
623
+ "ollama-fast": {
624
+ baseUrl: "http://mini.local:11434",
625
+ apiKey: "ollama-local",
626
+ api: "ollama",
627
+ contextWindow: 32768,
628
+ models: [{ id: "gemma4", name: "gemma4", input: ["text"] }],
629
+ },
630
+ "ollama-large": {
631
+ baseUrl: "http://gpu-box.local:11434",
632
+ apiKey: "ollama-local",
633
+ api: "ollama",
634
+ timeoutSeconds: 420,
635
+ contextWindow: 131072,
636
+ maxTokens: 16384,
637
+ models: [{ id: "qwen3.5:27b", name: "qwen3.5:27b", input: ["text"] }],
638
+ },
639
+ },
640
+ },
641
+ agents: {
642
+ defaults: {
643
+ model: {
644
+ primary: "ollama-fast/gemma4",
645
+ fallbacks: ["ollama-large/qwen3.5:27b"],
646
+ },
647
+ },
648
+ },
649
+ }
650
+ ```
651
+
652
+ When OpenClaw sends the request, the active provider prefix is stripped so `ollama-large/qwen3.5:27b` reaches Ollama as `qwen3.5:27b`.
653
+
654
+ </Accordion>
655
+
656
+ <Accordion title="Lean local model profile">
657
+ Some local models can answer simple prompts but struggle with the full agent tool surface. Start by limiting tools and context before changing global runtime settings.
658
+
659
+ ```json5
660
+ {
661
+ agents: {
662
+ list: [
663
+ {
664
+ id: "local",
665
+ experimental: {
666
+ localModelLean: true,
667
+ },
668
+ model: { primary: "ollama/gemma4" },
669
+ },
670
+ ],
671
+ },
672
+ models: {
673
+ providers: {
674
+ ollama: {
675
+ baseUrl: "http://127.0.0.1:11434",
676
+ apiKey: "ollama-local",
677
+ api: "ollama",
678
+ contextWindow: 32768,
679
+ models: [
680
+ {
681
+ id: "gemma4",
682
+ name: "gemma4",
683
+ input: ["text"],
684
+ params: { num_ctx: 32768 },
685
+ compat: { supportsTools: false },
686
+ },
687
+ ],
688
+ },
689
+ },
690
+ },
691
+ }
692
+ ```
693
+
694
+ Use `compat.supportsTools: false` only when the model or server reliably fails on tool schemas. It trades agent capability for stability.
695
+ `localModelLean` removes the browser, cron, and message tools from the direct agent surface and defaults larger catalogs behind structured Tool Search controls except when a run must keep direct message delivery semantics, but it does not change Ollama's runtime context or thinking mode. Pair it with explicit `params.num_ctx` and `params.thinking: false` for small Qwen-style thinking models that loop or spend their response budget on hidden reasoning.
696
+
697
+ </Accordion>
698
+ </AccordionGroup>
699
+
700
+ ### Model selection
701
+
702
+ Once configured, all your Ollama models are available:
703
+
704
+ ```json5
705
+ {
706
+ agents: {
707
+ defaults: {
708
+ model: {
709
+ primary: "ollama/gpt-oss:20b",
710
+ fallbacks: ["ollama/llama3.3", "ollama/qwen2.5-coder:32b"],
711
+ },
712
+ },
713
+ },
714
+ }
715
+ ```
716
+
717
+ Custom Ollama provider ids are also supported. When a model ref uses the active
718
+ provider prefix, such as `ollama-spark/qwen3:32b`, OpenClaw strips only that
719
+ prefix before calling Ollama so the server receives `qwen3:32b`.
720
+
721
+ For slow local models, prefer provider-scoped request tuning before raising the
722
+ whole agent runtime timeout:
723
+
724
+ ```json5
725
+ {
726
+ models: {
727
+ providers: {
728
+ ollama: {
729
+ timeoutSeconds: 300,
730
+ models: [
731
+ {
732
+ id: "gemma4:26b",
733
+ name: "gemma4:26b",
734
+ params: { keep_alive: "15m" },
735
+ },
736
+ ],
737
+ },
738
+ },
739
+ },
740
+ }
741
+ ```
742
+
743
+ `timeoutSeconds` applies to the model HTTP request, including connection setup,
744
+ headers, body streaming, and the total guarded-fetch abort. `params.keep_alive`
745
+ is forwarded to Ollama as top-level `keep_alive` on native `/api/chat` requests;
746
+ set it per model when first-turn load time is the bottleneck.
747
+
748
+ ### Quick verification
749
+
750
+ ```bash
751
+ # Ollama daemon visible to this machine
752
+ curl http://127.0.0.1:11434/api/tags
753
+
754
+ # OpenClaw catalog and selected model
755
+ openclaw models list --provider ollama
756
+ openclaw models status
757
+
758
+ # Direct model smoke
759
+ openclaw infer model run \
760
+ --model ollama/gemma4 \
761
+ --prompt "Reply with exactly: ok"
762
+ ```
763
+
764
+ For remote hosts, replace `127.0.0.1` with the host used in `baseUrl`. If `curl` works but OpenClaw does not, check whether the Gateway runs on a different machine, container, or service account.
765
+
766
+ ## Ollama Web Search
767
+
768
+ OpenClaw supports **Ollama Web Search** as a bundled `web_search` provider.
769
+
770
+ | Property | Detail |
771
+ | ----------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
772
+ | Host | Uses your configured Ollama host (`models.providers.ollama.baseUrl` when set, otherwise `http://127.0.0.1:11434`); `https://ollama.com` uses the hosted API directly |
773
+ | Auth | Key-free for signed-in local Ollama hosts; `OLLAMA_API_KEY` or configured provider auth for direct `https://ollama.com` search or auth-protected hosts |
774
+ | Requirement | Local/self-hosted hosts must be running and signed in with `ollama signin`; direct hosted search requires `baseUrl: "https://ollama.com"` plus a real Ollama API key |
775
+
776
+ Choose **Ollama Web Search** during `openclaw onboard` or `openclaw configure --section web`, or set:
777
+
778
+ ```json5
779
+ {
780
+ tools: {
781
+ web: {
782
+ search: {
783
+ provider: "ollama",
784
+ },
785
+ },
786
+ },
787
+ }
788
+ ```
789
+
790
+ For direct hosted search through Ollama Cloud:
791
+
792
+ ```json5
793
+ {
794
+ models: {
795
+ providers: {
796
+ ollama: {
797
+ baseUrl: "https://ollama.com",
798
+ apiKey: "OLLAMA_API_KEY",
799
+ api: "ollama",
800
+ models: [{ id: "kimi-k2.5:cloud", name: "kimi-k2.5:cloud", input: ["text"] }],
801
+ },
802
+ },
803
+ },
804
+ tools: {
805
+ web: {
806
+ search: { provider: "ollama" },
807
+ },
808
+ },
809
+ }
810
+ ```
811
+
812
+ For a signed-in local daemon, OpenClaw uses the daemon's `/api/experimental/web_search` proxy. For `https://ollama.com`, it calls the hosted `/api/web_search` endpoint directly.
813
+
814
+ <Note>
815
+ For the full setup and behavior details, see [Ollama Web Search](/tools/ollama-search).
816
+ </Note>
817
+
818
+ ## Advanced configuration
819
+
820
+ <AccordionGroup>
821
+ <Accordion title="Legacy OpenAI-compatible mode">
822
+ <Warning>
823
+ **Tool calling is not reliable in OpenAI-compatible mode.** Use this mode only if you need OpenAI format for a proxy and do not depend on native tool calling behavior.
824
+ </Warning>
825
+
826
+ If you need to use the OpenAI-compatible endpoint instead (for example, behind a proxy that only supports OpenAI format), set `api: "openai-completions"` explicitly:
827
+
828
+ ```json5
829
+ {
830
+ models: {
831
+ providers: {
832
+ ollama: {
833
+ baseUrl: "http://ollama-host:11434/v1",
834
+ api: "openai-completions",
835
+ injectNumCtxForOpenAICompat: true, // default: true
836
+ apiKey: "ollama-local",
837
+ models: [...]
838
+ }
839
+ }
840
+ }
841
+ }
842
+ ```
843
+
844
+ This mode may not support streaming and tool calling simultaneously. You may need to disable streaming with `params: { streaming: false }` in model config.
845
+
846
+ When `api: "openai-completions"` is used with Ollama, OpenClaw injects `options.num_ctx` by default so Ollama does not silently fall back to a 4096 context window. If your proxy/upstream rejects unknown `options` fields, disable this behavior:
847
+
848
+ ```json5
849
+ {
850
+ models: {
851
+ providers: {
852
+ ollama: {
853
+ baseUrl: "http://ollama-host:11434/v1",
854
+ api: "openai-completions",
855
+ injectNumCtxForOpenAICompat: false,
856
+ apiKey: "ollama-local",
857
+ models: [...]
858
+ }
859
+ }
860
+ }
861
+ }
862
+ ```
863
+
864
+ </Accordion>
865
+
866
+ <Accordion title="Context windows">
867
+ For auto-discovered models, OpenClaw uses the context window reported by Ollama when available, including larger `PARAMETER num_ctx` values from custom Modelfiles. Otherwise it falls back to the default Ollama context window used by OpenClaw.
868
+
869
+ You can set provider-level `contextWindow`, `contextTokens`, and `maxTokens` defaults for every model under that Ollama provider, then override them per model when needed. `contextWindow` is OpenClaw's prompt and compaction budget. Native Ollama requests leave `options.num_ctx` unset unless you explicitly configure `params.num_ctx`, so Ollama can apply its own model, `OLLAMA_CONTEXT_LENGTH`, or VRAM-based default. To cap or force Ollama's per-request runtime context without rebuilding a Modelfile, set `params.num_ctx`; invalid, zero, negative, and non-finite values are ignored. If you upgraded an older config that used only `contextWindow` or `maxTokens` to force a native Ollama request context, run `openclaw doctor --fix` to copy those explicit provider or model budgets into `params.num_ctx`. The OpenAI-compatible Ollama adapter still injects `options.num_ctx` by default from the configured `params.num_ctx` or `contextWindow`; disable that with `injectNumCtxForOpenAICompat: false` if your upstream rejects `options`.
870
+
871
+ Native Ollama model entries also accept the common Ollama runtime options under `params`, including `temperature`, `top_p`, `top_k`, `min_p`, `num_predict`, `stop`, `repeat_penalty`, `num_batch`, `num_thread`, and `use_mmap`. OpenClaw forwards only Ollama request keys, so OpenClaw runtime params such as `streaming` are not leaked to Ollama. Use `params.think` or `params.thinking` to send top-level Ollama `think`; `false` disables API-level thinking for Qwen-style thinking models.
872
+
873
+ ```json5
874
+ {
875
+ models: {
876
+ providers: {
877
+ ollama: {
878
+ contextWindow: 32768,
879
+ models: [
880
+ {
881
+ id: "llama3.3",
882
+ contextWindow: 131072,
883
+ maxTokens: 65536,
884
+ params: {
885
+ num_ctx: 32768,
886
+ temperature: 0.7,
887
+ top_p: 0.9,
888
+ thinking: false,
889
+ },
890
+ }
891
+ ]
892
+ }
893
+ }
894
+ }
895
+ }
896
+ ```
897
+
898
+ Per-model `agents.defaults.models["ollama/<model>"].params.num_ctx` works too. If both are configured, the explicit provider model entry wins over the agent default.
899
+
900
+ </Accordion>
901
+
902
+ <Accordion title="Thinking control">
903
+ For native Ollama models, OpenClaw forwards thinking control as Ollama expects it: top-level `think`, not `options.think`. Auto-discovered models whose `/api/show` response includes the `thinking` capability expose `/think low`, `/think medium`, `/think high`, and `/think max`; non-thinking models expose only `/think off`.
904
+
905
+ ```bash
906
+ openclaw agent --model ollama/gemma4 --thinking off
907
+ openclaw agent --model ollama/gemma4 --thinking low
908
+ ```
909
+
910
+ You can also set a model default:
911
+
912
+ ```json5
913
+ {
914
+ agents: {
915
+ defaults: {
916
+ models: {
917
+ "ollama/gemma4": {
918
+ thinking: "low",
919
+ },
920
+ },
921
+ },
922
+ },
923
+ }
924
+ ```
925
+
926
+ Per-model `params.think` or `params.thinking` can disable or force Ollama API thinking for a specific configured model. OpenClaw preserves those explicit model params when the active run only has the implicit default `off`; non-off runtime commands such as `/think medium` still override the active run.
927
+
928
+ </Accordion>
929
+
930
+ <Accordion title="Reasoning models">
931
+ OpenClaw treats models with names such as `deepseek-r1`, `reasoning`, or `think` as reasoning-capable by default.
932
+
933
+ ```bash
934
+ ollama pull deepseek-r1:32b
935
+ ```
936
+
937
+ No additional configuration is needed. OpenClaw marks them automatically.
938
+
939
+ </Accordion>
940
+
941
+ <Accordion title="Model costs">
942
+ Ollama is free and runs locally, so all model costs are set to $0. This applies to both auto-discovered and manually defined models.
943
+ </Accordion>
944
+
945
+ <Accordion title="Memory embeddings">
946
+ The bundled Ollama plugin registers a memory embedding provider for
947
+ [memory search](/concepts/memory). It uses the configured Ollama base URL
948
+ and API key, calls Ollama's current `/api/embed` endpoint, and batches
949
+ multiple memory chunks into one `input` request when possible.
950
+
951
+ When `proxy.enabled=true`, Ollama memory embedding requests to the exact
952
+ host-local loopback origin derived from the configured `baseUrl` use
953
+ OpenClaw's guarded direct path instead of the managed forward proxy. The
954
+ configured hostname must itself be `localhost` or a loopback IP literal;
955
+ DNS names that merely resolve to loopback still use the managed proxy path.
956
+ LAN, tailnet, private-network, and public Ollama hosts also stay on the
957
+ managed proxy path. Redirects to another host or port do not inherit trust.
958
+ Operators can still set the global `proxy.loopbackMode: "proxy"` setting to
959
+ send loopback traffic through the proxy, or `proxy.loopbackMode: "block"`
960
+ to deny loopback connections before opening a connection; see
961
+ [Managed proxy](/security/network-proxy#gateway-loopback-mode) for the
962
+ process-wide effect of this setting.
963
+
964
+ | Property | Value |
965
+ | ------------- | ------------------- |
966
+ | Default model | `nomic-embed-text` |
967
+ | Auto-pull | Yes — the embedding model is pulled automatically if not present locally |
968
+
969
+ Query-time embeddings use retrieval prefixes for models that require or recommend them, including `nomic-embed-text`, `qwen3-embedding`, and `mxbai-embed-large`. Memory document batches stay raw so existing indexes do not need a format migration.
970
+
971
+ To select Ollama as the memory search embedding provider:
972
+
973
+ ```json5
974
+ {
975
+ agents: {
976
+ defaults: {
977
+ memorySearch: {
978
+ provider: "ollama",
979
+ remote: {
980
+ // Default for Ollama. Raise on larger hosts if reindexing is too slow.
981
+ nonBatchConcurrency: 1,
982
+ },
983
+ },
984
+ },
985
+ },
986
+ }
987
+ ```
988
+
989
+ For a remote embedding host, keep auth scoped to that host:
990
+
991
+ ```json5
992
+ {
993
+ agents: {
994
+ defaults: {
995
+ memorySearch: {
996
+ provider: "ollama",
997
+ model: "nomic-embed-text",
998
+ remote: {
999
+ baseUrl: "http://gpu-box.local:11434",
1000
+ apiKey: "ollama-local",
1001
+ nonBatchConcurrency: 2,
1002
+ },
1003
+ },
1004
+ },
1005
+ },
1006
+ }
1007
+ ```
1008
+
1009
+ </Accordion>
1010
+
1011
+ <Accordion title="Streaming configuration">
1012
+ OpenClaw's Ollama integration uses the **native Ollama API** (`/api/chat`) by default, which fully supports streaming and tool calling simultaneously. No special configuration is needed.
1013
+
1014
+ For native `/api/chat` requests, OpenClaw also forwards thinking control directly to Ollama: `/think off` and `openclaw agent --thinking off` send top-level `think: false` unless an explicit model `params.think`/`params.thinking` value is configured, while `/think low|medium|high` send the matching top-level `think` effort string. `/think max` maps to Ollama's highest native effort, `think: "high"`.
1015
+
1016
+ <Tip>
1017
+ If you need to use the OpenAI-compatible endpoint, see the "Legacy OpenAI-compatible mode" section above. Streaming and tool calling may not work simultaneously in that mode.
1018
+ </Tip>
1019
+
1020
+ </Accordion>
1021
+ </AccordionGroup>
1022
+
1023
+ ## Troubleshooting
1024
+
1025
+ <AccordionGroup>
1026
+ <Accordion title="WSL2 crash loop (repeated reboots)">
1027
+ On WSL2 with NVIDIA/CUDA, the official Ollama Linux installer creates an `ollama.service` systemd unit with `Restart=always`. If that service autostarts and loads a GPU-backed model during WSL2 boot, Ollama can pin host memory while the model loads. Hyper-V memory reclaim cannot always reclaim those pinned pages, so Windows can terminate the WSL2 VM, systemd starts Ollama again, and the loop repeats.
1028
+
1029
+ Common evidence:
1030
+
1031
+ - repeated WSL2 reboots or terminations from the Windows side
1032
+ - high CPU in `app.slice` or `ollama.service` shortly after WSL2 startup
1033
+ - SIGTERM from systemd rather than a Linux OOM-killer event
1034
+
1035
+ OpenClaw logs a startup warning when it detects WSL2, `ollama.service` enabled with `Restart=always`, and visible CUDA markers.
1036
+
1037
+ Mitigation:
1038
+
1039
+ ```bash
1040
+ sudo systemctl disable ollama
1041
+ ```
1042
+
1043
+ Add this to `%USERPROFILE%\.wslconfig` on the Windows side, then run `wsl --shutdown`:
1044
+
1045
+ ```ini
1046
+ [experimental]
1047
+ autoMemoryReclaim=disabled
1048
+ ```
1049
+
1050
+ Set a shorter keep-alive in the Ollama service environment, or start Ollama manually only when you need it:
1051
+
1052
+ ```bash
1053
+ export OLLAMA_KEEP_ALIVE=5m
1054
+ ollama serve
1055
+ ```
1056
+
1057
+ See [ollama/ollama#11317](https://github.com/ollama/ollama/issues/11317).
1058
+
1059
+ </Accordion>
1060
+
1061
+ <Accordion title="Ollama not detected">
1062
+ Make sure Ollama is running and that you set `OLLAMA_API_KEY` (or an auth profile), and that you did **not** define an explicit `models.providers.ollama` entry:
1063
+
1064
+ ```bash
1065
+ ollama serve
1066
+ ```
1067
+
1068
+ Verify that the API is accessible:
1069
+
1070
+ ```bash
1071
+ curl http://localhost:11434/api/tags
1072
+ ```
1073
+
1074
+ </Accordion>
1075
+
1076
+ <Accordion title="No models available">
1077
+ If your model is not listed, either pull the model locally or define it explicitly in `models.providers.ollama`.
1078
+
1079
+ ```bash
1080
+ ollama list # See what's installed
1081
+ ollama pull gemma4
1082
+ ollama pull gpt-oss:20b
1083
+ ollama pull llama3.3 # Or another model
1084
+ ```
1085
+
1086
+ </Accordion>
1087
+
1088
+ <Accordion title="Connection refused">
1089
+ Check that Ollama is running on the correct port:
1090
+
1091
+ ```bash
1092
+ # Check if Ollama is running
1093
+ ps aux | grep ollama
1094
+
1095
+ # Or restart Ollama
1096
+ ollama serve
1097
+ ```
1098
+
1099
+ </Accordion>
1100
+
1101
+ <Accordion title="Remote host works with curl but not OpenClaw">
1102
+ Verify from the same machine and runtime that runs the Gateway:
1103
+
1104
+ ```bash
1105
+ openclaw gateway status --deep
1106
+ curl http://ollama-host:11434/api/tags
1107
+ ```
1108
+
1109
+ Common causes:
1110
+
1111
+ - `baseUrl` points at `localhost`, but the Gateway runs in Docker or on another host.
1112
+ - The URL uses `/v1`, which selects OpenAI-compatible behavior instead of native Ollama.
1113
+ - The remote host needs firewall or LAN binding changes on the Ollama side.
1114
+ - The model is present on your laptop's daemon but not on the remote daemon.
1115
+
1116
+ </Accordion>
1117
+
1118
+ <Accordion title="Model outputs tool JSON as text">
1119
+ This usually means the provider is using OpenAI-compatible mode or the model cannot handle tool schemas.
1120
+
1121
+ Prefer native Ollama mode:
1122
+
1123
+ ```json5
1124
+ {
1125
+ models: {
1126
+ providers: {
1127
+ ollama: {
1128
+ baseUrl: "http://ollama-host:11434",
1129
+ api: "ollama",
1130
+ },
1131
+ },
1132
+ },
1133
+ }
1134
+ ```
1135
+
1136
+ If a small local model still fails on tool schemas, set `compat.supportsTools: false` on that model entry and retest.
1137
+
1138
+ </Accordion>
1139
+
1140
+ <Accordion title="Kimi or GLM returns garbled symbols">
1141
+ Hosted Kimi/GLM responses that are long, non-linguistic symbol runs are treated as failed provider output instead of a successful assistant answer. That lets normal retry, fallback, or error handling take over without persisting the corrupted text into the session.
1142
+
1143
+ If it happens repeatedly, capture the raw model name, the current session file, and whether the run used `Cloud + Local` or `Cloud only`, then try a fresh session and a fallback model:
1144
+
1145
+ ```bash
1146
+ openclaw infer model run --model ollama/kimi-k2.5:cloud --prompt "Reply with exactly: ok" --json
1147
+ openclaw models set ollama/gemma4
1148
+ ```
1149
+
1150
+ </Accordion>
1151
+
1152
+ <Accordion title="Cold local model times out">
1153
+ Large local models can need a long first load before streaming begins. Keep the timeout scoped to the Ollama provider, and optionally ask Ollama to keep the model loaded between turns:
1154
+
1155
+ ```json5
1156
+ {
1157
+ models: {
1158
+ providers: {
1159
+ ollama: {
1160
+ timeoutSeconds: 300,
1161
+ models: [
1162
+ {
1163
+ id: "gemma4:26b",
1164
+ name: "gemma4:26b",
1165
+ params: { keep_alive: "15m" },
1166
+ },
1167
+ ],
1168
+ },
1169
+ },
1170
+ },
1171
+ }
1172
+ ```
1173
+
1174
+ If the host itself is slow to accept connections, `timeoutSeconds` also extends the guarded Undici connect timeout for this provider.
1175
+
1176
+ </Accordion>
1177
+
1178
+ <Accordion title="Large-context model is too slow or runs out of memory">
1179
+ Many Ollama models advertise contexts that are larger than your hardware can run comfortably. Native Ollama uses Ollama's own runtime context default unless you set `params.num_ctx`. Cap both OpenClaw's budget and Ollama's request context when you want predictable first-token latency:
1180
+
1181
+ ```json5
1182
+ {
1183
+ models: {
1184
+ providers: {
1185
+ ollama: {
1186
+ contextWindow: 32768,
1187
+ maxTokens: 8192,
1188
+ models: [
1189
+ {
1190
+ id: "qwen3.5:9b",
1191
+ name: "qwen3.5:9b",
1192
+ params: { num_ctx: 32768, thinking: false },
1193
+ },
1194
+ ],
1195
+ },
1196
+ },
1197
+ },
1198
+ }
1199
+ ```
1200
+
1201
+ Lower `contextWindow` first if OpenClaw is sending too much prompt. Lower `params.num_ctx` if Ollama is loading a runtime context that is too large for the machine. Lower `maxTokens` if generation runs too long.
1202
+
1203
+ </Accordion>
1204
+ </AccordionGroup>
1205
+
1206
+ <Note>
1207
+ More help: [Troubleshooting](/help/troubleshooting) and [FAQ](/help/faq).
1208
+ </Note>
1209
+
1210
+ ## Related
1211
+
1212
+ <CardGroup cols={2}>
1213
+ <Card title="Model providers" href="/concepts/model-providers" icon="layers">
1214
+ Overview of all providers, model refs, and failover behavior.
1215
+ </Card>
1216
+ <Card title="Model selection" href="/concepts/models" icon="brain">
1217
+ How to choose and configure models.
1218
+ </Card>
1219
+ <Card title="Ollama Web Search" href="/tools/ollama-search" icon="magnifying-glass">
1220
+ Full setup and behavior details for Ollama-powered web search.
1221
+ </Card>
1222
+ <Card title="Configuration" href="/gateway/configuration" icon="gear">
1223
+ Full config reference.
1224
+ </Card>
1225
+ </CardGroup>