Skip to content

fix(browser): validate discovered CDP websocket URLs#91747

Merged
eleqtrizit merged 6 commits into
openclaw:mainfrom
eleqtrizit:740
Jun 10, 2026
Merged

fix(browser): validate discovered CDP websocket URLs#91747
eleqtrizit merged 6 commits into
openclaw:mainfrom
eleqtrizit:740

Conversation

@eleqtrizit

Copy link
Copy Markdown
Contributor

Summary

Fixes the browser remote CDP raw /json/list fallback so discovered per-tab WebSocket endpoints are checked against the existing CDP endpoint policy before being returned to downstream tab consumers.

Changes

  • Validate each selectable normalized discovered webSocketDebuggerUrl with assertCdpEndpointAllowed() before returning tab.wsUrl.
  • Keep browser-internal target filtering before endpoint validation so non-selectable targets remain ignored.
  • Add regression coverage for strict CDP policy rejecting a blocked discovered WebSocket endpoint.
  • Update fallback test fixtures to use the harness-approved remote CDP host instead of a DNS-only example host.

Validation

  • node scripts/run-vitest.mjs run extensions/browser/src/browser/server-context.remote-profile-tab-ops.fallback.test.ts
  • node scripts/run-vitest.mjs run extensions/browser/src/browser/server-context.remote-profile-tab-ops.fallback.test.ts extensions/browser/src/browser/cdp.helpers.internal.test.ts extensions/browser/src/browser/chrome.loopback-ssrf.integration.test.ts
  • git diff --check
  • .agents/skills/autoreview/scripts/autoreview --mode local

Notes

  • AI-assisted change.
  • CHANGELOG.md was not updated.
  • USER.md worklog was appended locally and intentionally left out of the commit.
  • Real behavior proof: targeted browser-extension regression tests exercise the affected remote CDP fallback path through the repo test harness; no live remote browser provider was used.

@openclaw-barnacle openclaw-barnacle Bot added size: S maintainer Maintainer-authored PR labels Jun 9, 2026
@clawsweeper

clawsweeper Bot commented Jun 9, 2026

Copy link
Copy Markdown
Contributor

Codex review: needs maintainer review before merge. Reviewed June 9, 2026, 8:09 PM ET / 00:09 UTC.

Summary
The PR validates raw CDP discovered WebSocket endpoints from /json/list, /json/new, and Playwright termination cleanup with the existing SSRF policy, plus focused regression tests.

PR surface: Source +21, Tests +215. Total +236 across 10 files.

Reproducibility: yes. Current main source shows raw CDP fallback paths returning discovered WebSocket URLs without endpoint validation, and the PR proof demonstrates the after-fix blocked result against a local CDP-compatible endpoint.

Review metrics: 1 noteworthy metric.

  • Strict CDP checks: 3 enforcement points added. The PR changes strict-mode behavior for raw CDP list, raw CDP create, and cleanup discovery paths that previously trusted discovered WebSocket URLs.

Merge readiness
Overall: 🦞 diamond lobster
Proof: 🦞 diamond lobster
Patch quality: 🦞 diamond lobster
Result: ready for maintainer review.

Overall follows the weaker of proof and patch quality, so missing proof can cap an otherwise strong patch.

Risk before merge

  • [P1] Strict-mode users whose approved CDP HTTP endpoint advertises a private or link-local per-tab WebSocket will now fail closed instead of using that tab; this is the intended security boundary but can break existing remote CDP setups.

Maintainer options:

  1. Accept strict-mode fail-closed validation (recommended)
    Merge after maintainer acceptance that strict SSRF policy rejects discovered per-tab WebSocket URLs outside the allowed CDP host, even when the CDP HTTP endpoint itself is reachable.
  2. Require a compatibility escape hatch
    If maintainers need to preserve providers that advertise private WebSocket hosts, require an explicit documented opt-in or provider-specific proof before merge.

Next step before merge

  • No automated repair is needed; the remaining action is maintainer acceptance of a protected-label, compatibility-sensitive strict-SSRF behavior change.

Security
Cleared: The diff strengthens an existing browser CDP SSRF boundary and does not add dependencies, workflow changes, or new code-execution surfaces.

Review details

Best possible solution:

Land the targeted validation after maintainers explicitly accept the strict-mode fail-closed upgrade impact and keep the existing SSRF policy as the single source of truth.

Do we have a high-confidence way to reproduce the issue?

Yes. Current main source shows raw CDP fallback paths returning discovered WebSocket URLs without endpoint validation, and the PR proof demonstrates the after-fix blocked result against a local CDP-compatible endpoint.

Is this the best way to solve the issue?

Yes. Reusing assertCdpEndpointAllowed() at each discovery boundary is the narrowest maintainable fix; the only unresolved question is maintainer acceptance of the fail-closed compatibility effect.

AGENTS.md: found and applied where relevant.

Codex review notes: model gpt-5.5, reasoning high; reviewed against 48ec58a5844f.

Label changes

