Releases: openclaw/openclaw
Releases · openclaw/openclaw
openclaw 2026.3.13
Immutable
release. Only release title and notes can be modified.
This recovery release uses v2026.3.13-1 because GitHub immutable releases do not allow reusing v2026.3.13 after publication.
Important:
- This release exists to recover the broken
v2026.3.13tag/release path. - The corresponding npm version is still
2026.3.13, not2026.3.13-1. - The
-1suffix is for the Git tag and GitHub Release only.
What's Changed
- fix(compaction): use full-session token count for post-compaction sanity check by @efe-arv in #28347
- fix(telegram): thread media transport policy into SSRF by @obviyus in #44639
- fix: handle Discord gateway metadata fetch failures by @jalehman in #44397
- docs: move post-release changelog entries to Unreleased by @jalehman in #44691
- fix(session): preserve
lastAccountIdandlastThreadIdon session reset by @Lanfei in #44773 - Updated default model from openai-codex/gpt-5.3-codex to openai-codex/gpt-5.4 in tests. by @jrrcdev in #44367
- fix: address delivery dedupe review follow-ups by @frankekn in #44666
- CLI: align xhigh thinking help text by @frankekn in #44819
- docs: fix changelog credit for xhigh help by @frankekn in #44874
- fix(agents): drop Anthropic thinking blocks on replay by @frankekn in #44843
- docs: fix session key :dm: → :direct: by @Lanfei in #26506
- feat(android): redesign chat settings UI by @obviyus in #44894
- fix(agents): avoid injecting memory file twice on case-insensitive mounts by @Lanfei in #26054
- Docker: add OPENCLAW_TZ timezone support by @Lanfei in #34119
- Android: fix HttpURLConnection leak in TalkModeVoiceResolver by @Kaneki-x in #43780
- fix(agents): respect explicit user compat overrides for non-native openai-completions by @cheapestinference in #44432
- test(config): cover requiresOpenAiAnthropicToolPayload in compat schema fixture by @xingsy97 in #43438
- fix(agents): rephrase session reset prompt to avoid Azure content filter by @xingsy97 in #43403
- fix(config): add missing params field to agents.list[] validation schema by @atian8179 in #41171
- fix(android): use Google Code Scanner for onboarding QR by @obviyus in #45021
- fix: restore web fetch firecrawl config in runtime zod schema by @stim64045-spec in #42583
- fix(signal): add groups config to Signal channel schema by @unisone in #27199
- feat(ios): add onboarding welcome pager by @ngutman in #45054
- small addition to .gitignore by @Sovtoshi-SC in #42879
- fix(discovery): add missing domain to wideArea Zod config schema by @ingyukoh in #35615
- fix(ui): keep shared auth on insecure control-ui connects by @velvet-shark in #45088
- fix: preserve persona and language continuity in compaction summaries by @keepitmello in #10456
- ui: mobile navigation drawer & theme variant refinements by @BunsDev in #45107
- fix: resolve target agent workspace for cross-agent subagent spawns by @moshehbenavraham in #40176
- fix(ollama): hide native reasoning-only output by @frankekn in #45330
- test: annotate chat abort helper exports by @frankekn in #45346
- Fix incorrect rendering of brave costs in docs by @keelanfh in #44989
- security(docker): prevent gateway token leak in Docker build context by @xingsy97 in #44956
- refactor: remove redundant ?? undefined in Slack probe by @Cafexss in #44775
- fix(ui): restore chat-new-messages class on scroll pill button by @Astro-Han in #44856
- fix(windows): suppress visible console windows during restart and process cleanup by @MoerAI in #44842
- Slack: add opt-in interactive reply directives by @vincentkoc in #44607
- Docs: describe Slack interactive replies by @vincentkoc in #45463
- fix(cron): prevent isolated cron nested lane deadlocks by @vincentkoc in #45459
- Fix updater refresh cwd for service reinstall by @vincentkoc in #45452
- [codex] Polish sidebar status, agent skills, and chat rendering by @BunsDev in #45451
- perf(build): deduplicate plugin-sdk chunks to fix ~2x memory regression by @TarasShyn in #45426
- Guard updater service refresh against missing invocation cwd by @vincentkoc in #45486
- fix(browser): normalize batch act dispatch for selector and batch support by @vincentkoc in #45457
- docs(android): note that app is not publicly released yet by @eengad in #23051
- fix(browser): follow up batch failure and limit handling by @vincentkoc in #45506
- docker: add apt-get upgrade to all Dockerfiles by @jacobtomlinson in #45384
- fix(config): avoid Anthropic startup crash by @BunsDev in #45520
- test: preserve wrapper behavior for targeted runs by @Takhoffman in #45518
- UI: fix chat context notice icon sizing by @BunsDev in #45533
- fix(ui): stop dashboard chat history reload storm by @BunsDev in #45541
- fix: retry Telegram inbound media downloads over IPv4 fallback by @frankekn in #45327
- fix(feishu): preserve non-ASCII filenames in file uploads (#33912) by @fabiaodemianyang in #34262
- macOS: respect exec-approvals.json settings in gateway prompter by @sliekens in #13707
- fix(ui): keep oversized chat replies readable by @BunsDev in #45559
- fix(gateway/ui): restore control-ui auth bypass and classify connect failures by @sallyom in #45512
- fix(macos): prevent PortGuard from killing Docker Desktop in remote mode by @teslamint in #13798
- fix(sessions): create transcript file on chat.inject when missing by @2233admin in #36645
- Plugins: fail fast on channel and binding collisions by @vincentkoc in #45628
- fix(macos): align minimum Node.js version with runtime guard (22.16.0) by @ImLukeF in #45640
- fix(agents): preserve blank local custom-provider API keys after onboarding by @frankekn in #45631
- fix(browser): harden existing-session driver validation and session lifecycle by @odysseus0 in #45682
- fix(feishu): add early event-level dedup to prevent duplicate replies by @yunweibang in #43762
- fix(models): apply Gemini model-id normalization to google-vertex provider by @scoootscooob in #42435
- Gateway: treat scope-limited probe RPC as degraded reachability by @joshavant in #45622
- fix(gateway): bound unanswered client requests by @Takhoffman in #45689
New Contributors
- @jrrcdev made their first contribution in #44367
- @Kaneki-x made their first contribution in #43780
- @cheapestinference made their first contribution in #44432
- @xingsy97 made their first contribution in #43438
- @atian8179 made their first contribution in #41171
- @stim64045-spec made their first contribution in #42583
- @Sovtoshi-SC made their first contribution in #42879
- @keepitmello made their first contribution in #10456
- @moshehbenavraham made their first contribution in #40176
- @keelanfh made their first contribution in #44989
- @Cafexss made their first contribution in #44775
- @Astro-Han made their first contribution in #44856
- @eengad made their first contribution in https:...
openclaw 2026.3.13-beta.1
Immutable
release. Only release title and notes can be modified.
Pre-release for npm beta tag v2026.3.13-beta.1.
macOS assets are built with stable app version 2026.3.13 so they can be reused for the later non-beta release. appcast.xml is intentionally unchanged in this pre-release.
Changes
- Android/chat settings: redesign the chat settings sheet with grouped device and media sections, refresh the Connect and Voice tabs, and tighten the chat composer/session header for a denser mobile layout. (#44894) Thanks @obviyus.
- iOS/onboarding: add a first-run welcome pager before gateway setup, stop auto-opening the QR scanner, and show
/pair qrinstructions on the connect step. (#45054) Thanks @ngutman. - Browser/existing-session: add an official Chrome DevTools MCP attach mode for signed-in live Chrome sessions, with docs for
chrome://inspect/#remote-debuggingenablement and direct backlinks to Chrome’s own setup guides. - Browser/agents: add built-in
profile="user"for the logged-in host browser andprofile="chrome-relay"for the extension relay, so agent browser calls can prefer the real signed-in browser without the extrabrowserSessionselector. - Browser/act automation: add batched actions, selector targeting, and delayed clicks for browser act requests with normalized batch dispatch. Thanks @vincentkoc.
- Docker/timezone override: add
OPENCLAW_TZsodocker-setup.shcan pin gateway and CLI containers to a chosen IANA timezone instead of inheriting the daemon default. (#34119) Thanks @Lanfei. - Dependencies/pi: bump
@mariozechner/pi-agent-core,@mariozechner/pi-ai,@mariozechner/pi-coding-agent, and@mariozechner/pi-tuito0.58.0.
Fixes
- Dashboard/chat UI: stop reloading full chat history on every live tool result in dashboard v2 so tool-heavy runs no longer trigger UI freeze/re-render storms while the final event still refreshes persisted history. (#45541) Thanks @BunsDev.
- Ollama/reasoning visibility: stop promoting native
thinkingandreasoningfields into final assistant text so local reasoning models no longer leak internal thoughts in normal replies. (#45330) Thanks @xi7ang. - Android/onboarding QR scan: switch setup QR scanning to Google Code Scanner so onboarding uses a more reliable scanner instead of the legacy embedded ZXing flow. (#45021) Thanks @obviyus.
- Browser/existing-session: harden driver validation and session lifecycle so transport errors trigger reconnects while tool-level errors preserve the session, and extract shared ARIA role sets to deduplicate Playwright and Chrome MCP snapshot paths. (#45682) Thanks @odysseus0.
- Browser/existing-session: accept text-only
list_pagesandnew_pageresponses from Chrome DevTools MCP so live-session tab discovery and new-tab open flows keep working when the server omits structured page metadata. - Control UI/insecure auth: preserve explicit shared token and password auth on plain-HTTP Control UI connects so LAN and reverse-proxy sessions no longer drop shared auth before the first WebSocket handshake. (#45088) Thanks @velvet-shark.
- Gateway/session reset: preserve
lastAccountIdandlastThreadIdacross gateway session resets so replies keep routing back to the same account and thread after/reset. (#44773) Thanks @Lanfei. - macOS/onboarding: avoid self-restarting freshly bootstrapped launchd gateways and give new daemon installs longer to become healthy, so
openclaw onboard --install-daemonno longer false-fails on slower Macs and fresh VM snapshots. - Gateway/status: add
openclaw gateway status --require-rpcand clearer Linux non-interactive daemon-install failure reporting so automation can fail hard on probe misses instead of treating a printed RPC error as green. - macOS/exec approvals: respect per-agent exec approval settings in the gateway prompter, including allowlist fallback when the native prompt cannot be shown, so gateway-triggered
system.runrequests follow configured policy instead of always prompting or denying unexpectedly. (#13707) Thanks @sliekens. - Telegram/media downloads: thread the same direct or proxy transport policy into SSRF-guarded file fetches so inbound attachments keep working when Telegram falls back between env-proxy and direct networking. (#44639) Thanks @obviyus.
- Telegram/inbound media IPv4 fallback: retry SSRF-guarded Telegram file downloads once with the same IPv4 fallback policy as Bot API calls so fresh installs on IPv6-broken hosts no longer fail to download inbound images.
- Windows/gateway install: bound
schtaskscalls and fall back to the Startup-folder login item when task creation hangs, so nativeopenclaw gateway installfails fast instead of wedging forever on broken Scheduled Task setups. - Windows/gateway stop: resolve Startup-folder fallback listeners from the installed
gateway.cmdport, soopenclaw gateway stopnow actually kills fallback-launched gateway processes before restart. - Windows/gateway status: reuse the installed service command environment when reading runtime status, so startup-fallback gateways keep reporting the configured port and running state in
gateway status --jsoninstead of falling back togateway port unknown. - Windows/gateway auth: stop attaching device identity on local loopback shared-token and password gateway calls, so native Windows agent replies no longer log stale
device signature expiredfallback noise before succeeding. - Discord/gateway startup: treat plain-text and transient
/gateway/botmetadata fetch failures as transient startup errors so Discord gateway boot no longer crashes on unhandled rejections. (#44397) Thanks @jalehman. - Slack/probe: keep
auth.test()bot and team metadata mapping stable while simplifying the probe result path. (#44775) Thanks @Cafexss. - Dashboard/chat UI: render oversized plain-text replies as normal paragraphs instead of capped gray code blocks, so long desktop chat responses stay readable without tab-switching refreshes.
- Dashboard/chat UI: restore the
chat-new-messagesclass on the New messages scroll pill so the button uses its existing compact styling instead of rendering as a full-screen SVG overlay. (#44856) Thanks @Astro-Han. - Gateway/Control UI: restore the operator-only device-auth bypass and classify browser connect failures so origin and device-identity problems no longer show up as auth errors in the Control UI and web chat. (#45512) thanks @sallyom.
- macOS/voice wake: stop crashing wake-word command extraction when speech segment ranges come from a different transcript instance.
- Discord/allowlists: honor raw
guild_idwhen hydrated guild objects are missing so allowlisted channels and threads like#maintainersno longer get false-dropped before channel allowlist checks. - macOS/runtime locator: require Node >=22.16.0 during macOS runtime discovery so the app no longer accepts Node versions that the main runtime guard rejects later. Thanks @sumleo.
- Agents/custom providers: preserve blank API keys for loopback OpenAI-compatible custom providers by clearing the synthetic Authorization header at runtime, while keeping explicit apiKey and oauth/token config from silently downgrading into fake bearer auth. (#45631) Thanks @xinhuagu.
- Models/google-vertex Gemini flash-lite normalization: apply existing bare-ID preview normalization to
google-vertexmodel refs and provider configs sogoogle-vertex/gemini-3.1-flash-literesolves asgemini-3.1-flash-lite-preview. (#42435) thanks @scoootscooob. - iMessage/remote attachments: reject unsafe remote attachment paths before spawning SCP, so sender-controlled filenames can no longer inject shell metacharacters into remote media staging. Thanks @lintsinghua.
- Telegram/webhook auth: validate the Telegram webhook secret before reading or parsing request bodies, so unauthenticated requests are rejected immediately instead of consuming up to 1 MB first. Thanks @space08.
- Security/device pairing: make bootstrap setup codes single-use so pending device pairing requests cannot be silently replayed and widened to admin before approval. Thanks @tdjackey.
- Security/external content: strip zero-width and soft-hyphen marker-splitting characters during boundary sanitization so spoofed
EXTERNAL_UNTRUSTED_CONTENTmarkers fall back to the existing hardening path instead of bypassing marker normalization. - Security/exec approvals: unwrap more
pnpmruntime forms during approval binding, includingpnpm --reporter ... execand directpnpm nodefile runs, with matching regression coverage and docs updates. - Security/exec approvals: fail closed for Perl
-Mand-Iapproval flows so preload and load-path module resolution stays outside approval-backed runtime execution unless the operator uses a broader explicit trust path. - Security/exec approvals: recognize PowerShell
-Fileand-fwrapper forms during inline-command extraction so approval and command-analysis paths treat file-based PowerShell launches like the existing-Commandvariants. - Security/exec approvals: unwrap
envdispatch wrappers inside shell-segment allowlist resolution on macOS soenv FOO=bar /path/to/binresolves against the effective executable instead of the wrapper token. - Security/exec approvals: treat backslash-newline as shell line continuation during macOS shell-chain parsing so line-continued
$(substitutions fail closed instead of slipping past command-substitution checks. - Security/exec approvals: bind macOS skill auto-allow trust to both executable name and resolved path so same-basename binaries no longer inherit trust from unrelated skill bins.
- Build/plugin-sdk bundling: bundle plugin-sdk subpath entries in one shared build pass so published packages stop duplicating shared chunks and avoid the recent plugin-sdk memory blow-up. (#45426) Thanks @TarasShyn.
- Cron/isolated sessions: route nested cron-triggered embedded runner work onto the nested lane so isolated cron jobs no longer deadlock when compaction or other queued inner work runs. Thanks @vincentkoc...
openclaw 2026.3.12
Immutable
release. Only release title and notes can be modified.
Changes
- Control UI/dashboard-v2: refresh the gateway dashboard with modular overview, chat, config, agent, and session views, plus a command palette, mobile bottom tabs, and richer chat tools like slash commands, search, export, and pinned messages. (#41503) Thanks @BunsDev.
- OpenAI/GPT-5.4 fast mode: add configurable session-level fast toggles across
/fast, TUI, Control UI, and ACP, with per-model config defaults and OpenAI/Codex request shaping. - Anthropic/Claude fast mode: map the shared
/fasttoggle andparams.fastModeto direct Anthropic API-keyservice_tierrequests, with live verification for both Anthropic and OpenAI fast-mode tiers. - Models/plugins: move Ollama, vLLM, and SGLang onto the provider-plugin architecture, with provider-owned onboarding, discovery, model-picker setup, and post-selection hooks so core provider wiring is more modular.
- Docs/Kubernetes: Add a starter K8s install path with raw manifests, Kind setup, and deployment docs. Thanks @sallyom @dzianisv @egkristi
- Agents/subagents: add
sessions_yieldso orchestrators can end the current turn immediately, skip queued tool work, and carry a hidden follow-up payload into the next session turn. (#36537) thanks @jriff - Slack/agent replies: support
channelData.slack.blocksin the shared reply delivery path so agents can send Block Kit messages through standard Slack outbound delivery. (#44592) Thanks @vincentkoc.
Fixes
- Security/device pairing: switch
/pairandopenclaw qrsetup codes to short-lived bootstrap tokens so the next release no longer embeds shared gateway credentials in chat or QR pairing payloads. Thanks @lintsinghua. - Security/plugins: disable implicit workspace plugin auto-load so cloned repositories cannot execute workspace plugin code without an explicit trust decision. (
GHSA-99qw-6mr3-36qr)(#44174) Thanks @lintsinghua and @vincentkoc. - Models/Kimi Coding: send
anthropic-messagestools in native Anthropic format again sokimi-codingstops degrading tool calls into XML/plain-text pseudo invocations instead of realtool_useblocks. (#38669, #39907, #40552) Thanks @opriz. - TUI/chat log: reuse the active assistant message component for the same streaming run so
openclaw tuino longer renders duplicate assistant replies. (#35364) Thanks @lisitan. - Telegram/model picker: make inline model button selections persist the chosen session model correctly, clear overrides when selecting the configured default, and include effective fallback models in
/modelsbutton validation. (#40105) Thanks @avirweb. - Cron/proactive delivery: keep isolated direct cron sends out of the write-ahead resend queue so transient-send retries do not replay duplicate proactive messages after restart. (#40646) Thanks @openperf and @vincentkoc.
- Models/Kimi Coding: send the built-in
User-Agent: claude-code/0.1.0header by default forkimi-codingwhile still allowing explicit provider headers to override it, so Kimi Code subscription auth can work without a local header-injection proxy. (#30099) Thanks @Amineelfarssi and @vincentkoc. - Models/OpenAI Codex Spark: keep
gpt-5.3-codex-sparkworking on theopenai-codex/*path via resolver fallbacks and clearer Codex-only handling, while continuing to suppress the stale directopenai/*Spark row that OpenAI rejects live. - Ollama/Kimi Cloud: apply the Moonshot Kimi payload compatibility wrapper to Ollama-hosted Kimi models like
kimi-k2.5:cloud, so tool routing no longer breaks when thinking is enabled. (#41519) Thanks @vincentkoc. - Moonshot CN API: respect explicit
baseUrl(api.moonshot.cn) in implicit provider resolution so platform.moonshot.cn API keys authenticate correctly instead of returning HTTP 401. (#33637) Thanks @chengzhichao-xydt. - Kimi Coding/provider config: respect explicit
models.providers["kimi-coding"].baseUrlwhen resolving the implicit provider so custom Kimi Coding endpoints no longer get overwritten by the built-in default. (#36353) Thanks @2233admin. - Gateway/main-session routing: keep TUI and other
mode:UImain-session sends on the internal surface whendeliveris enabled, so replies no longer inherit the session's persisted Telegram/WhatsApp route. (#43918) Thanks @obviyus. - BlueBubbles/self-chat echo dedupe: drop reflected duplicate webhook copies only when a matching
fromMeevent was just seen for the same chat, body, and timestamp, preventing self-chat loops without broad webhook suppression. Related to #32166. (#38442) Thanks @vincentkoc. - iMessage/self-chat echo dedupe: drop reflected duplicate copies only when a matching
is_from_meevent was just seen for the same chat, text, andcreated_at, preventing self-chat loops without broad text-only suppression. Related to #32166. (#38440) Thanks @vincentkoc. - Subagents/completion announce retries: raise the default announce timeout to 90 seconds and stop retrying gateway-timeout failures for externally delivered completion announces, preventing duplicate user-facing completion messages after slow gateway responses. Fixes #41235. Thanks @vasujain00 and @vincentkoc.
- Mattermost/block streaming: fix duplicate message delivery (one threaded, one top-level) when block streaming is active by excluding
replyToIdfrom the block reply dedup key and adding an explicitthreadingdock to the Mattermost plugin. (#41362) Thanks @mathiasnagler and @vincentkoc. - Mattermost/reply media delivery: pass agent-scoped
mediaLocalRootsthrough shared reply delivery so allowed local files upload correctly from button, slash-command, and model-picker replies. (#44021) Thanks @LyleLiu666. - macOS/Reminders: add the missing
NSRemindersUsageDescriptionto the bundled app soapple-reminderscan trigger the system permission prompt from OpenClaw.app. (#8559) Thanks @dinakars777. - Gateway/session discovery: discover disk-only and retired ACP session stores under custom templated
session.storeroots so ACP reconciliation, session-id/session-label targeting, and run-id fallback keep working after restart. (#44176) thanks @gumadeiras. - Plugins/env-scoped roots: fix plugin discovery/load caches and provenance tracking so same-process
HOME/OPENCLAW_HOMEchanges no longer reuse stale plugin state or misreport~/...plugins as untracked. (#44046) thanks @gumadeiras. - Models/OpenRouter native ids: canonicalize native OpenRouter model keys across config writes, runtime lookups, fallback management, and
models list --plain, and migrate legacy duplicatedopenrouter/openrouter/...config entries forward on write. - Windows/native update: make package installs use the npm update path instead of the git path, carry portable Git into native Windows updates, and mirror the installer's Windows npm env so
openclaw updateno longer dies early on missinggitornode-llama-cppdownload setup. - Sandbox/write: preserve pinned mutation-helper payload stdin so sandboxed
writeno longer reports success while creating empty files. (#43876) Thanks @glitch418x. - Security/exec approvals: escape invisible Unicode format characters in approval prompts so zero-width command text renders as visible
\u{...}escapes instead of spoofing the reviewed command. (GHSA-pcqg-f7rg-xfvv)(#43687) Thanks @EkiXu and @vincentkoc. - Hooks/loader: fail closed when workspace hook paths cannot be resolved with
realpath, so unreadable or broken internal hook paths are skipped instead of falling back to unresolved imports. (#44437) Thanks @vincentkoc. - Hooks/agent deliveries: dedupe repeated hook requests by optional idempotency key so webhook retries can reuse the first run instead of launching duplicate agent executions. (#44438) Thanks @vincentkoc.
- Security/exec detection: normalize compatibility Unicode and strip invisible formatting code points before obfuscation checks so zero-width and fullwidth command tricks no longer suppress heuristic detection. (
GHSA-9r3v-37xh-2cf6)(#44091) Thanks @wooluo and @vincentkoc. - Security/exec allowlist: preserve POSIX case sensitivity and keep
?within a single path segment so exact-looking allowlist patterns no longer overmatch executables across case or directory boundaries. (GHSA-f8r2-vg7x-gh8m)(#43798) Thanks @zpbrent and @vincentkoc. - Security/commands: require sender ownership for
/configand/debugso authorized non-owner senders can no longer reach owner-only config and runtime debug surfaces. (GHSA-r7vr-gr74-94p8)(#44305) Thanks @tdjackey and @vincentkoc. - Security/gateway auth: clear unbound client-declared scopes on shared-token WebSocket connects so device-less shared-token operators cannot self-declare elevated scopes. (
GHSA-rqpp-rjj8-7wv8)(#44306) Thanks @LUOYEcode and @vincentkoc. - Security/browser.request: block persistent browser profile create/delete routes from write-scoped
browser.requestso callers can no longer persist admin-only browser profile changes through the browser control surface. (GHSA-vmhq-cqm9-6p7q)(#43800) Thanks @tdjackey and @vincentkoc. - Security/agent: reject public spawned-run lineage fields and keep workspace inheritance on the internal spawned-session path so external
agentcallers can no longer override the gateway workspace boundary. (GHSA-2rqg-gjgv-84jm)(#43801) Thanks @tdjackey and @vincentkoc. - Security/session_status: enforce sandbox session-tree visibility and shared agent-to-agent access guards before reading or mutating target session state, so sandboxed subagents can no longer inspect parent session metadata or write parent model overrides via
session_status. (GHSA-wcxr-59v9-rxr8)(#43754) Thanks @tdjackey and @vincentkoc. - Security/agent tools: mark
nodesas explicitly owner-only and document/test thatcanvasremains a shared trusted-operator surface unless a real boundary bypass exists. - Security/exec approvals: fail closed for Ruby approval flows that use
-r,--require, or-Iso approval-backed commands no longer bind only the main script while extra local code-...
openclaw 2026.3.11
Immutable
release. Only release title and notes can be modified.
Security
- Gateway/WebSocket: enforce browser origin validation for all browser-originated connections regardless of whether proxy headers are present, closing a cross-site WebSocket hijacking path in
trusted-proxymode that could grant untrusted originsoperator.adminaccess. (GHSA-5wcw-8jjv-m286)
Changes
- OpenRouter/models: add temporary Hunter Alpha and Healer Alpha entries to the built-in catalog so OpenRouter users can try the new free stealth models during their roughly one-week availability window. (#43642) Thanks @ping-Toven.
- iOS/Home canvas: add a bundled welcome screen with a live agent overview that refreshes on connect, reconnect, and foreground return, and move the compact connection pill off the top-left canvas overlay. (#42456) Thanks @ngutman.
- iOS/Home canvas: replace floating controls with a docked toolbar, make the bundled home scaffold adapt to smaller phones, and open chat in the resolved main session instead of a synthetic
iossession. (#42456) Thanks @ngutman. - macOS/chat UI: add a chat model picker, persist explicit thinking-level selections across relaunch, and harden provider-aware session model sync for the shared chat composer. (#42314) Thanks @ImLukeF.
- Onboarding/Ollama: add first-class Ollama setup with Local or Cloud + Local modes, browser-based cloud sign-in, curated model suggestions, and cloud-model handling that skips unnecessary local pulls. (#41529) Thanks @BruceMacD.
- OpenCode/onboarding: add new OpenCode Go provider, treat Zen and Go as one OpenCode setup in the wizard/docs while keeping the runtime providers split, store one shared OpenCode key for both profiles, and stop overriding the built-in
opencode-gocatalog routing. (#42313) Thanks @ImLukeF and @vincentkoc. - Memory: add opt-in multimodal image and audio indexing for
memorySearch.extraPathswith Geminigemini-embedding-2-preview, strict fallback gating, and scope-based reindexing. (#43460) Thanks @gumadeiras. - Memory/Gemini: add
gemini-embedding-2-previewmemory-search support with configurable output dimensions and automatic reindexing when the configured dimensions change. (#42501) Thanks @BillChirico and @gumadeiras. - macOS/onboarding: detect when remote gateways need a shared auth token, explain where to find it on the gateway host, and clarify when a successful check used paired-device auth instead. (#43100) Thanks @ngutman.
- Discord/auto threads: add
autoArchiveDurationchannel config for auto-created threads so Discord thread archiving can stay at 1 hour, 1 day, 3 days, or 1 week instead of always using the 1-hour default. (#35065) Thanks @davidguttman. - iOS/TestFlight: add a local beta release flow with Fastlane prepare/archive/upload support, canonical beta bundle IDs, and watch-app archive fixes. (#42991) Thanks @ngutman.
- ACP/sessions_spawn: add optional
resumeSessionIdforruntime: "acp"so spawned ACP sessions can resume an existing ACPX/Codex conversation instead of always starting fresh. (#41847) Thanks @pejmanjohn. - Gateway/node pending work: add narrow in-memory pending-work queue primitives (
node.pending.enqueue/node.pending.drain) and wake-helper reuse as a foundation for dormant-node work delivery. (#41409) Thanks @mbelinky. - Git/runtime state: ignore the gateway-generated
.dev-statefile so local runtime state does not show up as untracked repo noise. (#41848) Thanks @smysle. - Exec/child commands: mark child command environments with
OPENCLAW_CLIso subprocesses can detect when they were launched from the OpenClaw CLI. (#41411) Thanks @vincentkoc.
Breaking
- Cron/doctor: tighten isolated cron delivery so cron jobs can no longer notify through ad hoc agent sends or fallback main-session summaries, and add
openclaw doctor --fixmigration for legacy cron storage and legacy notify/webhook delivery metadata. (#40998) Thanks @mbelinky.
Fixes
- Agents/text sanitization: strip leaked model control tokens (
<|...|>and full-width<|...|>variants) from user-facing assistant text, preventing GLM-5 and DeepSeek internal delimiters from reaching end users. (#42173) Thanks @imwyvern. - iOS/gateway foreground recovery: reconnect immediately on foreground return after stale background sockets are torn down, so the app no longer stays disconnected until a later wake path happens. (#41384) Thanks @mbelinky.
- Gateway/Control UI: keep dashboard auth tokens in session-scoped browser storage so same-tab refreshes preserve remote token auth without restoring long-lived localStorage token persistence, while scoping tokens to the selected gateway URL and fragment-only bootstrap flow. (#40892) thanks @velvet-shark.
- Gateway/macOS launchd restarts: keep the LaunchAgent registered during explicit restarts, hand off self-restarts through a detached launchd helper, and recover config/hot reload restart paths without unloading the service. Fixes #43311, #43406, #43035, and #43049.
- macOS/LaunchAgent install: tighten LaunchAgent directory and plist permissions during install so launchd bootstrap does not fail when the target home path or generated plist inherited group/world-writable modes.
- Discord/reply chunking: resolve the effective
maxLinesPerMessageconfig across live reply paths and preservechunkModein the fast send path so long Discord replies no longer split unexpectedly at the default 17-line limit. (#40133) thanks @rbutera. - Feishu/local image auto-convert: pass
mediaLocalRootsthrough thesendTextlocal-image shim so allowed local image paths upload as Feishu images again instead of falling back to raw path text. (#40623) Thanks @ayanesakura. - Models/Kimi Coding: send
anthropic-messagestools in native Anthropic format again sokimi-codingstops degrading tool calls into XML/plain-text pseudo invocations instead of realtool_useblocks. (#38669, #39907, #40552) Thanks @opriz. - Telegram/outbound HTML sends: chunk long HTML-mode messages, preserve plain-text fallback and silent-delivery params across retries, and cut over to plain text when HTML chunk planning cannot safely preserve the full message. (#42240) thanks @obviyus.
- Telegram/final preview delivery: split active preview lifecycle from cleanup retention so missing archived preview edits avoid duplicate fallback sends without clearing the live preview or blocking later in-place finalization. (#41662) thanks @hougangdev.
- Telegram/final preview delivery followup: keep ambiguous missing-
message_idfinals only when a preview was already visible, while first-preview/no-id cases still fall back so Telegram users do not lose the final reply. (#41932) thanks @hougangdev. - Telegram/final preview cleanup follow-up: clear stale cleanup-retain state only for transient preview finals so archived-preview retains no longer leave a stale partial bubble beside a later fallback-sent final. (#41763) Thanks @obviyus.
- Gateway/auth: allow one trusted device-token retry on shared-token mismatch with recovery hints to prevent reconnect churn during token drift. (#42507) Thanks @joshavant.
- Gateway/config errors: surface up to three validation issues in top-level
config.set,config.patch, andconfig.applyerror messages while preserving structured issue details. (#42664) Thanks @huntharo. - Agents/Azure OpenAI Responses: include the
azure-openaiprovider in the Responses API store override so Azure OpenAI multi-turn cron jobs and embedded agent runs no longer fail with HTTP 400 "store is set to false". (#42934, fixes #42800) Thanks @ademczuk. - Agents/error rendering: ignore stale assistant
errorMessagefields on successful turns so background/tool-side failures no longer prepend synthetic billing errors over valid replies. (#40616) Thanks @ingyukoh. - Agents/billing recovery: probe single-provider billing cooldowns on the existing throttle so topping up credits can recover without a manual gateway restart. (#41422) thanks @altaywtf.
- Agents/fallback: treat HTTP 499 responses as transient in both raw-text and structured failover paths so Anthropic-style client-closed overload responses trigger model fallback reliably. (#41468) thanks @zeroasterisk.
- Agents/fallback: recognize Venice
402 Insufficient USD or Diem balancebilling errors so configured model fallbacks trigger instead of surfacing the raw provider error. (#43205) Thanks @Squabble9. - Agents/fallback: recognize Poe
402 You've used up your points!billing errors so configured model fallbacks trigger instead of surfacing the raw provider error. (#42278) Thanks @CryUshio. - Agents/failover: treat Gemini
MALFORMED_RESPONSEstop reasons as retryable timeouts so preview-model enum drift falls back cleanly instead of crashing the run, without also reclassifying malformed function-call errors. (#42292) Thanks @jnMetaCode. - Agents/cooldowns: default cooldown windows with no recorded failure history to
unknowninstead ofrate_limit, avoiding false API rate-limit warnings while preserving cooldown recovery probes. (#42911) Thanks @VibhorGautam. - Auth/cooldowns: reset expired auth-profile cooldown error counters before computing the next backoff so stale on-disk counters do not re-escalate into long cooldown loops after expiry. (#41028) thanks @zerone0x.
- Agents/memory flush: forward
memoryFlushWritePaththroughrunEmbeddedPiAgentso memory-triggered flush turns keep the append-only write guard without aborting before tool setup. Follows up on #38574. (#41761) Thanks @frankekn. - Agents/context pruning: prune image-only tool results during soft-trim, align context-pruning coverage with the new tool-result contract, and extend historical image cleanup to the same screenshot-heavy session path. (#43045) Thanks @MoerAI.
- Sessions/reset model recompute: clear stale runtime model, context-token, and system-prompt metadata before session resets recompute the replacement session, so resets pick up current defaults and explicit overrides instead of reusing old runtime model state. (#41173) thanks @pon...
openclaw 2026.3.11-beta.1
Immutable
release. Only release title and notes can be modified.
Security
- Gateway/WebSocket: enforce browser origin validation for all browser-originated connections regardless of whether proxy headers are present, closing a cross-site WebSocket hijacking path in
trusted-proxymode that could grant untrusted originsoperator.adminaccess. (GHSA-5wcw-8jjv-m286)
Changes
- OpenRouter/models: add temporary Hunter Alpha and Healer Alpha entries to the built-in catalog so OpenRouter users can try the new free stealth models during their roughly one-week availability window. (#43642) Thanks @ping-Toven.
- iOS/Home canvas: add a bundled welcome screen with a live agent overview that refreshes on connect, reconnect, and foreground return, and move the compact connection pill off the top-left canvas overlay. (#42456) Thanks @ngutman.
- iOS/Home canvas: replace floating controls with a docked toolbar, make the bundled home scaffold adapt to smaller phones, and open chat in the resolved main session instead of a synthetic
iossession. (#42456) Thanks @ngutman. - macOS/chat UI: add a chat model picker, persist explicit thinking-level selections across relaunch, and harden provider-aware session model sync for the shared chat composer. (#42314) Thanks @ImLukeF.
- Onboarding/Ollama: add first-class Ollama setup with Local or Cloud + Local modes, browser-based cloud sign-in, curated model suggestions, and cloud-model handling that skips unnecessary local pulls. (#41529) Thanks @BruceMacD.
- OpenCode/onboarding: add new OpenCode Go provider, treat Zen and Go as one OpenCode setup in the wizard/docs while keeping the runtime providers split, store one shared OpenCode key for both profiles, and stop overriding the built-in
opencode-gocatalog routing. (#42313) Thanks @ImLukeF and @vincentkoc. - Memory: add opt-in multimodal image and audio indexing for
memorySearch.extraPathswith Geminigemini-embedding-2-preview, strict fallback gating, and scope-based reindexing. (#43460) Thanks @gumadeiras. - Memory/Gemini: add
gemini-embedding-2-previewmemory-search support with configurable output dimensions and automatic reindexing when the configured dimensions change. (#42501) Thanks @BillChirico and @gumadeiras. - macOS/onboarding: detect when remote gateways need a shared auth token, explain where to find it on the gateway host, and clarify when a successful check used paired-device auth instead. (#43100) Thanks @ngutman.
- Discord/auto threads: add
autoArchiveDurationchannel config for auto-created threads so Discord thread archiving can stay at 1 hour, 1 day, 3 days, or 1 week instead of always using the 1-hour default. (#35065) Thanks @davidguttman. - iOS/TestFlight: add a local beta release flow with Fastlane prepare/archive/upload support, canonical beta bundle IDs, and watch-app archive fixes. (#42991) Thanks @ngutman.
- ACP/sessions_spawn: add optional
resumeSessionIdforruntime: "acp"so spawned ACP sessions can resume an existing ACPX/Codex conversation instead of always starting fresh. (#41847) Thanks @pejmanjohn. - Gateway/node pending work: add narrow in-memory pending-work queue primitives (
node.pending.enqueue/node.pending.drain) and wake-helper reuse as a foundation for dormant-node work delivery. (#41409) Thanks @mbelinky. - Git/runtime state: ignore the gateway-generated
.dev-statefile so local runtime state does not show up as untracked repo noise. (#41848) Thanks @smysle. - Exec/child commands: mark child command environments with
OPENCLAW_CLIso subprocesses can detect when they were launched from the OpenClaw CLI. (#41411) Thanks @vincentkoc.
Breaking
- Cron/doctor: tighten isolated cron delivery so cron jobs can no longer notify through ad hoc agent sends or fallback main-session summaries, and add
openclaw doctor --fixmigration for legacy cron storage and legacy notify/webhook delivery metadata. (#40998) Thanks @mbelinky.
Fixes
- Agents/text sanitization: strip leaked model control tokens (
<|...|>and full-width<|...|>variants) from user-facing assistant text, preventing GLM-5 and DeepSeek internal delimiters from reaching end users. (#42173) Thanks @imwyvern. - iOS/gateway foreground recovery: reconnect immediately on foreground return after stale background sockets are torn down, so the app no longer stays disconnected until a later wake path happens. (#41384) Thanks @mbelinky.
- Gateway/Control UI: keep dashboard auth tokens in session-scoped browser storage so same-tab refreshes preserve remote token auth without restoring long-lived localStorage token persistence, while scoping tokens to the selected gateway URL and fragment-only bootstrap flow. (#40892) thanks @velvet-shark.
- Gateway/macOS launchd restarts: keep the LaunchAgent registered during explicit restarts, hand off self-restarts through a detached launchd helper, and recover config/hot reload restart paths without unloading the service. Fixes #43311, #43406, #43035, and #43049.
- macOS/LaunchAgent install: tighten LaunchAgent directory and plist permissions during install so launchd bootstrap does not fail when the target home path or generated plist inherited group/world-writable modes.
- Discord/reply chunking: resolve the effective
maxLinesPerMessageconfig across live reply paths and preservechunkModein the fast send path so long Discord replies no longer split unexpectedly at the default 17-line limit. (#40133) thanks @rbutera. - Feishu/local image auto-convert: pass
mediaLocalRootsthrough thesendTextlocal-image shim so allowed local image paths upload as Feishu images again instead of falling back to raw path text. (#40623) Thanks @ayanesakura. - Models/Kimi Coding: send
anthropic-messagestools in native Anthropic format again sokimi-codingstops degrading tool calls into XML/plain-text pseudo invocations instead of realtool_useblocks. (#38669, #39907, #40552) Thanks @opriz. - Telegram/outbound HTML sends: chunk long HTML-mode messages, preserve plain-text fallback and silent-delivery params across retries, and cut over to plain text when HTML chunk planning cannot safely preserve the full message. (#42240) thanks @obviyus.
- Telegram/final preview delivery: split active preview lifecycle from cleanup retention so missing archived preview edits avoid duplicate fallback sends without clearing the live preview or blocking later in-place finalization. (#41662) thanks @hougangdev.
- Telegram/final preview delivery followup: keep ambiguous missing-
message_idfinals only when a preview was already visible, while first-preview/no-id cases still fall back so Telegram users do not lose the final reply. (#41932) thanks @hougangdev. - Telegram/final preview cleanup follow-up: clear stale cleanup-retain state only for transient preview finals so archived-preview retains no longer leave a stale partial bubble beside a later fallback-sent final. (#41763) Thanks @obviyus.
- Gateway/auth: allow one trusted device-token retry on shared-token mismatch with recovery hints to prevent reconnect churn during token drift. (#42507) Thanks @joshavant.
- Gateway/config errors: surface up to three validation issues in top-level
config.set,config.patch, andconfig.applyerror messages while preserving structured issue details. (#42664) Thanks @huntharo. - Agents/Azure OpenAI Responses: include the
azure-openaiprovider in the Responses API store override so Azure OpenAI multi-turn cron jobs and embedded agent runs no longer fail with HTTP 400 "store is set to false". (#42934, fixes #42800) Thanks @ademczuk. - Agents/error rendering: ignore stale assistant
errorMessagefields on successful turns so background/tool-side failures no longer prepend synthetic billing errors over valid replies. (#40616) Thanks @ingyukoh. - Agents/billing recovery: probe single-provider billing cooldowns on the existing throttle so topping up credits can recover without a manual gateway restart. (#41422) thanks @altaywtf.
- Agents/fallback: treat HTTP 499 responses as transient in both raw-text and structured failover paths so Anthropic-style client-closed overload responses trigger model fallback reliably. (#41468) thanks @zeroasterisk.
- Agents/fallback: recognize Venice
402 Insufficient USD or Diem balancebilling errors so configured model fallbacks trigger instead of surfacing the raw provider error. (#43205) Thanks @Squabble9. - Agents/fallback: recognize Poe
402 You've used up your points!billing errors so configured model fallbacks trigger instead of surfacing the raw provider error. (#42278) Thanks @CryUshio. - Agents/failover: treat Gemini
MALFORMED_RESPONSEstop reasons as retryable timeouts so preview-model enum drift falls back cleanly instead of crashing the run, without also reclassifying malformed function-call errors. (#42292) Thanks @jnMetaCode. - Agents/cooldowns: default cooldown windows with no recorded failure history to
unknowninstead ofrate_limit, avoiding false API rate-limit warnings while preserving cooldown recovery probes. (#42911) Thanks @VibhorGautam. - Auth/cooldowns: reset expired auth-profile cooldown error counters before computing the next backoff so stale on-disk counters do not re-escalate into long cooldown loops after expiry. (#41028) thanks @zerone0x.
- Agents/memory flush: forward
memoryFlushWritePaththroughrunEmbeddedPiAgentso memory-triggered flush turns keep the append-only write guard without aborting before tool setup. Follows up on #38574. (#41761) Thanks @frankekn. - Agents/context pruning: prune image-only tool results during soft-trim, align context-pruning coverage with the new tool-result contract, and extend historical image cleanup to the same screenshot-heavy session path. (#43045) Thanks @MoerAI.
- Sessions/reset model recompute: clear stale runtime model, context-token, and system-prompt metadata before session resets recompute the replacement session, so resets pick up current defaults and explicit overrides instead of reusing old runtime model state. (#41173) thanks @pon...
openclaw 2026.3.8
Immutable
release. Only release title and notes can be modified.
Mac assets on this release reuse the beta artifact line from v2026.3.8-beta.1.
Changes
- CLI/backup: add
openclaw backup createandopenclaw backup verifyfor local state archives, including--only-config,--no-include-workspace, manifest/payload validation, and backup guidance in destructive flows. (#40163) thanks @shichangs. - macOS/onboarding: add a remote gateway token field for remote mode, preserve existing non-plaintext
gateway.remote.tokenconfig values until explicitly replaced, and warn when the loaded token shape cannot be used directly from the macOS app. (#40187, supersedes #34614) Thanks @cgdusek. - Talk mode: add top-level
talk.silenceTimeoutMsconfig so Talk waits a configurable amount of silence before auto-sending the current transcript, while keeping each platform's existing default pause window when unset. (#39607) Thanks @danodoesdesign. Fixes #17147. - TUI: infer the active agent from the current workspace when launched inside a configured agent workspace, while preserving explicit
agent:session targets. (#39591) thanks @arceus77-7. - Tools/Brave web search: add opt-in
tools.web.search.brave.mode: "llm-context"soweb_searchcan call Brave's LLM Context endpoint and return extracted grounding snippets with source metadata, plus config/docs/test coverage. (#33383) Thanks @thirumaleshp. - CLI/install: include the short git commit hash in
openclaw --versionoutput when metadata is available, and keep installer version checks compatible with the decorated format. (#39712) thanks @sourman. - CLI/backup: improve archive naming for date sorting, add config-only backup mode, and harden backup planning, publication, and verification edge cases. (#40163) Thanks @gumadeiras.
- ACP/Provenance: add optional ACP ingress provenance metadata and visible receipt injection (
openclaw acp --provenance off|meta|meta+receipt) so OpenClaw agents can retain and report ACP-origin context with session trace IDs. (#40473) thanks @mbelinky. - Tools/web search: alphabetize provider ordering across runtime selection, onboarding/configure pickers, and config metadata, so provider lists stay neutral and multi-key auto-detect now prefers Grok before Kimi. (#40259) thanks @kesku.
- Docs/Web search: restore $5/month free-credit details, replace defunct "Data for Search"/"Data for AI" plan names with current "Search" plan, and note legacy subscription validity in Brave setup docs. Follows up on #26860. (#40111) Thanks @remusao.
- Extensions/ACPX tests: move the shared runtime fixture helper from
src/runtime-internals/tosrc/test-utils/so the test-only helper no longer looks like shipped runtime code.
Fixes
- Update/macOS launchd restart: re-enable disabled LaunchAgent services before updater bootstrap so
openclaw updatecan recover from a disabled gateway service instead of leaving the restart step stuck. - macOS app/chat UI: route browser proxy through the local node browser service, preserve plain-text paste semantics, strip completed assistant trace/debug wrapper noise from transcripts, refresh permission state after returning from System Settings, and tolerate malformed cron rows in the macOS tab. (#39516) Thanks @Imhermes1.
- Android/Play distribution: remove self-update, background location,
screen.record, and background mic capture from the Android app, narrow the foreground service todataSynconly, and clean up the legacylocation.enabledMode=alwayspreference migration. (#39660) Thanks @obviyus. - Telegram/DM routing: dedupe inbound Telegram DMs per agent instead of per session key so the same DM cannot trigger duplicate replies when both
agent:main:mainandagent:main:telegram:direct:<id>resolve for one agent. Fixes #40005. Supersedes #40116. (#40519) thanks @obviyus. - Cron/Telegram announce delivery: route text-only announce jobs through the real outbound adapters after finalizing descendant output so plain Telegram targets no longer report
delivered: truewhen no message actually reached Telegram. (#40575) thanks @obviyus. - Matrix/DM routing: add safer fallback detection for broken
m.directhomeservers, honor explicit room bindings over DM classification, and preserve room-bound agent selection for Matrix DM rooms. (#19736) Thanks @derbronko. - Feishu/plugin onboarding: clear the short-lived plugin discovery cache before reloading the registry after installing a channel plugin, so onboarding no longer re-prompts to download Feishu immediately after a successful install. Fixes #39642. (#39752) Thanks @GazeKingNuWu.
- Plugins/channel onboarding: prefer bundled channel plugins over duplicate npm-installed copies during onboarding and release-channel sync, preventing bundled plugins from being shadowed by npm installs with the same plugin ID. (#40092)
- Config/runtime snapshots: keep secrets-runtime-resolved config and auth-profile snapshots intact after config writes so follow-up reads still see file-backed secret values while picking up the persisted config update. (#37313) thanks @bbblending.
- Gateway/Control UI: resolve bundled dashboard assets through symlinked global wrappers and auto-detected package roots, while keeping configured and custom roots on the strict hardlink boundary. (#40385) Thanks @LarytheLord.
- Browser/extension relay: add
browser.relayBindHostso the Chrome relay can bind to an explicit non-loopback address for WSL2 and other cross-namespace setups, while preserving loopback-only defaults. (#39364) Thanks @mvanhorn. - Browser/CDP: normalize loopback direct WebSocket CDP URLs back to HTTP(S) for
/json/*tab operations so localws:///wss://profiles can still list, focus, open, and close tabs after the new direct-WS support lands. (#31085) Thanks @shrey150. - Browser/CDP: rewrite wildcard
ws://0.0.0.0andws://[::]debugger URLs from remote/json/versionresponses back to the external CDP host/port, fixing Browserless-style container endpoints. (#17760) Thanks @joeharouni. - Browser/extension relay: wait briefly for a previously attached Chrome tab to reappear after transient relay drops before failing with
tab not found, reducing noisy reconnect flakes. (#32461) Thanks @AaronWander. - macOS/Tailscale gateway discovery: keep Tailscale Serve probing alive when other remote gateways are already discovered, prefer direct transport for resolved
.ts.netand Tailscale Serve gateways, and setTERM=dumbfor GUI-launched Tailscale CLI discovery. (#40167) thanks @ngutman. - TUI/theme: detect light terminal backgrounds via
COLORFGBGand pick a WCAG AA-compliant light palette, withOPENCLAW_THEME=light|darkoverride for terminals without auto-detection. (#38636) Thanks @ademczuk and @vincentkoc. - Agents/openai-codex: normalize
gpt-5.4fallback transport back toopenai-codex-responsesonchatgpt.com/backend-apiwhen config drifts to the generic OpenAI responses endpoint. (#38736) Thanks @0xsline. - Models/openai-codex GPT-5.4 forward-compat: use the GPT-5.4 1,050,000-token context window and 128,000 max tokens for
openai-codex/gpt-5.4instead of inheriting stale legacy Codex limits in resolver fallbacks and model listing. (#37876) thanks @yuweuii. - Tools/web search: restore Perplexity OpenRouter/Sonar compatibility for legacy
OPENROUTER_API_KEY,sk-or-..., and explicitperplexity.baseUrl/modelsetups while keeping direct Perplexity keys on the native Search API path. (#39937) Thanks @obviyus. - Agents/failover: detect Amazon Bedrock
Too many tokens per dayquota errors as rate limits across fallback, cron retry, and memory embeddings while keeping context-windowtoo many tokens per requesterrors out of the rate-limit lane. (#39377) Thanks @gambletan. - Mattermost replies: keep
root_idpinned to the existing thread root when an agent replies inside a thread, while still using reply-target threading for top-level posts. (#27744) thanks @hnykda. - Telegram/DM partial streaming: keep DM preview lanes on real message edits instead of native draft materialization so final replies no longer flash a second duplicate copy before collapsing back to one.
- macOS overlays: fix VoiceWake, Talk, and Notify overlay exclusivity crashes by removing shared
inoutvisibility mutation fromOverlayPanelFactory.present, and add a repeated Talk overlay smoke test. (#39275, #39321) Thanks @fellanH. - macOS Talk Mode: set the speech recognition request
taskHintto.dictationfor mic capture, and add regression coverage for the request defaults. (#38445) Thanks @dmiv. - macOS release packaging: default
scripts/package-mac-app.shto universal binaries forBUILD_CONFIG=release, and clarify thatscripts/package-mac-dist.shalready produces the release zip + DMG. (#33891) Thanks @cgdusek. - Hooks/session-memory: keep
/newand/resetmemory artifacts in the bound agent workspace and align saved reset session keys with that workspace when stale main-agent keys leak into the hook path. (#39875) thanks @rbutera. - Sessions/model switch: clear stale cached
contextTokenswhen a session changes models so status and runtime paths recompute against the active model window. (#38044) thanks @yuweuii. - ACP/session history: persist transcripts for successful ACP child runs, preserve exact transcript text, record ACP spawned-session lineage, and keep spawn-time transcript-path persistence best-effort so history storage failures do not block execution. (#40137) thanks @mbelinky.
- Docs/browser: add a layered WSL2 + Windows remote Chrome CDP troubleshooting guide, including Control UI origin pitfalls and extension-relay bind-address guidance. (#39407) Thanks @Owlock.
- Context engine registry/bundled builds: share the registry state through a
globalThissingleton so duplicated bundled module copies can resolve engines registered by each other at runtime, with regression coverage for duplicate-module imports. (#40115) thanks @jalehman. - Podman/setup: fix
cannot chdir: Permission deniedinrun_as_userwhen `...
openclaw 2026.3.8-beta.1
Immutable
release. Only release title and notes can be modified.
Changes
- CLI/backup: add
openclaw backup createandopenclaw backup verifyfor local state archives, including--only-config,--no-include-workspace, manifest/payload validation, and backup guidance in destructive flows. (#40163) thanks @shichangs. - macOS/onboarding: add a remote gateway token field for remote mode, preserve existing non-plaintext
gateway.remote.tokenconfig values until explicitly replaced, and warn when the loaded token shape cannot be used directly from the macOS app. (#40187, supersedes #34614) Thanks @cgdusek. - Talk mode: add top-level
talk.silenceTimeoutMsconfig so Talk waits a configurable amount of silence before auto-sending the current transcript, while keeping each platform's existing default pause window when unset. (#39607) Thanks @danodoesdesign. Fixes #17147. - TUI: infer the active agent from the current workspace when launched inside a configured agent workspace, while preserving explicit
agent:session targets. (#39591) thanks @arceus77-7. - Tools/Brave web search: add opt-in
tools.web.search.brave.mode: "llm-context"soweb_searchcan call Brave's LLM Context endpoint and return extracted grounding snippets with source metadata, plus config/docs/test coverage. (#33383) Thanks @thirumaleshp. - CLI/install: include the short git commit hash in
openclaw --versionoutput when metadata is available, and keep installer version checks compatible with the decorated format. (#39712) thanks @sourman. - CLI/backup: improve archive naming for date sorting, add config-only backup mode, and harden backup planning, publication, and verification edge cases. (#40163) Thanks @gumadeiras.
- ACP/Provenance: add optional ACP ingress provenance metadata and visible receipt injection (
openclaw acp --provenance off|meta|meta+receipt) so OpenClaw agents can retain and report ACP-origin context with session trace IDs. (#40473) thanks @mbelinky. - Tools/web search: alphabetize provider ordering across runtime selection, onboarding/configure pickers, and config metadata, so provider lists stay neutral and multi-key auto-detect now prefers Grok before Kimi. (#40259) thanks @kesku.
- Docs/Web search: restore $5/month free-credit details, replace defunct "Data for Search"/"Data for AI" plan names with current "Search" plan, and note legacy subscription validity in Brave setup docs. Follows up on #26860. (#40111) Thanks @remusao.
- Extensions/ACPX tests: move the shared runtime fixture helper from
src/runtime-internals/tosrc/test-utils/so the test-only helper no longer looks like shipped runtime code.
Fixes
- macOS app/chat UI: route browser proxy through the local node browser service, preserve plain-text paste semantics, strip completed assistant trace/debug wrapper noise from transcripts, refresh permission state after returning from System Settings, and tolerate malformed cron rows in the macOS tab. (#39516) Thanks @Imhermes1.
- Android/Play distribution: remove self-update, background location,
screen.record, and background mic capture from the Android app, narrow the foreground service todataSynconly, and clean up the legacylocation.enabledMode=alwayspreference migration. (#39660) Thanks @obviyus. - Telegram/DM routing: dedupe inbound Telegram DMs per agent instead of per session key so the same DM cannot trigger duplicate replies when both
agent:main:mainandagent:main:telegram:direct:<id>resolve for one agent. Fixes #40005. Supersedes #40116. (#40519) thanks @obviyus. - Cron/Telegram announce delivery: route text-only announce jobs through the real outbound adapters after finalizing descendant output so plain Telegram targets no longer report
delivered: truewhen no message actually reached Telegram. (#40575) thanks @obviyus. - Matrix/DM routing: add safer fallback detection for broken
m.directhomeservers, honor explicit room bindings over DM classification, and preserve room-bound agent selection for Matrix DM rooms. (#19736) Thanks @derbronko. - Feishu/plugin onboarding: clear the short-lived plugin discovery cache before reloading the registry after installing a channel plugin, so onboarding no longer re-prompts to download Feishu immediately after a successful install. Fixes #39642. (#39752) Thanks @GazeKingNuWu.
- Plugins/channel onboarding: prefer bundled channel plugins over duplicate npm-installed copies during onboarding and release-channel sync, preventing bundled plugins from being shadowed by npm installs with the same plugin ID. (#40092)
- Config/runtime snapshots: keep secrets-runtime-resolved config and auth-profile snapshots intact after config writes so follow-up reads still see file-backed secret values while picking up the persisted config update. (#37313) thanks @bbblending.
- Gateway/Control UI: resolve bundled dashboard assets through symlinked global wrappers and auto-detected package roots, while keeping configured and custom roots on the strict hardlink boundary. (#40385) Thanks @LarytheLord.
- Browser/extension relay: add
browser.relayBindHostso the Chrome relay can bind to an explicit non-loopback address for WSL2 and other cross-namespace setups, while preserving loopback-only defaults. (#39364) Thanks @mvanhorn. - Browser/CDP: normalize loopback direct WebSocket CDP URLs back to HTTP(S) for
/json/*tab operations so localws:///wss://profiles can still list, focus, open, and close tabs after the new direct-WS support lands. (#31085) Thanks @shrey150. - Browser/CDP: rewrite wildcard
ws://0.0.0.0andws://[::]debugger URLs from remote/json/versionresponses back to the external CDP host/port, fixing Browserless-style container endpoints. (#17760) Thanks @joeharouni. - Browser/extension relay: wait briefly for a previously attached Chrome tab to reappear after transient relay drops before failing with
tab not found, reducing noisy reconnect flakes. (#32461) Thanks @AaronWander. - macOS/Tailscale gateway discovery: keep Tailscale Serve probing alive when other remote gateways are already discovered, prefer direct transport for resolved
.ts.netand Tailscale Serve gateways, and setTERM=dumbfor GUI-launched Tailscale CLI discovery. (#40167) thanks @ngutman. - TUI/theme: detect light terminal backgrounds via
COLORFGBGand pick a WCAG AA-compliant light palette, withOPENCLAW_THEME=light|darkoverride for terminals without auto-detection. (#38636) Thanks @ademczuk and @vincentkoc. - Agents/openai-codex: normalize
gpt-5.4fallback transport back toopenai-codex-responsesonchatgpt.com/backend-apiwhen config drifts to the generic OpenAI responses endpoint. (#38736) Thanks @0xsline. - Models/openai-codex GPT-5.4 forward-compat: use the GPT-5.4 1,050,000-token context window and 128,000 max tokens for
openai-codex/gpt-5.4instead of inheriting stale legacy Codex limits in resolver fallbacks and model listing. (#37876) thanks @yuweuii. - Tools/web search: restore Perplexity OpenRouter/Sonar compatibility for legacy
OPENROUTER_API_KEY,sk-or-..., and explicitperplexity.baseUrl/modelsetups while keeping direct Perplexity keys on the native Search API path. (#39937) Thanks @obviyus. - Agents/failover: detect Amazon Bedrock
Too many tokens per dayquota errors as rate limits across fallback, cron retry, and memory embeddings while keeping context-windowtoo many tokens per requesterrors out of the rate-limit lane. (#39377) Thanks @gambletan. - Mattermost replies: keep
root_idpinned to the existing thread root when an agent replies inside a thread, while still using reply-target threading for top-level posts. (#27744) thanks @hnykda. - Telegram/DM partial streaming: keep DM preview lanes on real message edits instead of native draft materialization so final replies no longer flash a second duplicate copy before collapsing back to one.
- macOS overlays: fix VoiceWake, Talk, and Notify overlay exclusivity crashes by removing shared
inoutvisibility mutation fromOverlayPanelFactory.present, and add a repeated Talk overlay smoke test. (#39275, #39321) Thanks @fellanH. - macOS Talk Mode: set the speech recognition request
taskHintto.dictationfor mic capture, and add regression coverage for the request defaults. (#38445) Thanks @dmiv. - macOS release packaging: default
scripts/package-mac-app.shto universal binaries forBUILD_CONFIG=release, and clarify thatscripts/package-mac-dist.shalready produces the release zip + DMG. (#33891) Thanks @cgdusek. - Hooks/session-memory: keep
/newand/resetmemory artifacts in the bound agent workspace and align saved reset session keys with that workspace when stale main-agent keys leak into the hook path. (#39875) thanks @rbutera. - Sessions/model switch: clear stale cached
contextTokenswhen a session changes models so status and runtime paths recompute against the active model window. (#38044) thanks @yuweuii. - ACP/session history: persist transcripts for successful ACP child runs, preserve exact transcript text, record ACP spawned-session lineage, and keep spawn-time transcript-path persistence best-effort so history storage failures do not block execution. (#40137) thanks @mbelinky.
- Docs/browser: add a layered WSL2 + Windows remote Chrome CDP troubleshooting guide, including Control UI origin pitfalls and extension-relay bind-address guidance. (#39407) Thanks @Owlock.
- Context engine registry/bundled builds: share the registry state through a
globalThissingleton so duplicated bundled module copies can resolve engines registered by each other at runtime, with regression coverage for duplicate-module imports. (#40115) thanks @jalehman. - Podman/setup: fix
cannot chdir: Permission deniedinrun_as_userwhensetup-podman.shis invoked from a directory the target user cannot access, by wrapping user-switch calls in a subshell that cd's to/tmpwith/fallback. (#39435) Thanks @langdon and @jlcbk. - Podman/SELinux: auto-detect SELinux enforcing/permissive mode and add
:Zrelabel to bi...
openclaw 2026.3.7
Immutable
release. Only release title and notes can be modified.
Changes
- Agents/context engine plugin interface: add
ContextEngineplugin slot with full lifecycle hooks (bootstrap,ingest,assemble,compact,afterTurn,prepareSubagentSpawn,onSubagentEnded), slot-based registry with config-driven resolution,LegacyContextEnginewrapper preserving existing compaction behavior, scoped subagent runtime for plugin runtimes viaAsyncLocalStorage, andsessions.getgateway method. Enables plugins likelossless-clawto provide alternative context management strategies without modifying core compaction logic. Zero behavior change when no context engine plugin is configured. (#22201) thanks @jalehman. - ACP/persistent channel bindings: add durable Discord channel and Telegram topic binding storage, routing resolution, and CLI/docs support so ACP thread targets survive restarts and can be managed consistently. (#34873) Thanks @dutifulbob.
- Telegram/ACP topic bindings: accept Telegram Mac Unicode dash option prefixes in
/acp spawn, support Telegram topic thread binding (--thread here|auto), route bound-topic follow-ups to ACP sessions, add actionable Telegram approval buttons with prefixed approval-id resolution, and pin successful bind confirmations in-topic. (#36683) Thanks @huntharo. - Telegram/topic agent routing: support per-topic
agentIdoverrides in forum groups and DM topics so topics can route to dedicated agents with isolated sessions. (#33647; based on #31513) Thanks @kesor and @Sid-Qin. - Web UI/i18n: add Spanish (
es) locale support in the Control UI, including locale detection, lazy loading, and language picker labels across supported locales. (#35038) Thanks @DaoPromociones. - Onboarding/web search: add provider selection step and full provider list in configure wizard, with SecretRef ref-mode support during onboarding. (#34009) Thanks @kesku and @thewilloftheshadow.
- Tools/Web search: switch Perplexity provider to Search API with structured results plus new language/region/time filters. (#33822) Thanks @kesku.
- Gateway: add SecretRef support for gateway.auth.token with auth-mode guardrails. (#35094) Thanks @joshavant.
- Docker/Podman extension dependency baking: add
OPENCLAW_EXTENSIONSso container builds can preinstall selected bundled extension npm dependencies into the image for faster and more reproducible startup in container deployments. (#32223) Thanks @sallyom. - Plugins/before_prompt_build system-context fields: add
prependSystemContextandappendSystemContextso static plugin guidance can be placed in system prompt space for provider caching and lower repeated prompt token cost. (#35177) thanks @maweibin. - Plugins/hook policy: add
plugins.entries.<id>.hooks.allowPromptInjection, validate unknown typed hook names at runtime, and preserve legacybefore_agent_startmodel/provider overrides while stripping prompt-mutating fields when prompt injection is disabled. (#36567) thanks @gumadeiras. - Hooks/Compaction lifecycle: emit
session:compact:beforeandsession:compact:afterinternal events plus plugin compaction callbacks with session/count metadata, so automations can react to compaction runs consistently. (#16788) thanks @vincentkoc. - Agents/compaction post-context configurability: add
agents.defaults.compaction.postCompactionSectionsso deployments can choose whichAGENTS.mdsections are re-injected after compaction, while preserving legacy fallback behavior when the documented default pair is configured in any order. (#34556) thanks @efe-arv. - TTS/OpenAI-compatible endpoints: add
messages.tts.openai.baseUrlconfig support with config-over-env precedence, endpoint-aware directive validation, and OpenAI TTS request routing to the resolved base URL. (#34321) thanks @RealKai42. - Slack/DM typing feedback: add
channels.slack.typingReactionso Socket Mode DMs can show reaction-based processing status even when Slack native assistant typing is unavailable. (#19816) Thanks @dalefrieswthat. - Discord/allowBots mention gating: add
allowBots: "mentions"to only accept bot-authored messages that mention the bot. Thanks @thewilloftheshadow. - Agents/tool-result truncation: preserve important tail diagnostics by using head+tail truncation for oversized tool results while keeping configurable truncation options. (#20076) thanks @jlwestsr.
- Cron/job snapshot persistence: skip backup during normalization persistence in
ensureLoadedsojobs.json.bakkeeps the pre-edit snapshot for recovery, while preserving backup creation on explicit user-driven writes. (#35234) Thanks @0xsline. - CLI: make read-only SecretRef status flows degrade safely (#37023) thanks @joshavant.
- Tools/Diffs guidance: restore a short system-prompt hint for enabled diffs while keeping the detailed instructions in the companion skill, so diffs usage guidance stays out of user-prompt space. (#36904) thanks @gumadeiras.
- Tools/Diffs guidance loading: move diffs usage guidance from unconditional prompt-hook injection to the plugin companion skill path, reducing unrelated-turn prompt noise while keeping diffs tool behavior unchanged. (#32630) thanks @sircrumpet.
- Docs/Web search: remove outdated Brave free-tier wording and replace prescriptive AI ToS guidance with neutral compliance language in Brave setup docs. (#26860) Thanks @HenryLoenwind.
- Config/Compaction safeguard tuning: expose
agents.defaults.compaction.recentTurnsPreserveand quality-guard retry knobs through the validated config surface and embedded-runner wiring, with regression coverage for real config loading and schema metadata. (#25557) thanks @rodrigouroz. - iOS/App Store Connect release prep: align iOS bundle identifiers under
ai.openclaw.client, refresh Watch app icons, add Fastlane metadata/screenshot automation, and support Keychain-backed ASC auth for uploads. (#38936) Thanks @ngutman. - Mattermost/model picker: add Telegram-style interactive provider/model browsing for
/oc_modeland/oc_models, fix picker callback updates, and emit a normal confirmation reply when a model is selected. (#38767) thanks @mukhtharcm. - Docker/multi-stage build: restructure Dockerfile as a multi-stage build to produce a minimal runtime image without build tools, source code, or Bun; add
OPENCLAW_VARIANT=slimbuild arg for a bookworm-slim variant. (#38479) Thanks @sallyom. - Google/Gemini 3.1 Flash-Lite: add first-class
google/gemini-3.1-flash-lite-previewsupport across model-id normalization, default aliases, media-understanding image lookups, Google Gemini CLI forward-compat fallback, and docs.
Breaking
- BREAKING: Gateway auth now requires explicit
gateway.auth.modewhen bothgateway.auth.tokenandgateway.auth.passwordare configured (including SecretRefs). Setgateway.auth.modetotokenorpasswordbefore upgrade to avoid startup/pairing/TUI failures. (#35094) Thanks @joshavant.
Fixes
- Models/MiniMax: stop advertising removed
MiniMax-M2.5-Lightningin built-in provider catalogs, onboarding metadata, and docs; keep the supported fast-tier model asMiniMax-M2.5-highspeed. - Security/Config: fail closed when
loadConfig()hits validation or read errors so invalid configs cannot silently fall back to permissive runtime defaults. (#9040) Thanks @joetomasone. - Memory/Hybrid search: preserve negative FTS5 BM25 relevance ordering in
bm25RankToScore()so stronger keyword matches rank above weaker ones instead of collapsing or reversing scores. (#33757) Thanks @lsdcc01. - LINE/
requireMentiongroup gating: align inbound and reply-stage LINE group policy resolution across raw,group:, androom:keys (including account-scoped group config), preserve plugin-backed reply-stage fallback behavior, and add regression coverage for prefixed-only group/room config plus reply-stage policy resolution. (#35847) Thanks @kirisame-wang. - Onboarding/local setup: default unset local
tools.profiletocodinginstead ofmessaging, restoring file/runtime tools for fresh local installs while preserving explicit user-set profiles. (from #38241, overlap with #34958) Thanks @cgdusek. - Gateway/Telegram stale-socket restart guard: only apply stale-socket restarts to channels that publish event-liveness timestamps, preventing Telegram providers from being misclassified as stale solely due to long uptime and avoiding restart/pairing storms after upgrade. (#38464)
- Onboarding/headless Linux daemon probe hardening: treat
systemctl --user is-enabledprobe failures as non-fatal during daemon install flow so onboarding no longer crashes on SSH/headless VPS environments before showing install guidance. (#37297) Thanks @acarbajal-web. - Memory/QMD mcporter Windows spawn hardening: when
mcporter.cmdlaunch fails withspawn EINVAL, retry via baremcportershell resolution so QMD recall can continue instead of falling back to builtin memory search. (#27402) Thanks @i0ivi0i. - Tools/web_search Brave language-code validation: align
search_langhandling with Brave-supported codes (includingzh-hans,zh-hant,en-gb, andpt-br), map common alias inputs (zh,ja) to valid Brave values, and reject unsupported codes before upstream requests to prevent 422 failures. (#37260) Thanks @heyanming. - Models/openai-completions streaming compatibility: force
compat.supportsUsageInStreaming=falsefor non-native OpenAI-compatible endpoints during model normalization, preventing usage-only stream chunks from triggeringchoices[0]parser crashes in provider streams. (#8714) Thanks @nonanon1. - Tools/xAI native web-search collision guard: drop OpenClaw
web_searchfrom tool registration when routing to xAI/Grok model providers (including OpenRouterx-ai/*) to avoid duplicate tool-name request failures against provider-nativeweb_search. (#14749) Thanks @realsamrat. - TUI/token copy-safety rendering: treat long credential-like mixed alphanumeric tokens (including quoted forms) as copy-sensitive in render sanitization so formatter hard-wrap guards ...
openclaw 2026.3.7-beta.1
Immutable
release. Only release title and notes can be modified.
Changes
- Agents/context engine plugin interface: add
ContextEngineplugin slot with full lifecycle hooks (bootstrap,ingest,assemble,compact,afterTurn,prepareSubagentSpawn,onSubagentEnded), slot-based registry with config-driven resolution,LegacyContextEnginewrapper preserving existing compaction behavior, scoped subagent runtime for plugin runtimes viaAsyncLocalStorage, andsessions.getgateway method. Enables plugins likelossless-clawto provide alternative context management strategies without modifying core compaction logic. Zero behavior change when no context engine plugin is configured. (#22201) thanks @jalehman. - ACP/persistent channel bindings: add durable Discord channel and Telegram topic binding storage, routing resolution, and CLI/docs support so ACP thread targets survive restarts and can be managed consistently. (#34873) Thanks @dutifulbob.
- Telegram/ACP topic bindings: accept Telegram Mac Unicode dash option prefixes in
/acp spawn, support Telegram topic thread binding (--thread here|auto), route bound-topic follow-ups to ACP sessions, add actionable Telegram approval buttons with prefixed approval-id resolution, and pin successful bind confirmations in-topic. (#36683) Thanks @huntharo. - Telegram/topic agent routing: support per-topic
agentIdoverrides in forum groups and DM topics so topics can route to dedicated agents with isolated sessions. (#33647; based on #31513) Thanks @kesor and @Sid-Qin. - Web UI/i18n: add Spanish (
es) locale support in the Control UI, including locale detection, lazy loading, and language picker labels across supported locales. (#35038) Thanks @DaoPromociones. - Onboarding/web search: add provider selection step and full provider list in configure wizard, with SecretRef ref-mode support during onboarding. (#34009) Thanks @kesku and @thewilloftheshadow.
- Tools/Web search: switch Perplexity provider to Search API with structured results plus new language/region/time filters. (#33822) Thanks @kesku.
- Gateway: add SecretRef support for gateway.auth.token with auth-mode guardrails. (#35094) Thanks @joshavant.
- Docker/Podman extension dependency baking: add
OPENCLAW_EXTENSIONSso container builds can preinstall selected bundled extension npm dependencies into the image for faster and more reproducible startup in container deployments. (#32223) Thanks @sallyom. - Plugins/before_prompt_build system-context fields: add
prependSystemContextandappendSystemContextso static plugin guidance can be placed in system prompt space for provider caching and lower repeated prompt token cost. (#35177) thanks @maweibin. - Plugins/hook policy: add
plugins.entries.<id>.hooks.allowPromptInjection, validate unknown typed hook names at runtime, and preserve legacybefore_agent_startmodel/provider overrides while stripping prompt-mutating fields when prompt injection is disabled. (#36567) thanks @gumadeiras. - Hooks/Compaction lifecycle: emit
session:compact:beforeandsession:compact:afterinternal events plus plugin compaction callbacks with session/count metadata, so automations can react to compaction runs consistently. (#16788) thanks @vincentkoc. - Agents/compaction post-context configurability: add
agents.defaults.compaction.postCompactionSectionsso deployments can choose whichAGENTS.mdsections are re-injected after compaction, while preserving legacy fallback behavior when the documented default pair is configured in any order. (#34556) thanks @efe-arv. - TTS/OpenAI-compatible endpoints: add
messages.tts.openai.baseUrlconfig support with config-over-env precedence, endpoint-aware directive validation, and OpenAI TTS request routing to the resolved base URL. (#34321) thanks @RealKai42. - Slack/DM typing feedback: add
channels.slack.typingReactionso Socket Mode DMs can show reaction-based processing status even when Slack native assistant typing is unavailable. (#19816) Thanks @dalefrieswthat. - Discord/allowBots mention gating: add
allowBots: "mentions"to only accept bot-authored messages that mention the bot. Thanks @thewilloftheshadow. - Agents/tool-result truncation: preserve important tail diagnostics by using head+tail truncation for oversized tool results while keeping configurable truncation options. (#20076) thanks @jlwestsr.
- Cron/job snapshot persistence: skip backup during normalization persistence in
ensureLoadedsojobs.json.bakkeeps the pre-edit snapshot for recovery, while preserving backup creation on explicit user-driven writes. (#35234) Thanks @0xsline. - CLI: make read-only SecretRef status flows degrade safely (#37023) thanks @joshavant.
- Tools/Diffs guidance: restore a short system-prompt hint for enabled diffs while keeping the detailed instructions in the companion skill, so diffs usage guidance stays out of user-prompt space. (#36904) thanks @gumadeiras.
- Tools/Diffs guidance loading: move diffs usage guidance from unconditional prompt-hook injection to the plugin companion skill path, reducing unrelated-turn prompt noise while keeping diffs tool behavior unchanged. (#32630) thanks @sircrumpet.
- Docs/Web search: remove outdated Brave free-tier wording and replace prescriptive AI ToS guidance with neutral compliance language in Brave setup docs. (#26860) Thanks @HenryLoenwind.
- Config/Compaction safeguard tuning: expose
agents.defaults.compaction.recentTurnsPreserveand quality-guard retry knobs through the validated config surface and embedded-runner wiring, with regression coverage for real config loading and schema metadata. (#25557) thanks @rodrigouroz. - iOS/App Store Connect release prep: align iOS bundle identifiers under
ai.openclaw.client, refresh Watch app icons, add Fastlane metadata/screenshot automation, and support Keychain-backed ASC auth for uploads. (#38936) Thanks @ngutman. - Mattermost/model picker: add Telegram-style interactive provider/model browsing for
/oc_modeland/oc_models, fix picker callback updates, and emit a normal confirmation reply when a model is selected. (#38767) thanks @mukhtharcm. - Docker/multi-stage build: restructure Dockerfile as a multi-stage build to produce a minimal runtime image without build tools, source code, or Bun; add
OPENCLAW_VARIANT=slimbuild arg for a bookworm-slim variant. (#38479) Thanks @sallyom.
Breaking
- BREAKING: Gateway auth now requires explicit
gateway.auth.modewhen bothgateway.auth.tokenandgateway.auth.passwordare configured (including SecretRefs). Setgateway.auth.modetotokenorpasswordbefore upgrade to avoid startup/pairing/TUI failures. (#35094) Thanks @joshavant.
Fixes
- Models/MiniMax: stop advertising removed
MiniMax-M2.5-Lightningin built-in provider catalogs, onboarding metadata, and docs; keep the supported fast-tier model asMiniMax-M2.5-highspeed. - Security/Config: fail closed when
loadConfig()hits validation or read errors so invalid configs cannot silently fall back to permissive runtime defaults. (#9040) Thanks @joetomasone. - Memory/Hybrid search: preserve negative FTS5 BM25 relevance ordering in
bm25RankToScore()so stronger keyword matches rank above weaker ones instead of collapsing or reversing scores. (#33757) Thanks @lsdcc01. - LINE/
requireMentiongroup gating: align inbound and reply-stage LINE group policy resolution across raw,group:, androom:keys (including account-scoped group config), preserve plugin-backed reply-stage fallback behavior, and add regression coverage for prefixed-only group/room config plus reply-stage policy resolution. (#35847) Thanks @kirisame-wang. - Onboarding/local setup: default unset local
tools.profiletocodinginstead ofmessaging, restoring file/runtime tools for fresh local installs while preserving explicit user-set profiles. (from #38241, overlap with #34958) Thanks @cgdusek. - Gateway/Telegram stale-socket restart guard: only apply stale-socket restarts to channels that publish event-liveness timestamps, preventing Telegram providers from being misclassified as stale solely due to long uptime and avoiding restart/pairing storms after upgrade. (#38464)
- Onboarding/headless Linux daemon probe hardening: treat
systemctl --user is-enabledprobe failures as non-fatal during daemon install flow so onboarding no longer crashes on SSH/headless VPS environments before showing install guidance. (#37297) Thanks @acarbajal-web. - Memory/QMD mcporter Windows spawn hardening: when
mcporter.cmdlaunch fails withspawn EINVAL, retry via baremcportershell resolution so QMD recall can continue instead of falling back to builtin memory search. (#27402) Thanks @i0ivi0i. - Tools/web_search Brave language-code validation: align
search_langhandling with Brave-supported codes (includingzh-hans,zh-hant,en-gb, andpt-br), map common alias inputs (zh,ja) to valid Brave values, and reject unsupported codes before upstream requests to prevent 422 failures. (#37260) Thanks @heyanming. - Models/openai-completions streaming compatibility: force
compat.supportsUsageInStreaming=falsefor non-native OpenAI-compatible endpoints during model normalization, preventing usage-only stream chunks from triggeringchoices[0]parser crashes in provider streams. (#8714) Thanks @nonanon1. - Tools/xAI native web-search collision guard: drop OpenClaw
web_searchfrom tool registration when routing to xAI/Grok model providers (including OpenRouterx-ai/*) to avoid duplicate tool-name request failures against provider-nativeweb_search. (#14749) Thanks @realsamrat. - TUI/token copy-safety rendering: treat long credential-like mixed alphanumeric tokens (including quoted forms) as copy-sensitive in render sanitization so formatter hard-wrap guards no longer inject visible spaces into auth-style values before display. (#26710) Thanks @jasonthane.
- WhatsApp/self-chat response prefix fallback: stop forcing
"[openclaw]"as the implicit outbound response prefix when no identit...
openclaw 2026.3.2
Immutable
release. Only release title and notes can be modified.
Changes
- Secrets/SecretRef coverage: expand SecretRef support across the full supported user-supplied credential surface (64 targets total), including runtime collectors,
openclaw secretsplanning/apply/audit flows, onboarding SecretInput UX, and related docs; unresolved refs now fail fast on active surfaces while inactive surfaces report non-blocking diagnostics. (#29580) Thanks @joshavant. - Tools/PDF analysis: add a first-class
pdftool with native Anthropic and Google PDF provider support, extraction fallback for non-native models, configurable defaults (agents.defaults.pdfModel,pdfMaxBytesMb,pdfMaxPages), and docs/tests covering routing, validation, and registration. (#31319) Thanks @tyler6204. - Outbound adapters/plugins: add shared
sendPayloadsupport across direct-text-media, Discord, Slack, WhatsApp, Zalo, and Zalouser with multi-media iteration and chunk-aware text fallback. (#30144) Thanks @nohat. - Models/MiniMax: add first-class
MiniMax-M2.5-highspeedsupport across built-in provider catalogs, onboarding flows, and MiniMax OAuth plugin defaults, while keeping legacyMiniMax-M2.5-Lightningcompatibility for existing configs. - Sessions/Attachments: add inline file attachment support for
sessions_spawn(subagent runtime only) with base64/utf8 encoding, transcript content redaction, lifecycle cleanup, and configurable limits viatools.sessions_spawn.attachments. (#16761) Thanks @napetrov. - Telegram/Streaming defaults: default
channels.telegram.streamingtopartial(fromoff) so new Telegram setups get live preview streaming out of the box, with runtime fallback to message-edit preview when native drafts are unavailable. - Telegram/DM streaming: use
sendMessageDraftfor private preview streaming, keep reasoning/answer preview lanes separated in DM reasoning-stream mode. (#31824) Thanks @obviyus. - Telegram/voice mention gating: add optional
disableAudioPreflighton group/topic config to skip mention-detection preflight transcription for inbound voice notes where operators want text-only mention checks. (#23067) Thanks @yangnim21029. - CLI/Config validation: add
openclaw config validate(with--json) to validate config files before gateway startup, and include detailed invalid-key paths in startup invalid-config errors. (#31220) thanks @Sid-Qin. - Tools/Diffs: add PDF file output support and rendering quality customization controls (
fileQuality,fileScale,fileMaxWidth) for generated diff artifacts, and document PDF as the preferred option when messaging channels compress images. (#31342) Thanks @gumadeiras. - Memory/Ollama embeddings: add
memorySearch.provider = "ollama"andmemorySearch.fallback = "ollama"support, honormodels.providers.ollamasettings for memory embedding requests, and document Ollama embedding usage. (#26349) Thanks @nico-hoff. - Zalo Personal plugin (
@openclaw/zalouser): rebuilt channel runtime to use nativezca-jsintegration in-process, removing external CLI transport usage and keeping QR/login + send/listen flows fully inside OpenClaw. - Plugin SDK/channel extensibility: expose
channelRuntimeonChannelGatewayContextso external channel plugins can access shared runtime helpers (reply/routing/session/text/media/commands) without internal imports. (#25462) Thanks @guxiaobo. - Plugin runtime/STT: add
api.runtime.stt.transcribeAudioFile(...)so extensions can transcribe local audio files through OpenClaw's configured media-understanding audio providers. (#22402) Thanks @benthecarman. - Plugin hooks/session lifecycle: include
sessionKeyinsession_start/session_endhook events and contexts so plugins can correlate lifecycle callbacks with routing identity. (#26394) Thanks @tempeste. - Hooks/message lifecycle: add internal hook events
message:transcribedandmessage:preprocessed, plus richer outboundmessage:sentcontext (isGroup,groupId) for group-conversation correlation and post-transcription automations. (#9859) Thanks @Drickon. - Media understanding/audio echo: add optional
tools.media.audio.echoTranscript+echoFormatto send a pre-agent transcript confirmation message to the originating chat, with echo disabled by default. (#32150) Thanks @AytuncYildizli. - Plugin runtime/system: expose
runtime.system.requestHeartbeatNow(...)so extensions can wake targeted sessions immediately after enqueueing system events. (#19464) Thanks @AustinEral. - Plugin runtime/events: expose
runtime.events.onAgentEventandruntime.events.onSessionTranscriptUpdatefor extension-side subscriptions, and isolate transcript-listener failures so one faulty listener cannot break the entire update fanout. (#16044) Thanks @scifantastic. - CLI/Banner taglines: add
cli.banner.taglineMode(random|default|off) to control funny tagline behavior in startup output, with docs + FAQ guidance and regression tests for config override behavior.
Breaking
- BREAKING: Onboarding now defaults
tools.profiletomessagingfor new local installs (interactive + non-interactive). New setups no longer start with broad coding/system tools unless explicitly configured. - BREAKING: ACP dispatch now defaults to enabled unless explicitly disabled (
acp.dispatch.enabled=false). If you need to pause ACP turn routing while keeping/acpcontrols, setacp.dispatch.enabled=false. Docs: https://docs.openclaw.ai/tools/acp-agents - BREAKING: Plugin SDK removed
api.registerHttpHandler(...). Plugins must register explicit HTTP routes viaapi.registerHttpRoute({ path, auth, match, handler }), and dynamic webhook lifecycles should useregisterPluginHttpRoute(...). - BREAKING: Zalo Personal plugin (
@openclaw/zalouser) no longer depends on externalzca-compatible CLI binaries (openzca,zca-cli) for runtime send/listen/login; operators should useopenclaw channels login --channel zalouserafter upgrade to refresh sessions in the new JS-native path.
Fixes
- Plugin command/runtime hardening: validate and normalize plugin command name/description at registration boundaries, and guard Telegram native menu normalization paths so malformed plugin command specs cannot crash startup (
trimon undefined). (#31997) Fixes #31944. Thanks @liuxiaopai-ai. - Telegram: guard duplicate-token checks and gateway startup token normalization when account tokens are missing, preventing
token.trim()crashes during status/start flows. (#31973) Thanks @ningding97. - Discord/lifecycle startup status: push an immediate
connectedstatus snapshot when the gateway is already connected before lifecycle debug listeners attach, with abort-guarding to avoid contradictory status flips during pre-aborted startup. (#32336) Thanks @mitchmcalister. - Feishu/multi-app mention routing: guard mention detection in multi-bot groups by validating mention display name alongside bot
open_id, preventing false-positive self-mentions from Feishu WebSocket remapping so only the actually mentioned bot responds underrequireMention. (#30315) Thanks @teaguexiao. - Feishu/session-memory hook parity: trigger the shared
before_resetsession-memory hook path when Feishu/newand/resetcommands execute so reset flows preserve memory behavior consistent with other channels. (#31437) Thanks @Linux2010. - Feishu/LINE group system prompts: forward per-group
systemPromptconfig into inbound contextGroupSystemPromptfor Feishu and LINE group/room events so configured group-specific behavior actually applies at dispatch time. (#31713) Thanks @whiskyboy. - Mentions/Slack formatting hardening: add null-safe guards for runtime text normalization paths so malformed/undefined text payloads do not crash mention stripping or mrkdwn conversion. (#31865) Thanks @stone-jin.
- Feishu/Plugin sdk compatibility: add safe webhook default fallbacks when loading Feishu monitor state so mixed-version installs no longer crash if older
openclaw/plugin-sdkbuilds omit webhook default constants. (#31606) - Feishu/group broadcast dispatch: add configurable multi-agent group broadcast dispatch with observer-session isolation, cross-account dedupe safeguards, and non-mention history buffering rules that avoid duplicate replay in broadcast/topic workflows. (#29575) Thanks @ohmyskyhigh.
- Gateway/Subagent TLS pairing: allow authenticated local
gateway-clientbackend self-connections to skip device pairing while still requiring pairing for non-local/direct-host paths, restoringsessions_spawnwithgateway.tls.enabled=truein Docker/LAN setups. Fixes #30740. Thanks @Sid-Qin and @vincentkoc. - Browser/CDP startup diagnostics: include Chrome stderr output and a Linux no-sandbox hint in startup timeout errors so failed launches are easier to diagnose. (#29312) Thanks @veast.
- Synology Chat/webhook ingress hardening: enforce bounded body reads (size + timeout) via shared request-body guards to prevent unauthenticated slow-body hangs before token validation. (#25831) Thanks @bmendonca3.
- Feishu/Dedup restart resilience: warm persistent dedup state into memory on monitor startup so retry events after gateway restart stay suppressed without requiring initial on-disk probe misses. (#31605)
- Voice-call/runtime lifecycle: prevent
EADDRINUSEloops by resetting failed runtime promises, making webhookstart()idempotent with the actual bound port, and fully cleaning up webhook/tunnel/tailscale resources after startup failures. (#32395) Thanks @scoootscooob. - Gateway/Security hardening: tie loopback-origin dev allowance to actual local socket clients (not Host header claims), add explicit warnings/metrics when
gateway.controlUi.dangerouslyAllowHostHeaderOriginFallbackaccepts websocket origins, harden safe-regex detection for quantified ambiguous alternation patterns (for example(a|aa)+), and bound large regex-evaluation inputs for session-filter and log-redaction paths. - Gateway/Plugin HTTP hardening: require explicit
authfor plugin route registration...