Label justifications:

  • P1: The PR addresses a browser CDP SSRF policy bypass affecting strict-mode users and the browser control security boundary.
  • merge-risk: 🚨 compatibility: Existing remote CDP setups can fail closed if their reachable HTTP endpoint advertises a per-tab WebSocket on a host that strict SSRF policy blocks.
  • rating: 🦞 diamond lobster: Overall readiness is 🦞 diamond lobster; proof is 🦞 diamond lobster and patch quality is 🦞 diamond lobster.
  • status: 👀 ready for maintainer look: ClawSweeper has no concrete contributor-facing blocker left for this PR. Sufficient (terminal): Contributor-supplied terminal proof shows after-fix strict-policy rejection for both raw /json/list and /json/new discovered link-local WebSocket URLs, with private values redacted.
  • proof: sufficient: Contributor real behavior proof is sufficient. Contributor-supplied terminal proof shows after-fix strict-policy rejection for both raw /json/list and /json/new discovered link-local WebSocket URLs, with private values redacted.
Evidence reviewed

PR surface:

Source +21, Tests +215. Total +236 across 10 files.

View PR surface stats
Area Files Added Removed Net
Source 5 27 6 +21
Tests 5 221 6 +215
Docs 0 0 0 0
Config 0 0 0 0
Generated 0 0 0 0
Other 0 0 0 0
Total 10 248 12 +236

What I checked:

Likely related people:

  • Shakker: Current blame in this checkout attributes the central browser CDP tab ops, termination cleanup, and CDP endpoint helper lines to the same recent commit; history depth is shallow, so this is a routing hint rather than full ownership proof. (role: recent area contributor; confidence: medium; commits: d48778994fb2; files: extensions/browser/src/browser/server-context.tab-ops.ts, extensions/browser/src/browser/pw-session.ts, extensions/browser/src/browser/cdp.helpers.ts)
What the crustacean ranks mean
  • 🦀 challenger crab: rare, exceptional readiness with strong proof, clean implementation, and convincing validation.
  • 🦞 diamond lobster: very strong readiness with only minor maintainer review expected.
  • 🐚 platinum hermit: good normal PR, likely mergeable with ordinary maintainer review.
  • 🦐 gold shrimp: useful signal, but proof or patch confidence is still limited.
  • 🦪 silver shellfish: thin signal; proof, validation, or implementation needs work.
  • 🧂 unranked krab: not merge-ready because proof is missing/unusable or there are serious correctness or safety concerns.
  • 🌊 off-meta tidepool: rating does not apply to this item.

Shiny media proof means a screenshot, video, or linked artifact directly shows the changed behavior. Runtime, network, CSP, and security claims still need visible diagnostics.

How this review workflow works
  • ClawSweeper keeps one durable marker-backed review comment per issue or PR.
  • Re-runs edit this comment so the latest verdict, findings, and automation markers stay together instead of adding duplicate bot comments.
  • A fresh review can be triggered by eligible @clawsweeper re-review comments, exact-item GitHub events, scheduled/background review runs, or manual workflow dispatch.
  • PR/issue authors and users with repository write access can comment @clawsweeper re-review or @clawsweeper re-run on an open PR or issue to request a fresh review only.
  • Maintainers can also comment @clawsweeper review to request a fresh review only.
  • Fresh-review commands do not start repair, autofix, rebase, CI repair, or automerge.
  • Maintainer-only repair and merge flows require explicit commands such as @clawsweeper autofix, @clawsweeper automerge, @clawsweeper fix ci, or @clawsweeper address review.
  • Maintainers can comment @clawsweeper explain to ask for more context, or @clawsweeper stop to stop active automation.

@clawsweeper clawsweeper Bot added rating: 🧂 unranked krab Not merge-ready due to missing proof or serious correctness/safety concerns. status: 📣 needs proof The PR needs real behavior proof before ClawSweeper can clear the contributor ask. P1 High-priority user-facing bug, regression, or broken workflow. merge-risk: 🚨 compatibility 🚨 May break existing users, config, migrations, defaults, or upgrade paths. merge-risk: 🚨 security-boundary 🚨 May affect sandboxing, authorization, credentials, or sensitive data. labels Jun 9, 2026
@eleqtrizit

Copy link
Copy Markdown
Contributor Author

Behavioral proof

This addresses the ClawSweeper asks from the latest review:

  • /json/new is now covered by the same discovered WebSocket endpoint validation as /json/list.
  • I ran a redacted runtime proof against a real local CDP-compatible HTTP endpoint, not just the Vitest harness.

Proof setup:

  • Started a local CDP-style HTTP endpoint on 127.0.0.1.
  • Configured strict browser SSRF policy: dangerouslyAllowPrivateNetwork=false.
  • Exercised production createProfileTabOps() against the raw CDP fallback path.
  • Disabled the optional Playwright helper load for this proof so the run reaches the raw /json/list and /json/new CDP fallback code paths that this PR changes.
  • The endpoint advertised link-local discovered WebSocket URLs for both list and create responses.

Runtime proof command:

node --import tsx --loader ./.codex-proof/pw-ai-unavailable-loader.mjs ./.codex-proof/cdp-ssrf-proof.ts

Runtime proof output:

CDP SSRF behavioral proof
configured cdpUrl: http://127.0.0.1:42391/chrome?token=<redacted>
strict policy: dangerouslyAllowPrivateNetwork=false
advertised list websocket: ws://169.254.169.254/devtools/page/T_LIST
list result: blocked with BrowserCdpEndpointBlockedError
advertised created websocket: ws://169.254.169.254/devtools/page/T_NEW
create result: blocked with BrowserCdpEndpointBlockedError
requests observed:
- GET /chrome/json/list?token=<redacted>
- GET /chrome/json/version?token=<redacted>
- PUT /chrome/json/new?token=<redacted>&url=about%3Ablank

Additional validation:

node scripts/run-vitest.mjs run extensions/browser/src/browser/server-context.remote-profile-tab-ops.fallback.test.ts

Result:

Test Files  1 passed (1)
Tests       12 passed (12)
node scripts/run-vitest.mjs run extensions/browser/src/browser/server-context.remote-profile-tab-ops.fallback.test.ts extensions/browser/src/browser/cdp.helpers.internal.test.ts extensions/browser/src/browser/chrome.loopback-ssrf.integration.test.ts

Result:

Test Files  3 passed (3)
Tests       42 passed (42)
git diff --check upstream/main...HEAD

Result: passed.

The temporary proof files were removed after the run. CHANGELOG.md was not updated.

@eleqtrizit

Copy link
Copy Markdown
Contributor Author

@clawsweeper re-review

@clawsweeper

clawsweeper Bot commented Jun 9, 2026

Copy link
Copy Markdown
Contributor

🦞🧹
ClawSweeper re-review requested.

I asked ClawSweeper to review this item again.
Action: item re-review queued (workflow sweep.yml, event repository_dispatch).
Result: the existing ClawSweeper review comment will be edited in place when the review finishes.

Re-review progress:

@clawsweeper clawsweeper Bot added proof: sufficient ClawSweeper judged the real behavior proof convincing. status: ⏳ waiting on author ClawSweeper has contributor-facing work open and is waiting for author action. and removed status: 📣 needs proof The PR needs real behavior proof before ClawSweeper can clear the contributor ask. labels Jun 9, 2026
@eleqtrizit eleqtrizit self-assigned this Jun 9, 2026
@eleqtrizit

Copy link
Copy Markdown
Contributor Author

@clawsweeper re-review

@clawsweeper

clawsweeper Bot commented Jun 9, 2026

Copy link
Copy Markdown
Contributor

🦞🧹
ClawSweeper re-review requested.

I asked ClawSweeper to review this item again.
Action: item re-review queued (workflow sweep.yml, event repository_dispatch).
Result: the existing ClawSweeper review comment will be edited in place when the review finishes.

Re-review progress:

@clawsweeper clawsweeper Bot added rating: 🐚 platinum hermit Good normal PR readiness with ordinary maintainer review expected. status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR. and removed rating: 🧂 unranked krab Not merge-ready due to missing proof or serious correctness/safety concerns. status: ⏳ waiting on author ClawSweeper has contributor-facing work open and is waiting for author action. proof: sufficient ClawSweeper judged the real behavior proof convincing. rating: 🐚 platinum hermit Good normal PR readiness with ordinary maintainer review expected. labels Jun 9, 2026
@clawsweeper clawsweeper Bot added the rating: 🌊 off-meta tidepool PR readiness rating does not apply to this item. label Jun 9, 2026
@clawsweeper clawsweeper Bot removed the status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR. label Jun 9, 2026
@eleqtrizit

Copy link
Copy Markdown
Contributor Author

Summary of Checks Performed

Relevance

The issue was confirmed as a legitimate CDP SSRF policy bypass — in scope per SECURITY.md, not yet fixed on main, and fixable with a targeted backward-compatible change using existing SSRF infrastructure. The vulnerability allows a policy-approved CDP HTTP endpoint to return a webSocketDebuggerUrl pointing to a blocked private/link-local endpoint (e.g., AWS metadata), bypassing the existing SSRF boundary. All reviewers verified the vulnerable code path on current origin/main.

Compatibility

The change reuses the existing assertCdpEndpointAllowed() helper (which already supports http, https, ws, and wss protocols) without adding any new config options, public APIs, CLI flags, gateway protocol fields, plugin manifest changes, or docs surfaces. No migration, no new defaults, no breaking changes. Operators with dangerouslyAllowPrivateNetwork: true are unaffected. The fix aligns the raw CDP fallback paths with sibling CDP discovery paths that already validate discovered WebSocket URLs. Boundary inventory scripts report no import violations.

ClawSweeper

ClawSweeper reviewed the PR and identified two concerns: the sibling /json/new fallback path and missing real behavior proof. Both were addressed — the /json/new path received the same SSRF validation, and a real behavioral proof was run against a local CDP endpoint exercising both raw CDP fallback paths with strict SSRF policy, confirming both paths correctly reject blocked discovered WebSocket URLs with BrowserCdpEndpointBlockedError.

Code Reviews Completed

Multiple code reviews verified the fix across several dimensions: security boundary correctness, code quality, backward compatibility, test coverage, sibling path parity, downstream consumer analysis, error handling, and CI validation. All reviews confirmed the core fix is sound, targeted, and well-implemented. A lint issue (oxlint no-base-to-string in a test file) was identified during CI and fixed.


All Checks Completed

Check Result
Unit tests — CDP fallback SSRF regression ✅ Passed (12 tests)
Unit tests — CDP helpers + Chrome SSRF integration ✅ Passed (42 tests, 3 files)
Real behavioral proof — local CDP endpoint ✅ Both /json/list and /json/new blocked with BrowserCdpEndpointBlockedError
git diff --check ✅ Passed
Auto-review (autoreview --mode local) ✅ Clean, no actionable findings
Import boundary checks ✅ No violations
CI — preflight ✅ Passed
CI — security-fast ✅ Passed
CI — check-prod-types ✅ Passed
CI — check-test-types ✅ Passed
CI — check-guards ✅ Passed
CI — check-lint ✅ Passed (after fix)
CI — check-additional-extension-bundled ✅ Passed (after fix)
CI — check-dependencies ✅ Passed
CI — Node core test shards (80+) ✅ Passed
CI — Agentic test shards ✅ Passed
CI — Extension boundary lanes ✅ Passed
Code review — security boundary correctness ✅ All CDP discovery paths now validated
Code review — backward compatibility ✅ No breaking changes
Code review — sibling path parity ✅ Playwright, /json/list, /json/new, cdp.ts, chrome.ts all consistent
Code review — downstream consumer analysis ✅ Validation at tab-listing layer protects all consumers

Abbreviations

Abbreviation Definition
CDP Chrome DevTools Protocol — the protocol used to control Chromium browser tabs
SSRF Server-Side Request Forgery — an attack that tricks a server into making requests to internal/private resources
CI Continuous Integration — automated test and validation pipeline
LOC Lines of Code
GHSA GitHub Security Advisory
CVE Common Vulnerabilities and Exposures — a standard for identifying security vulnerabilities

@clawsweeper clawsweeper Bot added proof: sufficient ClawSweeper judged the real behavior proof convincing. rating: 🦞 diamond lobster Very strong PR readiness with only minor maintainer review expected. status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR. and removed rating: 🌊 off-meta tidepool PR readiness rating does not apply to this item. merge-risk: 🚨 security-boundary 🚨 May affect sandboxing, authorization, credentials, or sensitive data. labels Jun 9, 2026
@clawsweeper clawsweeper Bot added rating: 🧂 unranked krab Not merge-ready due to missing proof or serious correctness/safety concerns. status: ⏳ waiting on author ClawSweeper has contributor-facing work open and is waiting for author action. and removed rating: 🦞 diamond lobster Very strong PR readiness with only minor maintainer review expected. status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR. labels Jun 9, 2026
@clawsweeper clawsweeper Bot added rating: 🦞 diamond lobster Very strong PR readiness with only minor maintainer review expected. status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR. and removed rating: 🧂 unranked krab Not merge-ready due to missing proof or serious correctness/safety concerns. status: ⏳ waiting on author ClawSweeper has contributor-facing work open and is waiting for author action. labels Jun 9, 2026
@eleqtrizit

Copy link
Copy Markdown
Contributor Author

Behavioral proof

This addresses the latest ClawSweeper review ask: the production Playwright termination cleanup callers now pass the existing ssrfPolicy into forceDisconnectPlaywrightForTarget, and the tests prove the click abort, evaluate abort, and navigation retry paths preserve that policy.

Behavior addressed: strict browser CDP SSRF policy must apply to discovered WebSocket endpoints from raw CDP fallback paths and to best-effort Playwright termination cleanup.

Real environment tested: local CDP-compatible HTTP endpoint bound on 127.0.0.1, with the local endpoint explicitly allowlisted and strict policy enabled. The endpoint advertised link-local WebSocket URLs for both raw tab listing and raw tab creation. The optional Playwright module was made unavailable only for this proof so the run exercised the raw CDP fallback code paths changed by this PR.

Exact command run after this patch:

node --loader ./.codex-proof/pw-ai-unavailable-loader.mjs --import tsx --input-type=module <runtime proof script>

Evidence after fix:

CDP SSRF behavioral proof
configured cdpUrl: http://127.0.0.1:32817/chrome?token=<redacted>
strict policy: dangerouslyAllowPrivateNetwork=false; allowedHostnames includes 127.0.0.1
optional Playwright module: unavailable for raw fallback proof
advertised list websocket: ws://169.254.169.254/devtools/page/T_LIST
list result: blocked with BrowserCdpEndpointBlockedError
advertised created websocket: ws://169.254.169.254/devtools/page/T_NEW
create result: blocked with BrowserCdpEndpointBlockedError
requests observed:
- GET /chrome/json/list?token=<redacted>
- GET /chrome/json/version?token=<redacted>
- PUT /chrome/json/new?token=<redacted>&url=about%3Ablank

Observed result after fix: the policy-approved local CDP HTTP endpoint was reachable, but both advertised link-local discovered WebSocket URLs were rejected with BrowserCdpEndpointBlockedError before being returned or used.

Additional focused validation after the ClawSweeper fix:

node scripts/run-vitest.mjs run extensions/browser/src/browser/pw-tools-core.interactions.evaluate.abort.test.ts extensions/browser/src/browser/pw-tools-core.snapshot.navigate-guard.test.ts extensions/browser/src/browser/pw-tools-core.browser-ssrf-guard.test.ts extensions/browser/src/browser/pw-session.termination-cdp-ssrf.test.ts
Test Files  4 passed (4)
Tests       19 passed (19)
node scripts/run-vitest.mjs run extensions/browser/src/browser/pw-session.termination-cdp-ssrf.test.ts extensions/browser/src/browser/pw-tools-core.interactions.evaluate.abort.test.ts extensions/browser/src/browser/pw-tools-core.snapshot.navigate-guard.test.ts
Test Files  3 passed (3)
Tests       9 passed (9)
node scripts/run-vitest.mjs run extensions/browser/src/browser/server-context.remote-profile-tab-ops.fallback.test.ts extensions/browser/src/browser/cdp.helpers.internal.test.ts extensions/browser/src/browser/chrome.loopback-ssrf.integration.test.ts extensions/browser/src/browser/pw-tools-core.browser-ssrf-guard.test.ts
Test Files  4 passed (4)
Tests       52 passed (52)
git diff --check upstream/main...HEAD
git diff --check
.agents/skills/autoreview/scripts/autoreview --mode local

Results: both diff checks passed; autoreview reported no accepted/actionable findings.

What was not tested: no external hosted browser provider was used. The proof uses a local CDP-compatible endpoint so the advertised blocked WebSocket behavior is deterministic and redacted. Temporary proof files were removed after the run. CHANGELOG.md was not updated, and USER.md remains uncommitted.

@eleqtrizit

Copy link
Copy Markdown
Contributor Author

@clawsweeper re-review

@clawsweeper

clawsweeper Bot commented Jun 10, 2026

Copy link
Copy Markdown
Contributor

🦞🧹
ClawSweeper re-review requested.

I asked ClawSweeper to review this item again.
Action: item re-review queued (workflow sweep.yml, event repository_dispatch).
Result: the existing ClawSweeper review comment will be edited in place when the review finishes.

Re-review progress:

@eleqtrizit eleqtrizit merged commit ade5ac0 into openclaw:main Jun 10, 2026
169 of 175 checks passed
github-actions Bot pushed a commit to Desicool/openclaw that referenced this pull request Jun 11, 2026
* fix(browser): validate discovered cdp websocket urls

* fix(browser): validate cdp tab creation websockets

* fix(browser): guard termination cdp websocket

* fix(browser): use .toString() instead of String() to satisfy oxlint no-base-to-string

* fix(browser): avoid cdp termination assertion stringification

* fix(browser): preserve cdp ssrf policy
eleboucher pushed a commit to eleboucher/homelab that referenced this pull request Jun 12, 2026
…26.6.6) (#1040)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
| [ghcr.io/openclaw/openclaw](https://openclaw.ai) ([source](https://github.com/openclaw/openclaw)) | patch | `2026.6.5` → `2026.6.6` |

---

### Release Notes

<details>
<summary>openclaw/openclaw (ghcr.io/openclaw/openclaw)</summary>

### [`v2026.6.6`](https://github.com/openclaw/openclaw/blob/HEAD/CHANGELOG.md#202666)

[Compare Source](openclaw/openclaw@v2026.6.5...v2026.6.6)

##### Highlights

- Security boundaries are substantially tighter across transcripts, sandbox binds, host environment inheritance, MCP stdio, Codex HTTP access, native search policy, elevated sender checks, deleted-agent ACP bypasses, loopback tools, Discord moderation, and Teams group actions; exec approvals now fail closed on timeout. ([#&#8203;91529](openclaw/openclaw#91529), [#&#8203;91618](openclaw/openclaw#91618), [#&#8203;91615](openclaw/openclaw#91615), [#&#8203;91619](openclaw/openclaw#91619), [#&#8203;91741](openclaw/openclaw#91741), [#&#8203;91745](openclaw/openclaw#91745), [#&#8203;91746](openclaw/openclaw#91746), [#&#8203;91748](openclaw/openclaw#91748), [#&#8203;91749](openclaw/openclaw#91749), [#&#8203;91750](openclaw/openclaw#91750), [#&#8203;91751](openclaw/openclaw#91751), [#&#8203;91752](openclaw/openclaw#91752), [#&#8203;91763](openclaw/openclaw#91763), [#&#8203;89938](openclaw/openclaw#89938)) Thanks [@&#8203;joshavant](https://github.com/joshavant), [@&#8203;pgondhi987](https://github.com/pgondhi987), [@&#8203;mmaps](https://github.com/mmaps), [@&#8203;eleqtrizit](https://github.com/eleqtrizit), [@&#8203;shakkernerd](https://github.com/shakkernerd), and [@&#8203;drobison00](https://github.com/drobison00).
- Telegram delivery is safer and more coherent: account-scoped topics route to the right agent, streamed text survives tool calls, `/compact` works on generic ingress, callback handling uses concrete APIs, draft chunking is shared, durable dispatch dedupe moved into the SDK, and unauthorized DM text stays out of cache and prompt context. ([#&#8203;91189](openclaw/openclaw#91189), [#&#8203;88682](openclaw/openclaw#88682), [#&#8203;89588](openclaw/openclaw#89588), [#&#8203;90212](openclaw/openclaw#90212), [#&#8203;91876](openclaw/openclaw#91876), [#&#8203;91874](openclaw/openclaw#91874), [#&#8203;91904](openclaw/openclaw#91904), [#&#8203;91478](openclaw/openclaw#91478), [#&#8203;91915](openclaw/openclaw#91915)) Thanks [@&#8203;codysai001](https://github.com/codysai001), [@&#8203;alexzhu0](https://github.com/alexzhu0), [@&#8203;joelnishanth](https://github.com/joelnishanth), [@&#8203;snowzlm](https://github.com/snowzlm), [@&#8203;obviyus](https://github.com/obviyus), and [@&#8203;sallyom](https://github.com/sallyom).
- iMessage recovery and delivery now cover always-on inbound restart, durable echo markers, block streaming, idle approval discovery, hardened outbound transport, and actionable inbound startup diagnostics. ([#&#8203;91335](openclaw/openclaw#91335), [#&#8203;91449](openclaw/openclaw#91449), [#&#8203;88969](openclaw/openclaw#88969), [#&#8203;88530](openclaw/openclaw#88530), [#&#8203;91783](openclaw/openclaw#91783), [#&#8203;91785](openclaw/openclaw#91785)) Thanks [@&#8203;omarshahine](https://github.com/omarshahine), [@&#8203;jmissig](https://github.com/jmissig), and [@&#8203;colmbrogan](https://github.com/colmbrogan).
- Browser and MCP connectivity gained existing-session CDP support, discovered WebSocket validation, default-profile `cdpUrl` handling, safer browser-output boundaries, Streamable HTTP loopback transport, corrected OAuth/SSE authorization handling, and broader schema compatibility. ([#&#8203;91422](openclaw/openclaw#91422), [#&#8203;89851](openclaw/openclaw#89851), [#&#8203;91736](openclaw/openclaw#91736), [#&#8203;91747](openclaw/openclaw#91747), [#&#8203;91451](openclaw/openclaw#91451), [#&#8203;80143](openclaw/openclaw#80143)) Thanks [@&#8203;pgondhi987](https://github.com/pgondhi987), [@&#8203;anagnorisis2peripeteia](https://github.com/anagnorisis2peripeteia), [@&#8203;lifuyue](https://github.com/lifuyue), [@&#8203;eleqtrizit](https://github.com/eleqtrizit), [@&#8203;LiuwqGit](https://github.com/LiuwqGit), and [@&#8203;HemantSudarshan](https://github.com/HemantSudarshan).
- Control UI startup and first-reply latency are lower through cached model metadata, removal of the startup catalog wait, lazy slash-command loading, and first-event tracing with slow-reply diagnostics. ([#&#8203;91531](openclaw/openclaw#91531), [#&#8203;91538](openclaw/openclaw#91538), [#&#8203;91568](openclaw/openclaw#91568), [#&#8203;91583](openclaw/openclaw#91583), [#&#8203;91598](openclaw/openclaw#91598))
- Provider support expands with OpenRouter OAuth onboarding and Claude Fable 5 adaptive thinking, while Codex sessions keep correct compaction ownership, local models skip guardian review, dynamic tool progress normalizes cleanly, and Gemma 4 reasoning replay is preserved. ([#&#8203;91830](openclaw/openclaw#91830), [#&#8203;91882](openclaw/openclaw#91882), [#&#8203;91590](openclaw/openclaw#91590), [#&#8203;88630](openclaw/openclaw#88630), [#&#8203;88768](openclaw/openclaw#88768), [#&#8203;91696](openclaw/openclaw#91696)) Thanks [@&#8203;Patrick-Erichsen](https://github.com/Patrick-Erichsen), [@&#8203;joshavant](https://github.com/joshavant), [@&#8203;bdjben](https://github.com/bdjben), and [@&#8203;Coder-Wangyankun](https://github.com/Coder-Wangyankun).

##### Changes

- CLI progress: emit Claude CLI commentary progress events and bridge inter-tool commentary into channel progress without exposing internal protocol scaffolding. ([#&#8203;89834](openclaw/openclaw#89834), [#&#8203;90883](openclaw/openclaw#90883)) Thanks [@&#8203;anagnorisis2peripeteia](https://github.com/anagnorisis2peripeteia).
- Observability: allow trusted diagnostics channels to capture tool input/output content, add first-assistant-event traces, and warn on slow initial replies. ([#&#8203;91256](openclaw/openclaw#91256), [#&#8203;91568](openclaw/openclaw#91568), [#&#8203;91583](openclaw/openclaw#91583)) Thanks [@&#8203;amknight](https://github.com/amknight).
- Plugins/ClawHub: dogfood reusable package publishing, let dry runs skip publish approval, allow declared installed trusted hooks, report managed plugin version drift, and warn instead of failing on retired Skill Workshop configuration. ([#&#8203;91574](openclaw/openclaw#91574), [#&#8203;91591](openclaw/openclaw#91591), [#&#8203;90004](openclaw/openclaw#90004), [#&#8203;90927](openclaw/openclaw#90927), [#&#8203;90838](openclaw/openclaw#90838)) Thanks [@&#8203;Patrick-Erichsen](https://github.com/Patrick-Erichsen), [@&#8203;brokemac79](https://github.com/brokemac79), and [@&#8203;lonexreb](https://github.com/lonexreb).
- Memory/providers: move the local llama.cpp runtime into its provider plugin, batch embeddings across files, persist the agent model catalog cache, and keep QMD JSON search one-shot while filtering stale REM recall previews. ([#&#8203;91324](openclaw/openclaw#91324), [#&#8203;89138](openclaw/openclaw#89138), [#&#8203;90457](openclaw/openclaw#90457), [#&#8203;91837](openclaw/openclaw#91837), [#&#8203;91851](openclaw/openclaw#91851)) Thanks [@&#8203;osolmaz](https://github.com/osolmaz), [@&#8203;mushuiyu886](https://github.com/mushuiyu886), [@&#8203;ai-hpc](https://github.com/ai-hpc), and [@&#8203;TurboTheTurtle](https://github.com/TurboTheTurtle).
- Channels/mobile: add the QQBot group mention toggle, improve iPad and iPhone control surfaces, and expose the active connection host in the TUI footer. ([#&#8203;91423](openclaw/openclaw#91423), [#&#8203;91557](openclaw/openclaw#91557), [#&#8203;89909](openclaw/openclaw#89909)) Thanks [@&#8203;cxyhhhhh](https://github.com/cxyhhhhh), [@&#8203;Solvely-Colin](https://github.com/Solvely-Colin), and [@&#8203;baskduf](https://github.com/baskduf).
- Performance: prewarm TUI runtime plugins, deduplicate plugin auto-enable fanout, trim dense text-delta snapshots, and reuse prepared startup model metadata. ([#&#8203;90782](openclaw/openclaw#90782), [#&#8203;89978](openclaw/openclaw#89978), [#&#8203;91580](openclaw/openclaw#91580), [#&#8203;91531](openclaw/openclaw#91531)) Thanks [@&#8203;RomneyDa](https://github.com/RomneyDa) and [@&#8203;ai-hpc](https://github.com/ai-hpc).

##### Fixes

- Agent/session recovery: drop stale approval follow-ups after session rebind, remove drained reply-queue items by identity, recover stale main and visible replies, preserve Codex context-engine compaction ownership, lower the default compaction timeout to 180 seconds while respecting explicit configuration, and keep provider-failure terminal lifecycle state correct. ([#&#8203;85679](openclaw/openclaw#85679), [#&#8203;91450](openclaw/openclaw#91450), [#&#8203;91566](openclaw/openclaw#91566), [#&#8203;91840](openclaw/openclaw#91840), [#&#8203;91590](openclaw/openclaw#91590), [#&#8203;91361](openclaw/openclaw#91361), [#&#8203;91895](openclaw/openclaw#91895)) Thanks [@&#8203;openperf](https://github.com/openperf), [@&#8203;yetval](https://github.com/yetval), [@&#8203;joshavant](https://github.com/joshavant), [@&#8203;wangmiao0668000666](https://github.com/wangmiao0668000666), and [@&#8203;TurboTheTurtle](https://github.com/TurboTheTurtle).
- User-visible content boundaries: suppress Codex/Harmony protocol artifacts, neutralize browser and LanceDB memory media directives, redact transcript images, and preserve native `/compact` replies through source suppression. ([#&#8203;89151](openclaw/openclaw#89151), [#&#8203;91422](openclaw/openclaw#91422), [#&#8203;91425](openclaw/openclaw#91425), [#&#8203;91529](openclaw/openclaw#91529), [#&#8203;90212](openclaw/openclaw#90212)) Thanks [@&#8203;joelnishanth](https://github.com/joelnishanth), [@&#8203;pgondhi987](https://github.com/pgondhi987), [@&#8203;joshavant](https://github.com/joshavant), and [@&#8203;snowzlm](https://github.com/snowzlm).
- Channel delivery: keep WhatsApp captured replies attached to the successor controller after restart, retry Feishu rate limits, preserve Mattermost thread replies, canonicalize LINE webhook paths, restore Discord reply hydration and runtime timeout exports, and show OpenAI Realtime WebRTC assistant transcripts. ([#&#8203;85823](openclaw/openclaw#85823), [#&#8203;89659](openclaw/openclaw#89659), [#&#8203;91684](openclaw/openclaw#91684), [#&#8203;91649](openclaw/openclaw#91649), [#&#8203;90263](openclaw/openclaw#90263), [#&#8203;91686](openclaw/openclaw#91686), [#&#8203;90426](openclaw/openclaw#90426)) Thanks [@&#8203;itsuzef](https://github.com/itsuzef), [@&#8203;ladygege](https://github.com/ladygege), [@&#8203;jacobtomlinson](https://github.com/jacobtomlinson), [@&#8203;fuller-stack-dev](https://github.com/fuller-stack-dev), and [@&#8203;shushushv](https://github.com/shushushv).
- Cron: cancel active task runs cleanly, preserve terminal timeout/cancel state, and recover no-deliver tool warnings instead of silently losing the outcome. ([#&#8203;90666](openclaw/openclaw#90666), [#&#8203;90678](openclaw/openclaw#90678)) Thanks [@&#8203;ai-hpc](https://github.com/ai-hpc).
- Gateway/config/auth: share the approval runtime socket token, replace arrays explicitly in `config.patch`, skip the deleted-agent guard only for valid ACP harness sessions, surface headless LaunchAgent state, verify SQLite auth migration before cleanup, and arm QMD startup maintenance. ([#&#8203;87105](openclaw/openclaw#87105), [#&#8203;91551](openclaw/openclaw#91551), [#&#8203;91219](openclaw/openclaw#91219), [#&#8203;91614](openclaw/openclaw#91614), [#&#8203;91740](openclaw/openclaw#91740), [#&#8203;91978](openclaw/openclaw#91978)) Thanks [@&#8203;fuller-stack-dev](https://github.com/fuller-stack-dev) and [@&#8203;scotthuang](https://github.com/scotthuang).
- Providers/Codex: clarify quota errors, restore the Codex synthetic usage line, canonicalize Codex protocol assets, require API-key auth for realtime voice, normalize ACP model refs, preserve Gemma 4 `reasoning_content`, and avoid guardian review for local models. ([#&#8203;91390](openclaw/openclaw#91390), [#&#8203;91709](openclaw/openclaw#91709), [#&#8203;91507](openclaw/openclaw#91507), [#&#8203;91567](openclaw/openclaw#91567), [#&#8203;88630](openclaw/openclaw#88630), [#&#8203;91696](openclaw/openclaw#91696)) Thanks [@&#8203;hxy91819](https://github.com/hxy91819), [@&#8203;brokemac79](https://github.com/brokemac79), [@&#8203;RomneyDa](https://github.com/RomneyDa), [@&#8203;joshavant](https://github.com/joshavant), and [@&#8203;Coder-Wangyankun](https://github.com/Coder-Wangyankun).
- Updates/builds: recover package Gateway restarts after refresh failure, expose plugin convergence repair, fall back to Corepack in PATH-less pnpm environments, seed the correct Docker store packages, and keep ClawHub dry-run and publish paths reusable. ([#&#8203;91581](openclaw/openclaw#91581), [#&#8203;91599](openclaw/openclaw#91599), [#&#8203;91547](openclaw/openclaw#91547), [#&#8203;91591](openclaw/openclaw#91591)) Thanks [@&#8203;fuller-stack-dev](https://github.com/fuller-stack-dev), [@&#8203;sallyom](https://github.com/sallyom), and [@&#8203;Patrick-Erichsen](https://github.com/Patrick-Erichsen).
- UI: require explicit user intent before opening chat sessions and drain restored chat queues after session switches. ([#&#8203;91480](openclaw/openclaw#91480)) Thanks [@&#8203;TurboTheTurtle](https://github.com/TurboTheTurtle).
- Android: avoid the `dataSync` foreground-service type for persistent nodes. ([#&#8203;80082](openclaw/openclaw#80082)) Thanks [@&#8203;davelutztx](https://github.com/davelutztx).
- Native hooks: bound relay lifetimes so abandoned native hook connections cannot linger indefinitely. ([#&#8203;91550](openclaw/openclaw#91550)) Thanks [@&#8203;joshavant](https://github.com/joshavant).

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these updates again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMDEuMSIsInVwZGF0ZWRJblZlciI6IjQzLjEwMS4xIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJyZW5vdmF0ZS9jb250YWluZXIiLCJ0eXBlL3BhdGNoIl19-->

Reviewed-on: https://git.erwanleboucher.dev/eleboucher/homelab/pulls/1040
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

maintainer Maintainer-authored PR merge-risk: 🚨 compatibility 🚨 May break existing users, config, migrations, defaults, or upgrade paths. P1 High-priority user-facing bug, regression, or broken workflow. proof: sufficient ClawSweeper judged the real behavior proof convincing. rating: 🦞 diamond lobster Very strong PR readiness with only minor maintainer review expected. size: M status: 👀 ready for maintainer look ClawSweeper has no concrete contributor-facing blocker left for this PR.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant