Compare commits

..

3082 Commits

Author SHA1 Message Date
Vincent Koc
54429aa15d chore(plugin-sdk): refresh API baseline 2026-05-14 09:15:44 +08:00
Vincent Koc
b4bdd50c64 test(agents): fix live profile lint 2026-05-14 08:44:01 +08:00
Vincent Koc
690c521704 fix(plugin-sdk): export codex runtime helpers 2026-05-14 08:43:35 +08:00
Peter Steinberger
f3361dc928 test(agents): surface live OpenAI replay auth failures 2026-05-14 01:36:56 +01:00
Val Alexander
52370c5998 feat(ui): add browser-local Control UI text size setting
Adds a bounded browser-local Control UI text size setting in Appearance and Quick Settings, persists it in UiSettings, and applies CSS text-scale variables across chat text, composer input, sidebars, and tool cards while preserving mobile Safari input zoom safety.

Fixes #8547.
Thanks @BunsDev.
2026-05-13 19:18:05 -05:00
Peter Steinberger
0b55317494 test(plugins): isolate capability provider runtime mocks 2026-05-14 01:07:57 +01:00
Peter Steinberger
3225ec43c8 test(plugin-install): align npm peer scan expectations 2026-05-14 00:51:09 +01:00
Peter Steinberger
23446a248b ci(release): fail full validation on child failure 2026-05-14 00:46:22 +01:00
Eduardo Piva
9431d18aaf fix(sessions): classify spawn-child sessions correctly
Classify ACP spawn-child sessions via persisted spawnedBy metadata and share the session kind classifier across sessions/status output.

Verified with Azure Crabbox seeded ACP session-store proof, targeted session/status tests, touched-file lint, build, and green PR CI.
2026-05-13 16:39:04 -07:00
pashpashpash
74860e93fd fix(codex): preserve user home for app-server launches 2026-05-13 16:37:03 -07:00
Peter Steinberger
8046b5e462 docs: add plugin update changelog (#81512) (thanks @JARVIS-Glasses) 2026-05-14 00:25:52 +01:00
JARVIS-Glasses
5214f16e29 fix(update): clear stale plugin refs after failed updates 2026-05-14 00:25:52 +01:00
Vincent Koc
b5c3379097 fix(telegram): clear progress draft before answer 2026-05-14 07:19:00 +08:00
Peter Steinberger
dc7fab4dc5 perf: cache pi model discovery 2026-05-14 00:13:29 +01:00
Peter Steinberger
b10b946b12 docs(clawhub): remove missing security route 2026-05-13 23:57:05 +01:00
이민재
72f50dd127 fix(slack): normalize read timestamp bounds (#81338)
* fix(slack): normalize read timestamp bounds

* fix(slack): document read timestamp bounds fix

* fix(slack): simplify timestamp bounds validation

---------

Co-authored-by: honor2030 <19909783+honor2030@users.noreply.github.com>
Co-authored-by: Altay <altay@hey.com>
2026-05-14 01:52:55 +03:00
Vincent Koc
d08f68dee7 test(e2e): cover root-managed VPS upgrades 2026-05-14 06:50:58 +08:00
Peter Steinberger
25dd30d656 build(whatsapp): keep audio decoder dependency 2026-05-13 23:48:05 +01:00
Peter Steinberger
c654f1f811 test(whatsapp): allow audio runtime dependency 2026-05-13 23:47:03 +01:00
Josh Lehman
6395117142 fix: restore Codex cron automation compatibility (#81510)
* fix: restore Codex cron automation compatibility

* fix: document Codex cron automation restore
2026-05-13 15:34:31 -07:00
Shakker
26da4edbe1 docs: add acp request error changelog 2026-05-13 22:39:24 +01:00
vyctorbrzezowski
c5071a8061 fix(acp): preserve RequestError details 2026-05-13 22:39:24 +01:00
Eduardo Piva
207fb9951d fix(sessions): display ACP runtime sentinel for ACP sessions (#79543)
Display the ACP runtime sentinel for ACP control-plane session rows in openclaw sessions output, while preserving configured model/provider display for direct sessions.

Verified with focused sessions tests, touched-file oxlint, check:test-types, Crabbox after-fix proof, and exact-head GitHub CI.
2026-05-13 14:26:51 -07:00
B.K.
b8ea6097d9 fix(cli): report stale plugin doctor config (#81515)
Merged via squash.

Prepared head SHA: 23bc849abd
Co-authored-by: BKF-Gitty <263413630+BKF-Gitty@users.noreply.github.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-14 00:03:54 +03:00
vyctorbrzezowski
4d2e708726 fix(memory-lancedb): support cjk auto-capture triggers 2026-05-13 21:49:22 +01:00
Sarah Fortune
6602884b06 test(codex-migrate): stub clack log in migrate mock 2026-05-13 13:29:23 -07:00
Sarah Fortune
b85259c443 test(codex-migrate): cover new preview/result format 2026-05-13 13:29:23 -07:00
Sarah Fortune
49adf206e8 fix(codex-migrate): use String#replace in display name 2026-05-13 13:29:23 -07:00
Sarah Fortune
d7d1fba74b ux(codex-migrate): polish preview/result output
Restructure the migrate codex CLI output:

- Split into separate Before (preview) and After (result) messages
  so each can be tuned independently. Both render through clack's
  log.message so they pick up the standard '|' gutter.
- Group items by kind (Skills, Plugins, Memory, Secrets, Archive,
  Manual review, Other) instead of one flat list. Hide config items
  from display and exclude them from the summary count.
- Drop the internal kind/action tag (e.g. 'manual/manual'), strip
  '<kind>:' id prefixes and trailing ':N' disambiguators, and use
  '•' for bullets.
- Mute parenthetical action text.
- In result mode: replace status text with emoji ( migrated,
   error, ⏭️ skipped, ⚠️ conflict), show '(Migrated)' on success,
  show humanized failure reasons for known codes (plugin_missing,
  marketplace_missing, etc.), say '(Skipped)' for user-deselected
  skill/plugin items but keep the real message on manual-review
  skips. Drop warnings from the result message.
- In preview mode: omit the 'Next' section and move warnings to
  the bottom. Use generic action descriptions ('Copy Codex skill
  into OpenClaw', 'Install Codex plugin into OpenClaw').
- Drop the redundant 'Codex cached plugin bundles remain
  manual-review only.' warning — covered by the source-installed
  warning above it.
2026-05-13 13:29:23 -07:00
Peter Steinberger
cf571c1b58 fix(plugins): scope install scanner to runtime graph 2026-05-13 21:22:37 +01:00
dwc1997
cffae53b43 fix(security): classify broad Windows SIDs as world principals
Carry Windows ACL world-principal classification through @openclaw/fs-safe@0.2.2 so Anonymous Logon, Guests, Interactive, Network, and Local SID/principal variants are treated as world-equivalent in filesystem audit findings.

Also add regression coverage, changelog coverage, a narrow lint cleanup, and a UI test isolation fix needed by the current CI shard.

Co-authored-by: dwc <118101032587@njust.edu.cn>
2026-05-13 15:19:02 -05:00
Kevin Lin
6a23e26a27 docs: consolidate plugin install docs (#81167)
* docs: consolidate plugin install docs

* docs: align plugin getting started page

* snap

* docs: add reusable audit viewer tooling

* docs: add audit viewer doc mode

* docs: add audit viewer diff mode

* docs: strengthen plugin docs audit coverage

* docs: preserve plugin scan order reference

* docs: resolve plugin audit coverage gaps

* docs: strengthen audit line mappings

* docs: narrow plugin docs refactor scope

* docs: preserve plugin audit facts

* docs: keep audit skill local

* docs: remove audit skill from pr

* fix: satisfy plugin scan lint

* docs: address plugin docs review
2026-05-13 13:17:39 -07:00
Peter Steinberger
308b39efd5 docs: document real behavior proof fields 2026-05-13 21:08:17 +01:00
Peter Steinberger
f30c9eff76 docs: refresh clawdtributor update guidance 2026-05-13 21:07:49 +01:00
Peter Steinberger
7c4f607572 docs: refresh config baseline hash 2026-05-13 20:59:11 +01:00
Peter Steinberger
ebd829cffd test: add release qa docker lanes 2026-05-13 20:57:44 +01:00
edge_kase
8237d165e2 feat(acp): add backend provider failover for UNAVAILABLE errors (#69542)
Merged via squash.

Prepared head SHA: 1d4c929ad7
Co-authored-by: kaseonedge <15183881+kaseonedge@users.noreply.github.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-13 22:52:14 +03:00
狼哥
609187f5f6 fix(security): classify dangerous Windows sandbox binds first (#63074)
Adds Windows USERPROFILE to the sandbox blocked home roots so credential binds are denied even when HOME points at a different shell home.

Verified:
- node scripts/test-projects.mjs src/agents/sandbox/validate-sandbox-security.test.ts
- node scripts/test-projects.mjs src/agents/sandbox/bind-spec.test.ts src/agents/sandbox/host-paths.test.ts src/agents/sandbox/validate-sandbox-security.test.ts
- git diff --check HEAD^ HEAD

Co-authored-by: luoyanglang <hanwanlonga@gmail.com>
2026-05-13 14:42:45 -05:00
AI-HUB
b7d3b74f1c fix(ui): order live chat items by timestamp (#81016)
* fix(ui): order live chat items by timestamp

* fix(ui): stabilize chat timestamp sorting

* test: refresh core lint fixtures

* test: refresh current main guard fixtures

* test: refresh codex prompt snapshots

* test(matrix): keep runtime helper local

---------

Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-13 20:30:44 +01:00
Peter Steinberger
439e396262 fix(plugins): allow benign LanceDB runtime shims 2026-05-13 20:24:46 +01:00
Peter Steinberger
1f59031373 test(matrix): keep runtime media mock local 2026-05-13 20:07:10 +01:00
Peter Steinberger
8a406528b4 fix(codex): project user MCP servers into app-server threads
Fixes #80814.

Co-authored-by: kinjitakabe <273844887+kinjitakabe@users.noreply.github.com>
2026-05-13 20:07:10 +01:00
sallyom
d4484158d9 fix: avoid broad provider env marker inference 2026-05-13 15:02:56 -04:00
Josh Lehman
b55d9fa466 fix(codex): rotate incompatible context-engine threads (#81223)
* fix(codex): rotate incompatible context-engine threads

* fix(codex): tighten context-engine sidecar policy

* fix: type context-engine binding policy config

---------

Co-authored-by: Josh Lehman <phaedrus@Mac.hsd1.ca.comcast.net>
2026-05-13 11:50:03 -07:00
Shakker
433bafa55b fix: avoid bodyless media response buffering 2026-05-13 19:38:26 +01:00
Shakker
af6f75f78c docs: credit media fetch retry author 2026-05-13 19:38:26 +01:00
vyctorbrzezowski
e9a9434842 fix(media): retry transient remote media fetches 2026-05-13 19:38:26 +01:00
Peter Steinberger
58bfefbad3 test: add release user journey docker lane 2026-05-13 19:17:57 +01:00
homer-byte
c3e5d85ce1 fix(imessage): avoid visible media placeholder text (#81209)
Keep media-only iMessage sends from delivering visible <media:image> text while preserving a non-visible echo key for self-echo dedupe. Thanks @homer-byte.
2026-05-13 09:03:05 -07:00
Ayaan Zaidi
ddd79e51ba docs(changelog): note agent session bootstrap 2026-05-13 21:29:21 +05:30
Ayaan Zaidi
652af36d17 test(gateway): prove agent session bootstrap 2026-05-13 21:29:21 +05:30
Ayaan Zaidi
2d3f3de235 fix(gateway): bootstrap agent sessions before send 2026-05-13 21:29:21 +05:30
homer-byte
1d6e5f7a3e fix(imessage): make inbound image attachments readable by agents (#78580)
Stage native iMessage inbound attachments into managed media and convert HEIC/HEIF images to JPEG before dispatch. Thanks @homer-byte.
2026-05-13 08:35:52 -07:00
Peter Steinberger
58591c37a4 fix(tui): emit v4 embedded chat deltas
(cherry picked from commit a6d878376b)
2026-05-13 16:28:12 +01:00
Peter Steinberger
64ba5e2ae3 docs: add inline comment guidance 2026-05-13 16:13:49 +01:00
Peter Steinberger
f441a569ea docs: update changelog for OpenAI OAuth prompt (#81301) (thanks @rubencu) 2026-05-13 16:13:35 +01:00
Rubén Cuevas
83549774cd fix(openai): clarify remote Codex OAuth prompt 2026-05-13 16:13:35 +01:00
Peter Steinberger
48fb4bade8 docs: credit Telegram group fix contributor (#81030) 2026-05-13 16:09:13 +01:00
kinjitakabe
ab719c2f82 fix(telegram/groups): treat empty accounts.<id>.groups: {} as unspecified in single-account setups
`mergeTelegramAccountConfig` and the generic `resolveChannelGroups` both used
`accountGroups ?? channelConfig.groups` to fall back to root group allowlists,
which only catches the `undefined` case. An explicit empty `{}` survives
nullish coalescing and overrides the root allowlist with an empty allowlist,
which then pairs with the default `groupPolicy: "allowlist"` to silently
deny every group update — the symptom reported in #79427.

Treat an explicit empty `{}` the same as undefined for fallback purposes in
single-account setups (one or zero configured accounts). Multi-account setups
keep current semantics so per-account explicit-empty groups still scope
disable a single account without affecting its siblings. The explicit way to
block all groups for any account remains `groupPolicy: "disabled"`, which
this PR does not touch.

Fixes #79427.
2026-05-13 16:09:13 +01:00
Peter Steinberger
d540512d00 fix(gateway): satisfy node registry lint 2026-05-13 16:06:37 +01:00
Peter Steinberger
babd48b6cd docs(changelog): note v4 chat delta protocol 2026-05-13 16:06:37 +01:00
Peter Steinberger
a6497b1759 fix(gateway): avoid duplicate v4 deltas 2026-05-13 16:06:37 +01:00
Peter Steinberger
150bebcd0c fix(gateway): require v4 chat deltas 2026-05-13 16:06:37 +01:00
samzong
63724ddcfd fix(sdk): preserve replayed chat snapshots 2026-05-13 16:06:37 +01:00
samzong
10315ce215 fix(gateway): add incremental chat delta payloads 2026-05-13 16:06:37 +01:00
Vincent Koc
2a67a7f65e fix(plugins): prune managed peers on uninstall 2026-05-13 22:53:58 +08:00
Peter Steinberger
0513b285ef docs: update crabbox skill guidance 2026-05-13 15:46:50 +01:00
Pavan Kumar Gondhi
418d7afb33 gateway: pass Talk session scope to resolver [AI] (#81379)
* fix: pass talk session visibility scope

* addressing review-skill

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing claude review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 20:09:03 +05:30
Peter Steinberger
4d8aec8210 fix(plugins): attribute runtime config deprecations (#81425) (thanks @BKF-Gitty)
Co-authored-by: BKF-Gitty <bandark@mac.com>
2026-05-13 15:37:43 +01:00
Altay
a40499b21a fix(test): isolate auth profile secrets in test state (#81393)
Merged via squash.

Prepared head SHA: fde8787cb7
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-13 17:34:45 +03:00
Peter Steinberger
210c7c1b85 fix: preserve SGLang reasoning replay (#81091) 2026-05-13 15:28:07 +01:00
AI-HUB
51cd3cddeb fix(sglang): preserve reasoning replay history 2026-05-13 15:28:07 +01:00
Shakker
402b0df3b6 fix: preserve owned plugin dependencies during peer repair 2026-05-13 15:26:40 +01:00
Shakker
f4cb20300f fix: harden managed plugin peer recovery 2026-05-13 15:26:40 +01:00
Shakker
6e5042cd62 fix: avoid rescanning repaired plugin peers 2026-05-13 15:26:40 +01:00
Shakker
18ca285ed6 fix: preserve managed plugin peer dependencies 2026-05-13 15:26:40 +01:00
Peter Steinberger
1c28e4a0bb test: add docker live subagent announce proof 2026-05-13 15:21:37 +01:00
Peter Steinberger
0b8ee4616d fix(github-copilot): support Gemini image understanding
Fixes Copilot image understanding by exchanging OAuth tokens for Copilot API tokens, routing Copilot Gemini image requests through Chat Completions, and sending the prompt in user content with Copilot vision headers.

Real behavior proof:
- Old Responses route with real Copilot key reproduced `400 model gemini-3.1-pro-preview does not support Responses API`.
- Fixed route with the same real Copilot key returned `Cat`.
- Final CLI live smoke returned `ok: true` and `text: Cat` for `github-copilot/gemini-3.1-pro-preview`.

Verification:
- pnpm test src/media-understanding/image.test.ts extensions/github-copilot/models.test.ts extensions/github-copilot/stream.test.ts src/agents/pi-hooks/compaction-safeguard.test.ts -- --reporter=verbose
- pnpm check:changed via Blacksmith Testbox tbx_01krgt56pqmft8txekt017wke6, Actions run https://github.com/openclaw/openclaw/actions/runs/25803926150, exit 0.

Refs #80393, #80442.

Co-authored-by: Yang Haoyu <150496764+afunnyhy@users.noreply.github.com>
2026-05-13 15:20:27 +01:00
Peter Steinberger
6160e7a411 fix(gateway): hide unapproved node surfaces
Co-authored-by: samzong <samzong.lu@gmail.com>
2026-05-13 15:13:44 +01:00
Peter Steinberger
53d007bc87 refactor(media): centralize bounded remote downloads
Co-authored-by: samzong <samzong.lu@gmail.com>
2026-05-13 15:04:49 +01:00
Peter Steinberger
218156447c docs: add config mutation changelog 2026-05-13 15:00:07 +01:00
Peter Steinberger
ab3d61813a fix: rebase synthetic browser profiles 2026-05-13 15:00:07 +01:00
Peter Steinberger
23344fdb61 fix: avoid stale config mutation rebases 2026-05-13 15:00:07 +01:00
Peter Steinberger
756379b11d refactor: centralize config mutations 2026-05-13 15:00:07 +01:00
Peter Steinberger
c4c0b65b80 fix: rebase browser profile mutations 2026-05-13 15:00:07 +01:00
Peter Steinberger
ec998d1e95 fix: clean current dependency checks 2026-05-13 15:00:07 +01:00
Peter Steinberger
07c5e2465b fix: handle rebased config mutation races 2026-05-13 15:00:07 +01:00
Peter Steinberger
743cbc2f13 fix: mark slack channel system events untrusted 2026-05-13 15:00:07 +01:00
Peter Steinberger
66cce180c3 test: align config mutation mocks 2026-05-13 15:00:07 +01:00
Peter Steinberger
f3327ac30b fix: clean production config mutation checks 2026-05-13 15:00:07 +01:00
Peter Steinberger
2fe39ce949 refactor: rebase runtime config writes 2026-05-13 15:00:07 +01:00
Peter Steinberger
fb3aa155be fix: remove redundant config clone casts 2026-05-13 15:00:07 +01:00
Peter Steinberger
2e983e47df fix: serialize config mutation writes 2026-05-13 15:00:07 +01:00
Peter Steinberger
488a3d8e52 fix(ci): refresh stale metadata ownership 2026-05-13 14:59:47 +01:00
Peter Steinberger
5ac6b600de docs(channels): document bot loop protection 2026-05-13 14:59:47 +01:00
Peter Steinberger
4785a073d6 feat(channels): add generic bot loop protection 2026-05-13 14:59:47 +01:00
Peter Steinberger
d00e9eba65 docs: add ds4 provider guide 2026-05-13 14:45:34 +01:00
Peter Steinberger
96c0309db9 test: fix queue settings session fixtures 2026-05-13 14:24:45 +01:00
Peter Steinberger
714f62f976 test: add live subagent steering proof 2026-05-13 14:24:45 +01:00
Peter Steinberger
3cef9a65d3 fix: use in-process subagent announce handoff 2026-05-13 14:24:45 +01:00
stain lu
f1381b5312 fix(telegram): limit startup probes (#80986)
## Summary

- Limit Telegram startup `getMe` probes to two concurrent accounts.
- Add regression coverage for queued startup and queued abort behavior.
- Document the multi-account startup bound and add changelog credit.

## Verification

- `pnpm exec oxfmt --check --threads=1 CHANGELOG.md docs/channels/telegram.md extensions/telegram/src/channel.ts extensions/telegram/src/channel.gateway.test.ts extensions/telegram/src/startup-probe-limiter.ts`
- `node scripts/format-docs.mjs --check docs/channels/telegram.md`
- `git diff --check HEAD~1..HEAD`
- `env OPENCLAW_TEST_HEAVY_CHECK_LOCK_HELD=1 OPENCLAW_VITEST_MAX_WORKERS=1 pnpm --config.manage-package-manager-versions=false test extensions/telegram/src/channel.gateway.test.ts src/gateway/server-channels.test.ts`
- `env OPENCLAW_TSGO_HEAVY_CHECK_LOCK_HELD=1 pnpm --config.manage-package-manager-versions=false run tsgo:extensions`
- `env OPENCLAW_TSGO_HEAVY_CHECK_LOCK_HELD=1 pnpm --config.manage-package-manager-versions=false run tsgo:extensions:test`
- GitHub CI mostly green on `2d389e1010742efa884eacea520afd588d0b898f`; `check-test-types` red in unrelated `src/auto-reply/reply/queue/settings.test.ts` outside this PR's diff.

Co-authored-by: stainlu <stainlu@newtype-ai.org>
2026-05-13 14:23:32 +01:00
Pavan Kumar Gondhi
b17e77a22b Require approval for setup-code device pairing [AI] (#81292)
* fix: require approval for setup-code bootstrap pairing

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 18:48:44 +05:30
Peter Steinberger
05bef5db20 docs: update changelog for docker setup path fix (#81105) 2026-05-13 14:13:57 +01:00
brokemac79
3cf296185f fix(docker): pin setup cli container paths 2026-05-13 14:13:57 +01:00
Jason
70df2b8fe2 feat: steer mid-turn prompts by default (#77023)
Summary:
- Default active-run queueing to steer while preserving explicit followup/collect modes.
- Keep `/steer` fallback behavior and migrate retired queue steering config.
- Await Codex app-server steering acceptance so rejected/aborted steering can fall back safely.
- Route active subagent announcements through intentional acceptance-aware steering, with legacy queue helpers deprecated for delivery decisions.

Verification:
- git diff --check
- rg -n "^(<<<<<<<|=======|>>>>>>>|\|\|\|\|\|\|\|)" CHANGELOG.md docs src extensions || true
- pnpm test src/agents/subagent-announce-dispatch.test.ts src/agents/subagent-announce-delivery.test.ts src/agents/pi-embedded-runner/runs.test.ts src/agents/subagent-announce.format.e2e.test.ts src/agents/subagent-announce.test.ts
- pnpm test src/auto-reply/reply/commands-steer.test.ts src/auto-reply/reply/queue/settings.test.ts src/auto-reply/reply/queue-policy.test.ts src/auto-reply/reply/agent-runner.runreplyagent.e2e.test.ts src/auto-reply/reply/get-reply-run.media-only.test.ts extensions/codex/src/app-server/run-attempt.test.ts -- -t "queued steering|explicit all-mode steering|flushes pending default queued steering|rejects queued steering|resolveActiveRunQueueAction|resolveQueueSettings|handleSteerCommand"

Co-authored-by: fuller-stack-dev <263060202+fuller-stack-dev@users.noreply.github.com>
2026-05-13 14:00:11 +01:00
Peter Steinberger
1c5c72ea24 docs: update changelog for chat action overlap (#81244) 2026-05-13 13:54:30 +01:00
JARVIS-Glasses
3b7181a38b fix(ui): prevent chat actions overlapping replies 2026-05-13 13:54:06 +01:00
Peter Steinberger
4e34c1aa47 fix(channel): refresh wecom onboarding install (#80390) (thanks @brokemac79) 2026-05-13 13:52:05 +01:00
brokemac79
f2cbe9ecc5 fix(channel): refresh wecom onboarding install 2026-05-13 13:52:05 +01:00
Peter Steinberger
dfead3198d ci: make testbox session shutdown non-blocking 2026-05-13 13:50:44 +01:00
Peter Steinberger
852f88f1e7 ci: guard optional website installer file 2026-05-13 13:35:54 +01:00
Peter Steinberger
694ca50e97 Revert "refactor: move runtime state to SQLite"
This reverts commit f91de52f0d.
2026-05-13 13:33:38 +01:00
Peter Steinberger
3de5979bdc ci: fix website installer sync git add 2026-05-13 13:31:39 +01:00
Peter Steinberger
d1fdd6e186 fix(installer): honor git install versions 2026-05-13 13:17:29 +01:00
Peter Steinberger
f91de52f0d refactor: move runtime state to SQLite
* refactor: remove stale file-backed shims

* fix: harden sqlite state ci boundaries

* refactor: store matrix idb snapshots in sqlite

* fix: satisfy rebased CI guardrails

* refactor: store current conversation bindings in sqlite table

* refactor: store tui last sessions in sqlite table

* refactor: reset sqlite schema history

* refactor: drop unshipped sqlite table migration

* refactor: remove plugin index file rollback

* refactor: drop unshipped sqlite sidecar migrations

* refactor: remove runtime commitments kv migration

* refactor: preserve kysely sync result types

* refactor: drop unshipped sqlite schema migration table

* test: keep session usage coverage sqlite-backed

* refactor: keep sqlite migration doctor-only

* refactor: isolate device legacy imports

* refactor: isolate push voicewake legacy imports

* refactor: isolate remaining runtime legacy imports

* refactor: tighten sqlite migration guardrails

* test: cover sqlite persisted enum parsing

* refactor: isolate legacy update and tui imports

* refactor: tighten sqlite state ownership

* refactor: move legacy imports behind doctor

* refactor: remove legacy session row lookup

* refactor: canonicalize memory transcript locators

* refactor: drop transcript path scope fallbacks

* refactor: drop runtime legacy session delivery pruning

* refactor: store tts prefs only in sqlite

* refactor: remove cron store path runtime

* refactor: use cron sqlite store keys

* refactor: rename telegram message cache scope

* refactor: read memory dreaming status from sqlite

* refactor: rename cron status store key

* refactor: stop remembering transcript file paths

* test: use sqlite locators in agent fixtures

* refactor: remove file-shaped commitments and cron store surfaces

* refactor: keep compaction transcript handles out of session rows

* refactor: derive transcript handles from session identity

* refactor: derive runtime transcript handles

* refactor: remove gateway session locator reads

* refactor: remove transcript locator from session rows

* refactor: store raw stream diagnostics in sqlite

* refactor: remove file-shaped transcript rotation

* refactor: hide legacy trajectory paths from runtime

* refactor: remove runtime transcript file bridges

* refactor: repair database-first rebase fallout

* refactor: align tests with database-first state

* refactor: remove transcript file handoffs

* refactor: sync post-compaction memory by transcript scope

* refactor: run codex app-server sessions by id

* refactor: bind codex runtime state by session id

* refactor: pass memory transcripts by sqlite scope

* refactor: remove transcript locator cleanup leftovers

* test: remove stale transcript file fixtures

* refactor: remove transcript locator test helper

* test: make cron sqlite keys explicit

* test: remove cron runtime store paths

* test: remove stale session file fixtures

* test: use sqlite cron keys in diagnostics

* refactor: remove runtime delivery queue backfill

* test: drop fake export session file mocks

* refactor: rename acp session read failure flag

* refactor: rename acp row session key

* refactor: remove session store test seams

* refactor: move legacy session parser tests to doctor

* refactor: reindex managed memory in place

* refactor: drop stale session store wording

* refactor: rename session row helpers

* refactor: rename sqlite session entry modules

* refactor: remove transcript locator leftovers

* refactor: trim file-era audit wording

* refactor: clean managed media through sqlite

* fix: prefer explicit agent for exports

* fix: use prepared agent for session resets

* fix: canonicalize legacy codex binding import

* test: rename state cleanup helper

* docs: align backup docs with sqlite state

* refactor: drop legacy Pi usage auth fallback

* refactor: move legacy auth profile imports to doctor

* refactor: keep Pi model discovery auth in memory

* refactor: remove MSTeams legacy learning key fallback

* refactor: store model catalog config in sqlite

* refactor: use sqlite model catalog at runtime

* refactor: remove model json compatibility aliases

* refactor: store auth profiles in sqlite

* refactor: seed copied auth profiles in sqlite

* refactor: make auth profile runtime sqlite-addressed

* refactor: migrate hermes secrets into sqlite auth store

* refactor: move plugin install config migration to doctor

* refactor: rename plugin index audit checks

* test: drop auth file assumptions

* test: remove legacy transcript file assertions

* refactor: drop legacy cli session aliases

* refactor: store skill uploads in sqlite

* refactor: keep subagent attachments in sqlite vfs

* refactor: drop subagent attachment cleanup state

* refactor: move legacy session aliases to doctor

* refactor: require node 24 for sqlite state runtime

* refactor: move provider caches into sqlite state

* fix: harden virtual agent filesystem

* refactor: enforce database-first runtime state

* refactor: rename compaction transcript rotation setting

* test: clean sqlite refactor test types

* refactor: consolidate sqlite runtime state

* refactor: model session conversations in sqlite

* refactor: stop deriving cron delivery from session keys

* refactor: stop classifying sessions from key shape

* refactor: hydrate announce targets from typed delivery

* refactor: route heartbeat delivery from typed sqlite context

* refactor: tighten typed sqlite session routing

* refactor: remove session origin routing shadow

* refactor: drop session origin shadow fixtures

* perf: query sqlite vfs paths by prefix

* refactor: use typed conversation metadata for sessions

* refactor: prefer typed session routing metadata

* refactor: require typed session routing metadata

* refactor: resolve group tool policy from typed sessions

* refactor: delete dead session thread info bridge

* Show Codex subscription reset times in channel errors (#80456)

* feat(plugin-sdk): consolidate session workflow APIs

* fix(agents): allow read-only agent mount reads

* [codex] refresh plugin regression fixtures

* fix(agents): restore compaction gateway logs

* test: tighten gateway startup assertions

* Redact persisted secret-shaped payloads [AI] (#79006)

* test: tighten device pair notify assertions

* test: tighten hermes secret assertions

* test: assert matrix client error shapes

* test: assert config compat warnings

* fix(heartbeat): remap cron-run exec events to session keys (#80214)

* fix(codex): route btw through native side threads

* fix(auth): accept friendly OpenAI order for Codex profiles

* fix(codex): rotate auth profiles inside harness

* fix: keep browser status page probe within timeout

* test: assert agents add outputs

* test: pin cron read status

* fix(agents): avoid Pi resource discovery stalls

Co-authored-by: dataCenter430 <titan032000@gmail.com>

* fix: retire timed-out codex app-server clients

* test: tighten qa lab runtime assertions

* test: check security fix outputs

* test: verify extension runtime messages

* feat(wake): expose typed sessionKey on wake protocol + system event CLI

* fix(gateway): await session_end during shutdown drain and track channel + compaction lifecycle paths (#57790)

* test: guard talk consult call helper

* fix(codex): scale context engine projection (#80761)

* fix(codex): scale context engine projection

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* chore: align Codex projection changelog

* chore: realign Codex projection changelog

* fix: isolate Codex projection patch

---------

Co-authored-by: Eva (agent) <eva+agent-78055@100yen.org>
Co-authored-by: Josh Lehman <josh@martian.engineering>

* refactor: move agent runtime state toward piless

* refactor: remove cron session reaper

* refactor: move session management to sqlite

* refactor: finish database-first state migration

* chore: refresh generated sqlite db types

* refactor: remove stale file-backed shims

* test: harden kysely type coverage

# Conflicts:
#	.agents/skills/kysely-database-access/SKILL.md
#	src/infra/kysely-sync.types.test.ts
#	src/proxy-capture/store.sqlite.test.ts
#	src/state/openclaw-agent-db.test.ts
#	src/state/openclaw-state-db.test.ts

* refactor: remove cron store path runtime

* refactor: keep compaction transcript handles out of session rows

* refactor: derive embedded transcripts from sqlite identity

* refactor: remove embedded transcript locator handoff

* refactor: remove runtime transcript file bridges

* refactor: remove transcript file handoffs

* refactor: remove MSTeams legacy learning key fallback

* refactor: store model catalog config in sqlite

* refactor: use sqlite model catalog at runtime

# Conflicts:
#	docs/cli/secrets.md
#	docs/gateway/authentication.md
#	docs/gateway/secrets.md

* fix: keep oauth sibling sync sqlite-local

# Conflicts:
#	src/commands/onboard-auth.test.ts

* refactor: remove task session store maintenance

# Conflicts:
#	src/commands/tasks.ts

* refactor: keep diagnostics in state sqlite

* refactor: enforce database-first runtime state

* refactor: consolidate sqlite runtime state

* Show Codex subscription reset times in channel errors (#80456)

* fix(codex): refresh subscription limit resets

* fix(codex): format reset times for channels

* Update CHANGELOG with latest changes and fixes

Updated CHANGELOG with recent fixes and improvements.

* fix(codex): keep command load failures on codex surface

* fix(codex): format account rate limits as rows

* fix(codex): summarize account limits as usage status

* fix(codex): simplify account limit status

* test: tighten subagent announce queue assertion

* test: tighten session delete lifecycle assertions

* test: tighten cron ops assertions

* fix: track cron execution milestones

* test: tighten hermes secret assertions

* test: assert matrix sync store payloads

* test: assert config compat warnings

* fix(codex): align btw side thread semantics

* fix(codex): honor codex fallback blocking

* fix(agents): avoid Pi resource discovery stalls

* test: tighten codex event assertions

* test: tighten cron assertions

* Fix Codex app-server OAuth harness auth

* refactor: move agent runtime state toward piless

* refactor: move device and push state to sqlite

* refactor: move runtime json state imports to doctor

* refactor: finish database-first state migration

* chore: refresh generated sqlite db types

* refactor: clarify cron sqlite store keys

* refactor: remove stale file-backed shims

* refactor: bind codex runtime state by session id

* test: expect sqlite trajectory branch export

* refactor: rename session row helpers

* fix: keep legacy device identity import in doctor

* refactor: enforce database-first runtime state

* refactor: consolidate sqlite runtime state

* build: align pi contract wrappers

* chore: repair database-first rebase

* refactor: remove session file test contracts

* test: update gateway session expectations

* refactor: stop routing from session compatibility shadows

* refactor: stop persisting session route shadows

* refactor: use typed delivery context in clients

* refactor: stop echoing session route shadows

* refactor: repair embedded runner rebase imports

# Conflicts:
#	src/agents/pi-embedded-runner/run/attempt.tool-call-argument-repair.ts

* refactor: align pi contract imports

* refactor: satisfy kysely sync helper guard

* refactor: remove file transcript bridge remnants

* refactor: remove session locator compatibility

* refactor: remove session file test contracts

* refactor: keep rebase database-first clean

* refactor: remove session file assumptions from e2e

* docs: clarify database-first goal state

* test: remove legacy store markers from sqlite runtime tests

* refactor: remove legacy store assumptions from runtime seams

* refactor: align sqlite runtime helper seams

* test: update memory recall sqlite audit mock

* refactor: align database-first runtime type seams

* test: clarify doctor cron legacy store names

* fix: preserve sqlite session route projections

* test: fix copilot token cache test syntax

* docs: update database-first proof status

* test: align database-first test fixtures

* docs: update database-first proof status

* refactor: clean extension database-first drift

* test: align agent session route proof

* test: clarify doctor legacy path fixtures

* chore: clean database-first changed checks

* chore: repair database-first rebase markers

* build: allow baileys git subdependency

* chore: repair exp-vfs rebase drift

* chore: finish exp-vfs rebase cleanup

* chore: satisfy rebase lint drift

* chore: fix qqbot rebase type seam

* chore: fix rebase drift leftovers

* fix: keep auth profile oauth secrets out of sqlite

* fix: repair rebase drift tests

* test: stabilize pairing request ordering

* test: use source manifests in plugin contract checks

* fix: restore gateway session metadata after rebase

* fix: repair database-first rebase drift

* fix: clean up database-first rebase fallout

* test: stabilize line quick reply receipt time

* fix: repair extension rebase drift

* test: keep transcript redaction tests sqlite-backed

* fix: carry injected transcript redaction through sqlite

* chore: clean database branch rebase residue

* fix: repair database branch CI drift

* fix: repair database branch CI guard drift

* fix: stabilize oauth tls preflight test

* test: align database branch fast guards

* test: repair build artifact boundary guards

* chore: clean changelog rebase markers

---------

Co-authored-by: pashpashpash <nik@vault77.ai>
Co-authored-by: Eva <eva@100yen.org>
Co-authored-by: stainlu <stainlu@newtype-ai.org>
Co-authored-by: Jason Zhou <jason.zhou.design@gmail.com>
Co-authored-by: Ruben Cuevas <hi@rubencu.com>
Co-authored-by: Pavan Kumar Gondhi <pavangondhi@gmail.com>
Co-authored-by: Shakker <shakkerdroid@gmail.com>
Co-authored-by: Kaspre <36520309+Kaspre@users.noreply.github.com>
Co-authored-by: dataCenter430 <titan032000@gmail.com>
Co-authored-by: Kaspre <kaspre@gmail.com>
Co-authored-by: pandadev66 <nova.full.stack@outlook.com>
Co-authored-by: Eva <admin@100yen.org>
Co-authored-by: Eva (agent) <eva+agent-78055@100yen.org>
Co-authored-by: Josh Lehman <josh@martian.engineering>
Co-authored-by: jeffjhunter <support@aipersonamethod.com>
2026-05-13 13:15:12 +01:00
Peter Steinberger
0a9f7afb66 fix(agents): surface memory-flush errors safely
Refs #80755.
Replaces #80884.

Verification:
- pnpm test src/plugins/contracts/extension-runtime-dependencies.contract.test.ts src/auto-reply/reply/agent-runner-memory.test.ts
- pnpm changed:lanes --json
- git diff --check
- node scripts/run-oxlint.mjs --tsconfig config/tsconfig/oxlint.scripts.json scripts/generate-plugin-inventory-doc.mjs scripts/deadcode-unused-files.allowlist.mjs
- pnpm deadcode:unused-files
- pnpm check:changed via Blacksmith Testbox tbx_01krgjhyx965k8ew4qg9nxq8yn
- GitHub CI on PR #81387 head 695f694b70

Co-authored-by: kinjitakabe <273844887+kinjitakabe@users.noreply.github.com>
2026-05-13 12:56:09 +01:00
Peter Steinberger
c796b96d34 docs: add changelog for Claude CLI reseed (#80934) (thanks @bitloi) 2026-05-13 12:54:40 +01:00
bitloi
dd8aa1dcce fix: reseed Claude CLI session context on rotation closes #80905 2026-05-13 12:54:40 +01:00
Jason
ce31fc91e1 Allow pnpm source updates to build OpenClaw (#81294)
Merged via squash.

Prepared head SHA: 4815d5a8c9
Co-authored-by: fuller-stack-dev <263060202+fuller-stack-dev@users.noreply.github.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-13 14:30:08 +03:00
Pavan Kumar Gondhi
af42260440 Require explicit browser device pairing [AI] (#81289)
* fix: require explicit pairing for browser-origin device sessions

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 16:49:24 +05:30
Pavan Kumar Gondhi
96fba91b3a Require Control UI pairing before proxy-scoped access [AI] (#81288)
* fix: require control ui device pairing for proxy auth

* addressing review-skill

* fix: cover proxy control ui unbound scopes

* docs: add changelog entry for PR merge
2026-05-13 16:48:39 +05:30
Peter Steinberger
5f8e1dd399 feat(telegram): support web app presentation buttons
Refs #81356
Co-authored-by: Jamil Zakirov <jamil@zakirov.com>
2026-05-13 12:08:29 +01:00
Peter Steinberger
b4d148e21a fix: harden telegram localized command menus (#81351) (thanks @jzakirov) 2026-05-13 11:59:21 +01:00
Jamil Zakirov
97df0bc55a feat(telegram): localized command menu descriptions
Consume `descriptionLocalizations` from plugin command specs and
register per-locale command menus via Telegram `setMyCommands`
`language_code` parameter. Follows the same pattern already used
by the Discord extension.
2026-05-13 11:59:21 +01:00
Peter Steinberger
ca4672458c docs: stop referencing shell profile secrets 2026-05-13 11:55:14 +01:00
Peter Steinberger
0832343197 fix(discord): quiet fatal realtime voice startup failures 2026-05-13 11:51:43 +01:00
Peter Steinberger
74a809a1cd ci: grant dependency awareness pull request writes 2026-05-13 11:45:33 +01:00
Peter Steinberger
1bc45af1db ci: tolerate dependency awareness read-only tokens 2026-05-13 11:45:33 +01:00
Peter Steinberger
46f7750c63 fix: narrow plugin SDK hook type exports 2026-05-13 11:40:37 +01:00
Jamil Zakirov
68c77bb55d feat(plugin-sdk): export plugin hook types
Add `openclaw/plugin-sdk/types` entrypoint that re-exports plugin hook
types, so external plugins can import typed hook interfaces without
reaching into internal paths.

Also export `resolveActiveEmbeddedRunSessionId` from
`agent-harness-runtime` for session resolution in embedded runs.
2026-05-13 11:40:25 +01:00
Pavan Kumar Gondhi
26c7da2d02 Harden trusted-proxy source validation [AI] (#81290)
* fix: reject local-interface trusted-proxy peers

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-13 16:10:11 +05:30
Jamil Zakirov
b7572cc384 feat(plugins): expose tools in LLM input hook event
Add optional `tools` array to `PluginHookLlmInputEvent` so plugin
hooks receive the full LLM call context, not just prompt and history.
2026-05-13 11:38:32 +01:00
Vincent Koc
65e37017b6 revert(cli): remove global root refusal (#81370) 2026-05-13 18:34:46 +08:00
Peter Steinberger
9f46e9cb85 refactor(provider): share operation timeout resolvers 2026-05-13 11:26:30 +01:00
Peter Steinberger
bd326cdd5e fix(provider): retry post status and download deadlines 2026-05-13 11:26:30 +01:00
Peter Steinberger
8b0b4ea82f fix(provider): retry google rest status failures 2026-05-13 11:26:30 +01:00
Peter Steinberger
af021aac8d fix(provider): preserve retry deadlines 2026-05-13 11:26:30 +01:00
Peter Steinberger
47ba73de27 fix(provider): type minimax retry helper 2026-05-13 11:26:30 +01:00
Peter Steinberger
86ee352138 fix(provider): avoid nested transcription retries 2026-05-13 11:26:30 +01:00
Peter Steinberger
ecdad948b5 refactor(provider): centralize transient retry stages 2026-05-13 11:26:30 +01:00
Peter Steinberger
9741bbe2c1 fix(provider): retry top-level network codes 2026-05-13 11:26:29 +01:00
Peter Steinberger
635f6e0d0e fix(provider): tag timeout aborts for retry 2026-05-13 11:26:29 +01:00
Peter Steinberger
b150e23a60 fix(provider): keep abort retries timeout-scoped 2026-05-13 11:26:29 +01:00
Peter Steinberger
2e3c49b161 fix(provider): dedupe transient retry policy 2026-05-13 11:26:29 +01:00
sqsge
f20054ba79 fix(provider): add opt-in transient retries for provider execution 2026-05-13 11:26:29 +01:00
Peter Steinberger
27e5d49fe5 build(whatsapp): keep audio deps external 2026-05-13 11:21:17 +01:00
Peter Steinberger
1e8e004361 build(pnpm): restore exotic subdependency blocking 2026-05-13 11:21:17 +01:00
Peter Steinberger
85f9276624 build(whatsapp): externalize whatsapp plugin 2026-05-13 11:21:17 +01:00
Peter Steinberger
49ccd4e080 docs: quote clawdtributor skill description 2026-05-13 11:20:33 +01:00
Peter Steinberger
7c89fb455b docs: tighten clawdtributor skill trigger 2026-05-13 11:18:31 +01:00
Peter Steinberger
09a490de17 docs: add clawdtributor triage skill 2026-05-13 11:16:34 +01:00
Peter Steinberger
a15559b8d0 fix: normalize array tool schemas (#81217) (thanks @JARVIS-Glasses) 2026-05-13 11:04:13 +01:00
JARVIS-Glasses
392b23c01e fix(agents): normalize array tool schemas 2026-05-13 11:04:13 +01:00
Peter Steinberger
2cae5e92a6 test: dedupe codex user input mock read 2026-05-13 10:58:25 +01:00
Peter Steinberger
16c5d5b87b test: dedupe codex subagent mirror mock reads 2026-05-13 10:57:08 +01:00
Peter Steinberger
453019a2c7 test: dedupe codex compact mock reads 2026-05-13 10:55:45 +01:00
Peter Steinberger
fe19d9fea8 test: dedupe codex schema mock read 2026-05-13 10:54:10 +01:00
Peter Steinberger
a661b7b04c test: dedupe feishu cleanup mock reads 2026-05-13 10:52:29 +01:00
Peter Steinberger
db6bb6d329 test: dedupe zalo pairing mock read 2026-05-13 10:51:10 +01:00
Peter Steinberger
c115b126d2 test: dedupe codex client mock reads 2026-05-13 10:49:47 +01:00
Peter Steinberger
48c8aa11f8 test: dedupe codex context engine mock read 2026-05-13 10:48:18 +01:00
Sarah Fortune
aae173a1c9 fix(plugins): raise default install scan file limit to 25k (#81361) 2026-05-13 02:47:13 -07:00
Peter Steinberger
62adbe0b80 test: dedupe codex binding mock helper 2026-05-13 10:45:51 +01:00
Peter Steinberger
80190249ec test: dedupe nostr mock call helper 2026-05-13 10:44:22 +01:00
Peter Steinberger
95901042d4 fix(config): normalize gemini subagent model writes 2026-05-13 10:42:08 +01:00
Jesse Merhi
6c92324c5f Revert "Check ClawHub trust before plugin installs (#81307)" (#81363)
This reverts commit 87eb450047.
2026-05-13 19:34:18 +10:00
Peter Steinberger
060768ef75 test: dedupe gateway run loop mock read 2026-05-13 10:33:35 +01:00
Peter Steinberger
a9215ef2d4 test: dedupe command secret target mock read 2026-05-13 10:28:56 +01:00
Peter Steinberger
578d723b48 test: dedupe daemon cli mock read 2026-05-13 10:25:54 +01:00
Peter Steinberger
b1db684aca test: dedupe command secret gateway mock read 2026-05-13 10:23:44 +01:00
Peter Steinberger
5904e2027f test: dedupe node cli mock read 2026-05-13 10:20:51 +01:00
Peter Steinberger
06b8cd4565 test: tighten core test mock fixtures 2026-05-13 10:18:35 +01:00
Peter Steinberger
2e6d34d2c9 test: dedupe matrix devices mock read 2026-05-13 10:13:47 +01:00
Peter Steinberger
321c996af8 test: dedupe matrix logger mock read 2026-05-13 10:12:05 +01:00
Peter Steinberger
0fa30e790c docs: clarify cluster close policy 2026-05-13 10:08:17 +01:00
Mason Huang
0eeafbdce2 docs(changelog): credit Ziy1-Tan for transcript redaction (#81343)
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-05-13 17:06:17 +08:00
Peter Steinberger
7c3e4dbf94 test: dedupe whatsapp audio mock read 2026-05-13 10:02:45 +01:00
Peter Steinberger
3a44d88d09 test: dedupe litellm image mock read 2026-05-13 10:00:10 +01:00
Peter Steinberger
383ebe723b test: dedupe canvas tool mock read 2026-05-13 09:56:50 +01:00
Peter Steinberger
5bb2c5e454 test: dedupe canvas cli mock read 2026-05-13 09:54:55 +01:00
Peter Steinberger
f02b715f2b test: dedupe qqbot image mock reads 2026-05-13 09:51:51 +01:00
Peter Steinberger
898a5aae21 test: dedupe line signature mock read 2026-05-13 09:48:41 +01:00
Peter Steinberger
c1700a5c9f test: dedupe imessage action mock read 2026-05-13 09:45:26 +01:00
Peter Steinberger
ffb2dcc2e6 test: dedupe imessage retry mock reads 2026-05-13 09:43:20 +01:00
Peter Steinberger
1d331bcfc5 test: fix telegram transcript mock type 2026-05-13 09:39:19 +01:00
Peter Steinberger
6cd2059749 test: dedupe line rich menu mock reads 2026-05-13 09:35:04 +01:00
Peter Steinberger
33655ee290 test: dedupe line lifecycle mock read 2026-05-13 09:32:43 +01:00
clawsweeper[bot]
faaa7efef0 fix(security): inline redact into appendSessionTranscriptMessage (#79645)
Merged via squash.

Prepared head SHA: da91ab6cf1
Co-authored-by: app/clawsweeper <274271284+clawsweeper[bot]@users.noreply.github.com>
Co-authored-by: hxy91819 <8814856+hxy91819@users.noreply.github.com>
Reviewed-by: @hxy91819
2026-05-13 16:31:04 +08:00
Peter Steinberger
5ef9207813 test: dedupe mattermost retry mock read 2026-05-13 09:30:56 +01:00
Peter Steinberger
c8ddf71989 test: dedupe qa runtime mock read 2026-05-13 09:28:16 +01:00
Peter Steinberger
6c2e0bdc0c test: dedupe matrix action mock read 2026-05-13 09:25:59 +01:00
Peter Steinberger
06e04291e0 test: dedupe signal reply mock reads 2026-05-13 09:24:08 +01:00
Peter Steinberger
b693173e0d test: dedupe synology webhook mock read 2026-05-13 09:22:14 +01:00
Ayaan Zaidi
f7e9d80536 docs(changelog): credit idle timeout fallback fix (#80449) (thanks @jimdawdy-hub) 2026-05-13 13:51:51 +05:30
Ayaan Zaidi
a7ae889ae5 test(agents): cover idle timeout fallback during tools 2026-05-13 13:51:51 +05:30
Jim Dawdy
a6e4132a8c fix: preserve timeout reason after idle-only profile rotations
Addresses Codex P3 review finding: when shouldRotateAssistant fires on
idleTimedOut alone (timedOut=false), mergeRetryFailoverReason was passed
timedOut: params.timedOut (false), so the accumulated retry reason did
not record 'timeout'. Pass timedOut || idleTimedOut so the timeout reason
survives idle-only rotations and downstream fallback_model receives the
correct reason.
2026-05-13 13:51:51 +05:30
Jim Dawdy
b3ef14dbfc fix: address code review findings
- failover-policy.test.ts: move 4 new it() blocks inside describe()
  (they were orphaned outside the block and would not execute)
- run.ts: add idleTimedOut to the assistantFailoverDecision call site
  (missing required field caused TypeScript error and reproduced the freeze
  for the initial-decision code path in the outer loop)
- assistant-failover.ts: treat idleTimedOut same as timedOut in
  markFailedProfile to avoid incorrect profile failure recording
- assistant-failover.ts: add warn log when idle timeout rotates a profile
- assistant-failover.ts: extend resolveAssistantFailoverErrorMessage to
  accept idleTimedOut so surface_error emits "LLM request timed out."
  instead of the generic "LLM request failed."
2026-05-13 13:51:51 +05:30
Jim Dawdy
5ca95b2012 fix(agents): escalate LLM idle timeout to model fallback after profile rotation
When the LLM idle watchdog fires (model produced no tokens for N seconds),
idleTimedOut is set in handleAssistantFailover but was never passed into
resolveRunFailoverDecision. As a result, shouldRotateAssistant saw neither
failoverReason nor timedOut (the run-budget timeout) set, returned false,
and the decision fell through to continue_normal -- the agent silently froze
without surfacing an error or advancing the fallback chain.

Fixes #76877 (regression since 2026.4.24).

Changes:
- failover-policy.ts: add idleTimedOut to AssistantDecisionParams; include it
  in shouldRotateAssistant and reason selection in resolveRunFailoverDecision
- assistant-failover.ts: pass idleTimedOut into resolveRunFailoverDecision
- failover-policy.test.ts: 4 new cases for idle timeout path; update existing
  assistant stage cases with the new required field (idleTimedOut: false)
2026-05-13 13:51:51 +05:30
Peter Steinberger
ba17ddaef3 test: dedupe mattermost route mock read 2026-05-13 09:19:41 +01:00
Peter Steinberger
99f81f10e3 test: dedupe qqbot websocket mock read 2026-05-13 09:17:48 +01:00
Peter Steinberger
9ac275a8bf test: dedupe line download mock read 2026-05-13 09:16:20 +01:00
Peter Steinberger
1dc678393f test: dedupe huggingface provider mock read 2026-05-13 09:15:12 +01:00
Peter Steinberger
4e1f92641c test: dedupe tavily client mock reads 2026-05-13 09:13:34 +01:00
Peter Steinberger
9d13203d15 test: dedupe ollama setup mock reads 2026-05-13 09:12:26 +01:00
Peter Steinberger
6648950862 test: dedupe irc inbound mock read 2026-05-13 09:11:22 +01:00
Peter Steinberger
0f7b1c5414 test: dedupe clickclack inbound mock reads 2026-05-13 09:10:17 +01:00
Peter Steinberger
6ad1c7f3b7 test: dedupe discord listener mock read 2026-05-13 09:08:57 +01:00
Ayaan Zaidi
95a105334b docs(changelog): note worktree heavy-check locks (#80734) (thanks @samzong) 2026-05-13 13:38:52 +05:30
Ayaan Zaidi
25cda2b24c test(scripts): simplify worktree lock setup 2026-05-13 13:38:52 +05:30
samzong
94aae40c28 feat(scripts): allow worktree heavy-check locks
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-13 13:38:52 +05:30
Peter Steinberger
64ff396593 test: dedupe discord webhook mock read 2026-05-13 09:06:09 +01:00
Josh Avant
bd4db5ee62 Add dependency release safety evidence and PR awareness (#81325)
* test: cover dependency pin guard

* build: add dependency vulnerability gate

* build: add dependency risk report

* build: add dependency drift reports

* build: include dependency ownership surface evidence

* build: rename dependency report commands

* build: respect release age exclusions in risk report

* build: clarify transitive risk accounting

* build: remove transitive risk exception registry

* build: clarify transitive risk signal wording

* ci: attach dependency evidence to release preflight

* ci: extract dependency release evidence generator

* build: rename ownership surface dependency report

* ci: clarify release evidence naming

* build: clarify recently published risk report

* build: reorder transitive risk report sections

* build: fix ownership surface pluralization

* ci: surface dependency changes on PRs

* ci: harden dependency change awareness

* ci: use dependency changed PR label

* build: fix dependency report lint

* docs: add dependency safety changelog
2026-05-13 03:05:09 -05:00
Peter Steinberger
b9b7ffc8cd test: dedupe memory search mock read 2026-05-13 09:04:40 +01:00
Peter Steinberger
f2bd20351f test: dedupe llm task mock read 2026-05-13 09:03:18 +01:00
Peter Steinberger
abd45b1763 test: dedupe zalo reply mock read 2026-05-13 08:59:31 +01:00
Peter Steinberger
96752f9804 test: dedupe tlon guarded fetch mock read 2026-05-13 08:57:52 +01:00
Peter Steinberger
22411e17cb fix(cli): normalize Gemini config mutation refs 2026-05-13 08:56:02 +01:00
Peter Steinberger
954407ab74 test: dedupe outbound matrix mock read 2026-05-13 08:43:35 +01:00
Peter Steinberger
edce338e32 test: dedupe cron model override last mock read 2026-05-13 08:41:20 +01:00
Peter Steinberger
cf11d16b43 fix(agents): make subagent task delivery visible
Co-authored-by: stainlu <stainlu@newtype-ai.org>
2026-05-13 08:40:27 +01:00
Peter Steinberger
17fe41a4b9 test: dedupe heartbeat stability mock read 2026-05-13 08:38:57 +01:00
Peter Steinberger
e2ced4cb53 test: dedupe command status mock read 2026-05-13 08:36:19 +01:00
Lellansin Huang
78e03e3004 fix(gateway): forward OpenAI sampling params
- Forward temperature and top_p through OpenAI-compatible chat and responses gateway paths.
- Return OpenAI-compatible 400 errors for invalid sampling params and provider validation failures instead of collapsing them to 500s.
- Add regression coverage and changelog credit.

Co-authored-by: lellansin <lellansin@gmail.com>
2026-05-13 08:35:48 +01:00
Peter Steinberger
b0c817ee9d test: dedupe discord sdk mock read 2026-05-13 08:32:31 +01:00
Peter Steinberger
27af4f618e test: dedupe inbound reply mock read 2026-05-13 08:30:05 +01:00
Peter Steinberger
52a02ab310 test: dedupe acp runtime mock read 2026-05-13 08:27:26 +01:00
Peter Steinberger
34ce85a83d test: dedupe heartbeat commitment mock read 2026-05-13 08:24:24 +01:00
Peter Steinberger
a95a317425 test: dedupe cron tts mock read 2026-05-13 08:22:07 +01:00
Peter Steinberger
40e8782400 test: dedupe cron skills snapshot mock read 2026-05-13 08:20:12 +01:00
Peter Steinberger
d97f72633c test: dedupe plugin approval mock read 2026-05-13 08:18:31 +01:00
Peter Steinberger
49e34f2b7b docs: update crabbox cross-platform skill 2026-05-13 08:16:47 +01:00
Peter Steinberger
f5be0d1406 fix: make codex harness live test portable 2026-05-13 08:16:47 +01:00
Peter Steinberger
984981832e test: dedupe cron model preflight mock read 2026-05-13 08:16:07 +01:00
Peter Steinberger
718476ccc5 test: dedupe cron model override mock read 2026-05-13 08:13:55 +01:00
Peter Steinberger
9ade25d985 test: dedupe isolated cron fallback mock read 2026-05-13 08:11:55 +01:00
Peter Steinberger
62f9024361 test: dedupe isolated cron session mock read 2026-05-13 08:09:59 +01:00
Peter Steinberger
1ae9d8227a test: dedupe cron enqueue mock read 2026-05-13 08:07:09 +01:00
Peter Steinberger
f706d3c322 test: dedupe approval route mock read 2026-05-13 08:05:28 +01:00
Peter Steinberger
4a97da8b47 test: dedupe scheduled turn mock read 2026-05-13 08:03:52 +01:00
Peter Steinberger
b6fcb63d75 test: dedupe session attachment mock read 2026-05-13 08:01:55 +01:00
Peter Steinberger
4c7ce0ad91 test: dedupe web search provider mock read 2026-05-13 07:59:34 +01:00
Peter Steinberger
81811e55a7 test: dedupe provider runtime mock read 2026-05-13 07:58:05 +01:00
Peter Steinberger
0bd3d7c2ed test: dedupe plugin runtime mock read 2026-05-13 07:56:44 +01:00
Peter Steinberger
d29225fde4 test: dedupe plugin install path mock read 2026-05-13 07:54:50 +01:00
Peter Steinberger
57027e35db test: dedupe metadata registry mock read 2026-05-13 07:53:22 +01:00
Peter Steinberger
15481dab26 test: dedupe plugin uninstall mock read 2026-05-13 07:51:59 +01:00
Sarah Fortune
a197e31abb feat(migrate): suppress plan log on embedding + add "Accept recommended" affordance (#81219)
Two related improvements to the interactive `openclaw migrate <provider>`
flow, both surfaced by the onboarding post-install migration prompt that
landed in #81192.

1. `suppressPlanLog?: boolean` on `MigrateCommonOptions`
   (`src/commands/migrate/types.ts`). When set, `migratePlanCommand`
   skips the up-front `runtime.log(formatMigrationPlan(plan))` dump.
   The interactive Codex selection picker and the "Apply this migration
   now?" confirm still run. Wired from the wizard helper at
   `src/wizard/setup.post-install-migration.ts` so that path no longer
   shows the plan dump after the user has already confirmed at the
   wizard prompt.

2. New "Accept recommended" sentinel row at the top of both Codex
   selection pickers, with "Toggle all on" and "Toggle all off" moved
   to the bottom. The cursor starts on "Accept recommended" so pressing
   Enter at the default position submits the picker's `initialValues`
   (the recommended set) — matching the visual state of the checkboxes.

   Implemented in `skill-selection-prompt.ts`:
   - Enter on the Accept sentinel sets `prompt.value` to
     `opts.initialValues` and lets clack submit.
   - Space on the Accept sentinel snaps `prompt.value` to
     `opts.initialValues` so the visible checkboxes flip to the
     recommended state. The user can then Enter to commit or continue
     toggling individual rows. The Accept row itself is never persisted
     in the submitted value list.

   The existing Enter handler for "Toggle all on" / "Toggle all off"
   stays unchanged.

3. Removed the "Skip for now" sentinel entirely. It was a single-
   keystroke trap: with the picker cursor wrapping from Accept to Skip
   via up-arrow (or via accidental down-arrows), Enter on Skip wiped
   `prompt.value` to `[MIGRATION_SELECTION_SKIP]` and abandoned the
   whole migration — including any items the user had already
   confirmed in the previous picker. To exit without migrating, users
   now navigate to "Toggle all off" (or use the `a` / `i` keyboard
   shortcuts) to clear the selection; the apply phase then sees no
   planned work and skips itself via the existing
   `shouldSkipCodexApplyAfterInteractiveSelection` path.

   Cleanup spans `migrate/selection.ts` (constants, `{ action: "skip" }`
   variant, and the reconcile/resolve SKIP branches),
   `migrate.ts` (the picker option rows and the
   `if (selection.action === "skip")` handler blocks in both pickers),
   and the corresponding tests.

4. Plugin selection hint relabelled from "Activate every recommended
   plugin" to "Migrate every recommended plugin" so it matches the
   skill hint and the prompt's own verb ("Migrate ... into this agent
   now?").

Tests:

- `src/commands/migrate/skill-selection-prompt.test.ts` — Accept
  sentinel cases (Enter and Space + Enter both submit initialValues);
  Skip-related test removed; Skip row dropped from the picker fixture.
- `src/commands/migrate/selection.test.ts` — Skip-related sub-
  assertions trimmed from the resolve/reconcile tests; the
  "skip + toggle-off precedence" test renamed to "toggle-off precedence
  over toggle-on" and Skip cases removed.
- `src/commands/migrate.test.ts` — four Skip-driven scenarios removed
  (plugin-only skip, both-pickers skip, skip-skills-continue-to-plugins,
  Codex subscription warning + skip).
- `src/wizard/setup.post-install-migration.test.ts` — call-args
  assertion expects the new `suppressPlanLog` option.

Verification:

- `pnpm lint` clean
- `pnpm tsgo:core` + `pnpm tsgo:core:test` clean
- Touched test suites green (migrate 32/32, selection 17/17,
  skill-selection-prompt 6/6, setup.post-install-migration 10/10).
2026-05-12 23:51:19 -07:00
Peter Steinberger
96b49f0b93 test: dedupe plugin service mock read 2026-05-13 07:50:21 +01:00
Peter Steinberger
10663e4ba2 test: dedupe plugin lifecycle mock read 2026-05-13 07:48:52 +01:00
Peter Steinberger
86dfc78d97 test: dedupe npm pack temp dir mock read 2026-05-13 07:46:07 +01:00
Peter Steinberger
8ebb18416a test: dedupe shell env exec mock read 2026-05-13 07:44:38 +01:00
Peter Steinberger
e898ea67b4 test: dedupe marketplace command mock read 2026-05-13 07:42:52 +01:00
Peter Steinberger
23856156e2 test: dedupe inbound claim log mock read 2026-05-13 07:41:24 +01:00
Peter Steinberger
21aaa9ed81 test: dedupe google video download mock read 2026-05-13 07:39:14 +01:00
Peter Steinberger
6b4333ae6b test: dedupe xiaomi speech fetch mock read 2026-05-13 07:37:35 +01:00
Peter Steinberger
3bc433c179 fix(config): normalize per-agent Gemini preview refs 2026-05-13 07:35:56 +01:00
Jesse Merhi
87eb450047 Check ClawHub trust before plugin installs (#81307)
Merged via squash.

Prepared head SHA: 273fd7c20e
Co-authored-by: jesse-merhi <79823012+jesse-merhi@users.noreply.github.com>
Co-authored-by: jesse-merhi <79823012+jesse-merhi@users.noreply.github.com>
Reviewed-by: @jesse-merhi
2026-05-13 16:31:52 +10:00
Peter Steinberger
cf68115e6e test: dedupe synology client mock reads 2026-05-13 07:25:03 +01:00
Peter Steinberger
ef78fc9534 test: dedupe synology route mock read 2026-05-13 07:23:36 +01:00
Ayaan Zaidi
8879c671e3 docs(changelog): note Telegram polling stall fix 2026-05-13 11:53:00 +05:30
Ayaan Zaidi
56873b6065 fix(telegram): detect polling stalls from getUpdates 2026-05-13 11:53:00 +05:30
Peter Steinberger
7899b70c18 test: dedupe whatsapp close mock read 2026-05-13 07:21:41 +01:00
Peter Steinberger
0b4f0129df test: dedupe qwen video request mock reads 2026-05-13 07:19:44 +01:00
Peter Steinberger
63ee74109e test: dedupe ollama embedding fetch mock read 2026-05-13 07:18:13 +01:00
Peter Steinberger
4cf6971130 test: dedupe gradium tts fetch mock read 2026-05-13 07:15:45 +01:00
Peter Steinberger
dd127ba0ba test: dedupe google image fetch mock read 2026-05-13 07:14:29 +01:00
Peter Steinberger
6932c66ffe test: dedupe minimax speech fetch mock reads 2026-05-13 07:12:39 +01:00
Peter Steinberger
7e1e4c5f78 test: dedupe memory wiki cli mock read 2026-05-13 07:11:04 +01:00
Peter Steinberger
6ced971cf1 test: dedupe minimax image fetch mock reads 2026-05-13 07:09:24 +01:00
Peter Steinberger
b430270429 test: dedupe copilot model fetch mock reads 2026-05-13 07:07:56 +01:00
Peter Steinberger
29ac94b0e4 test: dedupe device pair qr mock read 2026-05-13 07:06:34 +01:00
Ayaan Zaidi
bfbb9c6f9f docs(changelog): note ACP Claude timeout fix (#80812) (thanks @sxxtony) 2026-05-13 11:35:36 +05:30
Ayaan Zaidi
a146bf03db refactor(acpx): distill ACP command detection 2026-05-13 11:35:36 +05:30
sxxtony
bf8f5d991c fix(acp): drop unsupported timeout config option for claude-agent-acp
`runtime-options.buildRuntimeConfigOptionPairs` translated
`AcpSessionRuntimeOptions.timeoutSeconds` into a
`session/set_config_option(configId: "timeout")` pair on every turn. Both the
control plane (`AcpSessionManager.applyManagerRuntimeControls`) and the ACPX
wrapper (`AcpxRuntime.setConfigOption`) sit between that pair and the backend:

- The control plane validates pairs against the backend's advertised
  config-option keys and throws `ACP_BACKEND_UNSUPPORTED_CONTROL` for any
  pair the backend did not advertise. claude-agent-acp does not advertise a
  `timeout` alias.
- The wrapper then forwards remaining pairs to the delegate. The Codex ACP
  command was already short-circuited there; every other command, including
  claude-agent-acp, fell through.

Net effect on the reporter's scenario:
`sessions_spawn({ runtime:"acp", agentId:"claude", timeoutSeconds: 60 })`
failed at the control-plane validation with `ACP_BACKEND_UNSUPPORTED_CONTROL`
(and, had it reached the wire, claude-agent-acp would have answered
`-32603 Internal error / Unknown config option: timeout`, surfacing as
`ACP_TURN_FAILED: Internal error`).

Fix two layers:

1. Control plane (`src/acp/control-plane/runtime-options.ts`): add
   `isTimeoutConfigOptionAdvertised(advertisedConfigOptionKeys)` and gate the
   timeout pair on it. When advertised keys are unknown (`undefined` or
   empty), keep emitting the pair — this preserves current behavior for
   backends that have not produced a capability list yet. When advertised
   keys are present but exclude every alias in
   `RUNTIME_CONFIG_OPTION_ALIASES.timeoutSeconds`, skip the pair. The
   per-turn timeout is still enforced in-process via
   `AcpSessionManager.resolveTurnTimeoutMs` in `manager.core.ts`.

2. ACPX wrapper (`extensions/acpx/src/runtime.ts`): hoist the Codex
   `timeout` / `timeout_seconds` suppression so it also applies to
   claude-agent-acp commands. Add `isClaudeAcpCommand` mirroring
   `isCodexAcpCommand` (package spec, binary, generated wrapper script).
   This layer is defense in depth — relevant when callers reach the wrapper
   without going through `applyManagerRuntimeControls`, or when advertised
   keys are not yet known.

Coverage:

- `src/acp/control-plane/runtime-options.test.ts` (new) asserts:
  - the timeout pair is omitted when advertised keys exclude every alias,
  - the pair is kept when `timeout` or `timeout_seconds` is advertised,
  - the pair is kept when advertised keys are unknown,
  - model/thinking emission is unaffected.
- `extensions/acpx/src/runtime.test.ts` flips the previous
  `forwards timeout config controls for non-Codex ACP agents` test, which
  codified the buggy behavior, into a suppression assertion. Adds a
  positive `still forwards non-timeout config controls for claude-agent-acp`
  test and an `isClaudeAcpCommand` detector test.

Closes #81127
2026-05-13 11:35:36 +05:30
Peter Steinberger
50cb5ae089 test: dedupe openrouter stream mock read 2026-05-13 07:05:03 +01:00
Peter Steinberger
6a589017ca test: dedupe memory wiki gateway mock reads 2026-05-13 07:03:45 +01:00
Peter Steinberger
3945fd5812 test: dedupe tokenjuice mock read 2026-05-13 07:02:06 +01:00
Peter Steinberger
53032505bd test: dedupe memory lancedb provider assertion 2026-05-13 07:00:59 +01:00
Peter Steinberger
b8727202a5 test: dedupe inworld tts mock read 2026-05-13 06:59:47 +01:00
Peter Steinberger
7de4c47da2 test: dedupe qa credential lease mock read 2026-05-13 06:57:56 +01:00
Peter Steinberger
2a931b5906 test: dedupe google meet oauth mock read 2026-05-13 06:56:44 +01:00
Peter Steinberger
be343e3134 test: dedupe zalouser pairing mock reads 2026-05-13 06:55:30 +01:00
Peter Steinberger
0e3347cba6 test: dedupe reply flow mock read 2026-05-13 06:54:15 +01:00
Peter Steinberger
dccb382283 test: dedupe hook security mock read 2026-05-13 06:51:28 +01:00
Peter Steinberger
134461723e test: dedupe session hook mock read 2026-05-13 06:49:45 +01:00
Peter Steinberger
4a6e46152a test: dedupe sandbox media mock read 2026-05-13 06:48:05 +01:00
Peter Steinberger
6de17fcb75 test: dedupe exec host mock read 2026-05-13 06:46:29 +01:00
Peter Steinberger
560679a2ad test: dedupe outbound channel mock read 2026-05-13 06:45:08 +01:00
Peter Steinberger
af21973ea2 test: dedupe outbound send mock read 2026-05-13 06:43:10 +01:00
Peter Steinberger
07ffc2b955 test: dedupe outbound media mock read 2026-05-13 06:41:47 +01:00
Peter Steinberger
2b5d9bb47c test: dedupe cron owner auth mock read 2026-05-13 06:39:53 +01:00
Peter Steinberger
cd993f4584 test: dedupe cron fast mode mock read 2026-05-13 06:38:15 +01:00
Peter Steinberger
210f606be8 test: dedupe lmstudio stream mock read 2026-05-13 06:36:48 +01:00
Peter Steinberger
93233b2c6b test: dedupe azure speech mock reads 2026-05-13 06:35:12 +01:00
Peter Steinberger
f513c3f0dd test: dedupe qa manual lane mock reads 2026-05-13 06:32:35 +01:00
Peter Steinberger
b21630d6d1 test: dedupe memory watcher mock reads 2026-05-13 06:30:58 +01:00
Peter Steinberger
61268e8117 test: dedupe memory search mock read 2026-05-13 06:29:31 +01:00
Peter Steinberger
df9c9adeff test: dedupe mantle anthropic mock read 2026-05-13 06:27:58 +01:00
Peter Steinberger
87109e5fb5 test: dedupe anthropic vertex mock reads 2026-05-13 06:26:33 +01:00
Peter Steinberger
a282bdc601 test: dedupe openai image mock reads 2026-05-13 06:25:08 +01:00
Peter Steinberger
7bb2153fb2 test: dedupe openai tts mock reads 2026-05-13 06:23:44 +01:00
Peter Steinberger
30af076000 test: dedupe doctor registry mock read 2026-05-13 06:21:35 +01:00
homer-byte
ba1f4271e8 fix(imessage): keep pasted links without preview media (#79374)
Thanks @homer-byte.
2026-05-12 22:20:44 -07:00
Peter Steinberger
a123cddb4b test: dedupe channel module mock read 2026-05-13 06:19:57 +01:00
Ayaan Zaidi
8fe196e28b docs(changelog): add diagnostic lane PR reference 2026-05-13 10:48:46 +05:30
Ayaan Zaidi
d571f21c66 docs(changelog): note diagnostic lane fix 2026-05-13 10:48:46 +05:30
Ayaan Zaidi
3d3a2399b5 fix(logging): track reply runs in diagnostics 2026-05-13 10:48:46 +05:30
Peter Steinberger
5a10326612 test: dedupe node media log mock read 2026-05-13 06:17:56 +01:00
Peter Steinberger
934198b9a5 test: dedupe mcp channel mock read 2026-05-13 06:16:31 +01:00
Peter Steinberger
b25f657394 test: dedupe fetch timeout mock read 2026-05-13 06:15:29 +01:00
Peter Steinberger
6715ac526e test: dedupe plugin cli mock reads 2026-05-13 06:13:46 +01:00
Peter Steinberger
0b0539af17 test: dedupe outbound send mock read 2026-05-13 06:12:32 +01:00
Peter Steinberger
5a2dfac674 test: dedupe cli utility mock read 2026-05-13 06:11:23 +01:00
Peter Steinberger
6af82efcad test: dedupe feishu chat mock reads 2026-05-13 06:10:09 +01:00
Peter Steinberger
54c633db36 test: dedupe feishu docx mock reads 2026-05-13 06:09:06 +01:00
Peter Steinberger
73e0c51a5a test: dedupe vydra fetch mock reads 2026-05-13 06:07:49 +01:00
Peter Steinberger
832f91adbc test: dedupe gateway devices mock read 2026-05-13 06:06:21 +01:00
Peter Steinberger
8d50c3bc05 test: dedupe gateway tools mock reads 2026-05-13 06:05:23 +01:00
Peter Steinberger
2e7036e85c test: dedupe gateway sessions mock read 2026-05-13 06:04:18 +01:00
Peter Steinberger
f9157fcf82 test: dedupe gateway drain mock read 2026-05-13 06:03:11 +01:00
Peter Steinberger
5c67c93ac9 test: dedupe brave fetch mock read 2026-05-13 06:01:48 +01:00
Gio Della-Libera
f141a086fc fix(update): suppress handoff newer-config warning (#81235)
Merged via squash.

Prepared head SHA: 61a5c975bf
Co-authored-by: giodl73-repo <giodl@microsoft.com>
Co-authored-by: galiniliev <5711535+galiniliev@users.noreply.github.com>
Reviewed-by: @galiniliev
2026-05-12 22:01:21 -07:00
Peter Steinberger
94fdc56b64 test: dedupe cron ops mock read 2026-05-13 06:00:25 +01:00
Peter Steinberger
2c3582ad0b test: dedupe cron service mock reads 2026-05-13 05:58:16 +01:00
Peter Steinberger
8fd0f9965e test: dedupe google chat mock reads 2026-05-13 05:56:42 +01:00
Pavan Kumar Gondhi
39bcd1e088 fix(plugins): scan installed dependency runtime code [AI] (#81066)
* fix: scan installed plugin dependency code

* addressing review-skill

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 10:26:24 +05:30
Peter Steinberger
06c3318bba test: dedupe cli plugin registry mock read 2026-05-13 05:55:05 +01:00
Peter Steinberger
77f08d095d test: dedupe models cli mock read 2026-05-13 05:54:01 +01:00
Peter Steinberger
c27eca08e3 test: dedupe plugin timeout mock read 2026-05-13 05:52:55 +01:00
Peter Steinberger
2597d6d6d4 test: dedupe runtime web tools mock read 2026-05-13 05:51:45 +01:00
Pavan Kumar Gondhi
6c918ca85f Inherit tool restrictions for delegated sessions [AI] (#80979)
* fix: inherit tool restrictions for delegated sessions

* addressing review-skill

* addressing review-skill

* addressing review-skill

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing review-skill

* addressing codex review

* addressing claude review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 10:21:36 +05:30
Peter Steinberger
aba7652b76 test: dedupe echo transcript mock read 2026-05-13 05:50:33 +01:00
Peter Steinberger
5ce26962c5 test: dedupe daemon restart mock read 2026-05-13 05:49:16 +01:00
Peter Steinberger
30f09cc54c test: dedupe daemon lifecycle mock read 2026-05-13 05:48:12 +01:00
Peter Steinberger
277ad4a71b fix: guard link understanding fetches 2026-05-13 05:47:36 +01:00
Peter Steinberger
d3b16ddec8 docs: note baileys install policy 2026-05-13 05:47:36 +01:00
Peter Steinberger
266e72149b test: dedupe daemon config guard mock read 2026-05-13 05:47:11 +01:00
Peter Steinberger
27e47ae8e6 test: dedupe daemon install mock read 2026-05-13 05:46:18 +01:00
Peter Steinberger
7f8ce2dfd6 test: dedupe daemon service mock read 2026-05-13 05:44:49 +01:00
Peter Steinberger
1eeec9e183 test: dedupe exec approval mock read 2026-05-13 05:43:52 +01:00
Peter Steinberger
54dd6e6da2 test: dedupe cli help mock read 2026-05-13 05:42:52 +01:00
Ayaan Zaidi
a820bda89d docs(changelog): credit telegram offset fix (#80671) (thanks @sxxtony) 2026-05-13 10:12:31 +05:30
Ayaan Zaidi
306b51011f fix(telegram): handle legacy rotated offsets 2026-05-13 10:12:31 +05:30
sxxtony
cb93c0f8f5 fix(telegram): factor offset rotation handling into typed surfaces
Builds on the prior commit by introducing the typed surfaces the rest of
the plugin (and `openclaw doctor`-style consumers) can reuse:

- `inspectTelegramUpdateOffset` returns a discriminated union
  (`absent | valid | rotated`) so callers can act on the rotation event
  without re-implementing the bot-id / fingerprint comparison.
  `readTelegramUpdateOffset` is now a thin adapter over it.
- `TelegramOffsetRotationReason` is exported as a named type alias so
  downstream code can switch over it exhaustively.
- New `TelegramOffsetRotationHandler` class encapsulates the
  "log warning + delete stale file" side effect that the monitor needs at
  startup, plus a `createTelegramOffsetRotationHandler` factory and a
  pure `formatTelegramOffsetRotationMessage` helper used to keep the
  wording consistent.
- `monitor.ts` now constructs the handler once per polling startup
  instead of inlining the closure, and the new surfaces are re-exported
  through `monitor-polling.runtime.ts`.

Unit coverage:
  pnpm test extensions/telegram/src/update-offset-store.test.ts \
            extensions/telegram/src/offset-rotation-handler.test.ts \
            extensions/telegram/src/monitor.test.ts
2026-05-13 10:12:31 +05:30
sxxtony
290d3879eb fix(telegram): detect same-bot token rotation via fingerprinted offset state
Closes #80653.

Persist a non-reversible SHA-256 fingerprint of the bot token alongside the
bot id in the long-poll update offset store (version 3). On read, treat the
persisted offset as stale when the fingerprint diverges from the current
token, even when the bot id still matches. This covers the BotFather
`/revoke` case where the bot id is unchanged but the secret rotates -- the
in-process update tracker would otherwise silently skip any new updates
whose `update_id` is `<=` the restored watermark.

The legacy v2 (bot-id-only) layout still parses, and offsets are preserved
when the bot id matches so existing installs don't lose a watermark on
upgrade; the next persistence upgrades the file to v3 and enables rotation
detection going forward.

`readTelegramUpdateOffset` now reports each rotation through a new
`onRotationDetected` callback. `monitor.ts` uses it to log a clear warning
naming the previous/new bot id and the discarded offset, and to delete the
stale file rather than waiting for the first update to overwrite it.

Acceptance suites pass:
  pnpm test extensions/telegram/src/update-offset-store.test.ts \
            extensions/telegram/src/bot-update-tracker.test.ts \
            extensions/telegram/src/monitor.test.ts \
            extensions/telegram/src/bot.create-telegram-bot.test.ts \
            extensions/telegram/src/token.test.ts \
            extensions/telegram/src/polling-lease.test.ts
2026-05-13 10:12:31 +05:30
Peter Steinberger
9850cb5057 test: dedupe media understanding mock read 2026-05-13 05:41:53 +01:00
Peter Steinberger
11919c8a97 test: dedupe launchd handoff mock read 2026-05-13 05:40:55 +01:00
Peter Steinberger
4e8d9d26a9 test: dedupe wizard install plan mock read 2026-05-13 05:39:57 +01:00
Gio Della-Libera
14170f1be8 fix(commitments): write json output to stdout (#81215)
Merged via squash.

Prepared head SHA: 4a8d3bb51b
Co-authored-by: giodl73-repo <235387111+giodl73-repo@users.noreply.github.com>
Co-authored-by: galiniliev <5711535+galiniliev@users.noreply.github.com>
Reviewed-by: @galiniliev
2026-05-12 21:38:43 -07:00
Peter Steinberger
84f4bc6ca4 test: dedupe plugin uninstall mock read 2026-05-13 05:35:45 +01:00
Peter Steinberger
2ffad5c18a test: dedupe commitments mock read 2026-05-13 05:33:37 +01:00
Peter Steinberger
5592132f56 test: dedupe foundry provider mock read 2026-05-13 05:31:55 +01:00
Peter Steinberger
e643890176 test: dedupe task store mock reads 2026-05-13 05:30:29 +01:00
Pavan Kumar Gondhi
3d93174c43 browser: enforce navigation checks for act interactions [AI] (#81070)
* fix: apply browser navigation policy to act interactions

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 09:59:36 +05:30
Peter Steinberger
0d3b6d8ff6 test: dedupe cli registration mock reads 2026-05-13 05:29:02 +01:00
rendrag-git
8831754f5c fix: resolve custom provider env markers 2026-05-13 00:27:39 -04:00
rendrag-git
2269ec727f fix: list self-hosted runtime wildcard models 2026-05-13 00:27:39 -04:00
rendrag-git
3b361cf51c fix: discover self-hosted provider wildcards 2026-05-13 00:27:39 -04:00
Peter Steinberger
0c5bbdaad0 test: dedupe plugin install mock read 2026-05-13 05:27:34 +01:00
Peter Steinberger
e68dfa511e test: dedupe gateway hook mock read 2026-05-13 05:26:13 +01:00
Pavan Kumar Gondhi
17fa101c16 Validate node exec event provenance [AI] (#81071)
* fix: validate node exec event provenance

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing claude review

* addressing ci

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 09:56:09 +05:30
Peter Steinberger
d643d64194 test: dedupe memory dreaming mock read 2026-05-13 05:25:01 +01:00
Peter Steinberger
8560bd845c test: dedupe realtime talk mock read 2026-05-13 05:23:45 +01:00
Peter Steinberger
98e6519878 test: dedupe acp permission mock read 2026-05-13 05:22:13 +01:00
Peter Steinberger
a840f3e775 test: dedupe message hooks mock read 2026-05-13 05:21:06 +01:00
Peter Steinberger
ac7b406d9d test: dedupe acp startup mock reads 2026-05-13 05:19:52 +01:00
Peter Steinberger
bc6fd1fe79 test: dedupe acp stop reason mock reads 2026-05-13 05:18:48 +01:00
Peter Steinberger
39f6dc7108 test: dedupe realtime websocket mock read 2026-05-13 05:17:42 +01:00
Peter Steinberger
33152f4162 test: dedupe provider env mock read 2026-05-13 05:16:18 +01:00
Peter Steinberger
3f590b4828 test: dedupe chat controller mock read 2026-05-13 05:15:18 +01:00
Peter Steinberger
8748ce9f57 test: dedupe system run mock read 2026-05-13 05:14:13 +01:00
Peter Steinberger
7b86539be2 test: dedupe auto reply helper mock read 2026-05-13 05:13:15 +01:00
Peter Steinberger
89a8047e18 test: dedupe heartbeat ack mock read 2026-05-13 05:11:46 +01:00
Peter Steinberger
d377c78aa3 test: dedupe heartbeat subagent mock read 2026-05-13 05:10:39 +01:00
Peter Steinberger
875dffca9e test: dedupe heartbeat tool mock reads 2026-05-13 05:09:36 +01:00
NVIDIAN
ecc48c6d86 fix(config): reject auto-managed meta.lastTouched* paths in config set/unset (#80856)
Merged via squash.

Prepared head SHA: a574312f5c
Co-authored-by: ai-hpc <183861985+ai-hpc@users.noreply.github.com>
Co-authored-by: hxy91819 <8814856+hxy91819@users.noreply.github.com>
Reviewed-by: @hxy91819
2026-05-13 12:09:25 +08:00
Peter Steinberger
6a9e1a7aad test: dedupe tui shell mock read 2026-05-13 05:08:31 +01:00
Peter Steinberger
6912af6d83 test: dedupe proxy validation mock read 2026-05-13 05:07:36 +01:00
Peter Steinberger
4f7a6cebbc test: dedupe windows restart mock read 2026-05-13 05:06:40 +01:00
Peter Steinberger
401d2c6acc test: dedupe ssh config mock read 2026-05-13 05:05:47 +01:00
Peter Steinberger
ef44aa71d3 test: dedupe ssrf dispatcher mock read 2026-05-13 05:04:50 +01:00
Peter Steinberger
a6160b99d9 test: dedupe tui launch mock read 2026-05-13 05:03:53 +01:00
Peter Steinberger
b26db874a3 test: dedupe heartbeat reply mock read 2026-05-13 05:02:58 +01:00
Peter Steinberger
bc92f73ffb test: dedupe heartbeat prefix mock read 2026-05-13 05:02:01 +01:00
Peter Steinberger
02d2c1fee2 test: dedupe heartbeat typing mock read 2026-05-13 05:01:00 +01:00
Peter Steinberger
d7a6656913 test: dedupe transcript mock read 2026-05-13 04:58:43 +01:00
Peter Steinberger
ce712f503f test: dedupe run main mock read 2026-05-13 04:57:39 +01:00
Peter Steinberger
09116464b6 test: dedupe message lifecycle mock read 2026-05-13 04:56:24 +01:00
Peter Steinberger
69f7269e7d test: dedupe message send mock read 2026-05-13 04:55:34 +01:00
Peter Steinberger
abc2f57768 test: dedupe approval gateway mock read 2026-05-13 04:54:36 +01:00
Peter Steinberger
0cd0e57e9c test: dedupe npm root mock read 2026-05-13 04:53:42 +01:00
Peter Steinberger
e202231d56 test: dedupe security audit mock read 2026-05-13 04:52:25 +01:00
Peter Steinberger
65c056d7e2 test: dedupe sessions mock read 2026-05-13 04:51:24 +01:00
Peter Steinberger
45b0c92b3a test: dedupe plugin policy mock read 2026-05-13 04:50:28 +01:00
Peter Steinberger
5ca5c59de2 test: dedupe container target mock read 2026-05-13 04:49:36 +01:00
Peter Steinberger
20ec18807c test: dedupe batch http mock read 2026-05-13 04:48:40 +01:00
Peter Steinberger
06045b578a test: dedupe crestodian mock read 2026-05-13 04:47:44 +01:00
Peter Steinberger
23edebbaed test: dedupe audio transcode mock read 2026-05-13 04:46:31 +01:00
Peter Steinberger
f57c500034 test: dedupe custom theme mock reads 2026-05-13 04:45:33 +01:00
Peter Steinberger
b52a36d6e0 test: dedupe memory cli mock reads 2026-05-13 04:44:08 +01:00
Peter Steinberger
58cebd63c1 test: dedupe acp spawn mock reads 2026-05-13 04:43:00 +01:00
Peter Steinberger
53342ee5f3 test: dedupe live model switch mock reads 2026-05-13 04:42:04 +01:00
Peter Steinberger
6afe7f12b1 test: dedupe cli runner mock reads 2026-05-13 04:40:54 +01:00
Peter Steinberger
596f7a5cda test: dedupe pty fallback mock reads 2026-05-13 04:39:58 +01:00
Peter Steinberger
2cd936366b test: dedupe compaction summary mock reads 2026-05-13 04:39:08 +01:00
Peter Steinberger
36088884ac test: dedupe mcp transport mock reads 2026-05-13 04:38:19 +01:00
Peter Steinberger
3cfbc9e234 test: dedupe restart recovery mock reads 2026-05-13 04:36:36 +01:00
Peter Steinberger
c31874fe87 test: dedupe extra params mock reads 2026-05-13 04:35:34 +01:00
Peter Steinberger
6405977c03 test: dedupe context maintenance mock reads 2026-05-13 04:33:51 +01:00
Peter Steinberger
48e4a38655 test: dedupe prompt cache mock reads 2026-05-13 04:32:52 +01:00
Peter Steinberger
06d15572d3 test: dedupe runner cron mock reads 2026-05-13 04:31:58 +01:00
Peter Steinberger
6a14c838ca test: dedupe media handler mock reads 2026-05-13 04:30:55 +01:00
Peter Steinberger
92c84bbee4 test: dedupe acp lifecycle mock reads 2026-05-13 04:29:54 +01:00
Peter Steinberger
280d7931c1 test: dedupe memory dreaming mock reads 2026-05-13 04:28:50 +01:00
Peter Steinberger
5db2bf75c4 test: dedupe memory qmd mock reads 2026-05-13 04:27:38 +01:00
Peter Steinberger
f6d093e75e test: dedupe embedded subscribe flush mock reads 2026-05-13 04:25:31 +01:00
Peter Steinberger
9831b28dd7 test: dedupe before-tool-call e2e mock reads 2026-05-13 04:23:34 +01:00
Peter Steinberger
9eed27a9b8 test: dedupe before-tool-call mock reads 2026-05-13 04:21:55 +01:00
Peter Steinberger
47f31dd15d test: dedupe ui bootstrap mock reads 2026-05-13 04:20:35 +01:00
Peter Steinberger
d534c15b0a test: dedupe ui gateway mock reads 2026-05-13 04:19:08 +01:00
Peter Steinberger
936989a88b test: dedupe codex projector mock reads 2026-05-13 04:17:31 +01:00
Peter Steinberger
01fc684502 test: dedupe discord component mock reads 2026-05-13 04:16:05 +01:00
Peter Steinberger
32103aa3fd test: dedupe feishu doc mock reads 2026-05-13 04:14:38 +01:00
Peter Steinberger
da23f4572d test: dedupe matrix handler mock reads 2026-05-13 04:13:25 +01:00
Peter Steinberger
a08a38d4d9 test: dedupe mattermost monitor mock reads 2026-05-13 04:11:41 +01:00
Peter Steinberger
e566e817fb test: dedupe openai codex mock reads 2026-05-13 04:10:17 +01:00
Peter Steinberger
efc3e072a4 test: dedupe qqbot adapter mock reads 2026-05-13 04:09:05 +01:00
Peter Steinberger
a4514860e5 test: dedupe telegram command mock reads 2026-05-13 04:06:53 +01:00
Peter Steinberger
a5f5504b0d test: dedupe telegram monitor mock reads 2026-05-13 04:05:30 +01:00
pashpashpash
3688c47f1f Trust installed Codex for its private task runtime (#81206)
* fix(codex): trust installed codex task runtime

* fix(codex): keep private runtime alias packaged
2026-05-12 20:04:45 -07:00
Peter Steinberger
85eb8d47d4 test: dedupe vydra provider mock reads 2026-05-13 04:04:12 +01:00
Peter Steinberger
e1f24786f4 test: dedupe whatsapp login mock reads 2026-05-13 04:02:31 +01:00
Peter Steinberger
12f36b9a5a test: dedupe whatsapp allowlist mock reads 2026-05-13 04:01:19 +01:00
Peter Steinberger
a37c201776 test: dedupe whatsapp monitor mock reads 2026-05-13 03:59:43 +01:00
Rubén Cuevas
d4998d7b88 fix(plugins): retry npm alias override installs (#80539)
* fix(plugins): retry npm alias override installs

* fix(onboarding): space install retry warning

* fix(onboarding): shorten retry progress label

* docs(changelog): note npm alias install retry

---------

Co-authored-by: pashpashpash <nik@vault77.ai>
2026-05-12 19:58:21 -07:00
Peter Steinberger
38e1d68d7a test: dedupe discord process mock reads 2026-05-13 03:58:10 +01:00
Peter Steinberger
3375473e2b test: dedupe matrix cli mock reads 2026-05-13 03:56:49 +01:00
Peter Steinberger
b3260b1d15 test: dedupe telegram media mock reads 2026-05-13 03:55:27 +01:00
Peter Steinberger
889c1d7c15 test: dedupe whatsapp media mock reads 2026-05-13 03:54:10 +01:00
Peter Steinberger
eeecb48775 test: dedupe browser tool mock reads 2026-05-13 03:52:46 +01:00
Peter Steinberger
7159dab78d test: dedupe codex approval mock reads 2026-05-13 03:50:11 +01:00
Peter Steinberger
2edb8dede8 test: dedupe matrix send mock reads 2026-05-13 03:48:40 +01:00
Peter Steinberger
b8a27720f2 test: dedupe telegram gateway mock reads 2026-05-13 03:47:20 +01:00
Peter Steinberger
1f02abe381 fix(update): make pnpm preflight resolution deterministic 2026-05-13 03:46:33 +01:00
Peter Steinberger
f1ddaf46c7 ci: avoid pnpm prompts in live docker tests 2026-05-13 03:46:33 +01:00
Peter Steinberger
130b9bb2c1 test: dedupe browser cli mock reads 2026-05-13 03:45:26 +01:00
Peter Steinberger
ff7beea3da test: dedupe feishu routing mock reads 2026-05-13 03:43:41 +01:00
Peter Steinberger
cb613022ff test: dedupe telegram send mock reads 2026-05-13 03:42:22 +01:00
Peter Steinberger
4c663056d9 test: dedupe qa matrix mock reads 2026-05-13 03:40:17 +01:00
Peter Steinberger
6b77b8d978 test: dedupe discord voice mock reads 2026-05-13 03:37:28 +01:00
Peter Steinberger
a20d253819 test: dedupe active memory mock reads 2026-05-13 03:35:41 +01:00
Peter Steinberger
a06b735f32 test: dedupe provider fetch mock reads 2026-05-13 03:32:22 +01:00
Peter Steinberger
52ce64302f test: dedupe ssh spawn mock reads 2026-05-13 03:31:20 +01:00
Peter Steinberger
1296211c2e test: dedupe auto reply dispatch mock reads 2026-05-13 03:30:15 +01:00
Peter Steinberger
6b0b29fd04 test: dedupe reply media mock reads 2026-05-13 03:29:15 +01:00
Peter Steinberger
a6886d3fc4 test: dedupe durable delivery mock reads 2026-05-13 03:28:07 +01:00
Peter Steinberger
4ce9ff7845 test: dedupe exec policy mock reads 2026-05-13 03:26:58 +01:00
Peter Steinberger
d1ddb68d37 test: dedupe mcp cli mock reads 2026-05-13 03:25:53 +01:00
Peter Steinberger
91bae4baa5 test: dedupe nodes cli mock reads 2026-05-13 03:23:24 +01:00
Peter Steinberger
d8111ea65b test: dedupe setup cli mock reads 2026-05-13 03:21:50 +01:00
Peter Steinberger
48013bb259 test: dedupe qr cli mock reads 2026-05-13 03:20:26 +01:00
Peter Steinberger
00a01d1a39 test: dedupe security cli mock reads 2026-05-13 03:19:01 +01:00
Peter Steinberger
597c69036d test: dedupe cron retry mock reads 2026-05-13 03:17:40 +01:00
Peter Steinberger
9287aa5ef7 test: dedupe channel setup mock reads 2026-05-13 03:16:21 +01:00
Peter Steinberger
b2da3e0a02 test: dedupe embeddings http mock reads 2026-05-13 03:15:02 +01:00
Peter Steinberger
950831d6d1 test: dedupe gateway discovery mock reads 2026-05-13 03:13:55 +01:00
Marcus Castro
81a3de1d9d fix(whatsapp): drain debounced inbound before close (#81246)
* fix(whatsapp): drain debounced inbound before close

* docs(changelog): note WhatsApp debounce close drain
2026-05-12 23:13:38 -03:00
Peter Steinberger
ccf58b069d test: dedupe restart sentinel mock reads 2026-05-13 03:12:38 +01:00
Peter Steinberger
4f1549a6ae test: dedupe gateway reload mock reads 2026-05-13 03:11:19 +01:00
Peter Steinberger
cbf6d5cfe2 test: dedupe fetch guard mock reads 2026-05-13 03:08:34 +01:00
Peter Steinberger
4fdd71d186 test: dedupe transport ready mock reads 2026-05-13 03:07:27 +01:00
Peter Steinberger
74bbac994d test: dedupe git install mock reads 2026-05-13 03:06:23 +01:00
Peter Steinberger
661aa45eeb test: dedupe optional plugin tool mock reads 2026-05-13 03:05:15 +01:00
Peter Steinberger
fc09643aa2 test: dedupe tui command mock reads 2026-05-13 03:04:11 +01:00
Peter Steinberger
784b6cf2da test: dedupe dispatch config mock reads 2026-05-13 03:02:58 +01:00
WhatsSkiLL
e0f6f78b02 fix(gateway): clarify invalid config recovery hints
Closes #40652.

Thanks @JARVIS-Glasses.
2026-05-12 19:01:59 -07:00
Peter Steinberger
7cb596c807 test: dedupe model fallback mock reads 2026-05-13 03:01:37 +01:00
Peter Steinberger
b8bbe0e1e4 test: dedupe embedded reasoning mock reads 2026-05-13 02:59:52 +01:00
Peter Steinberger
46aa0ff9d0 test: dedupe embedded subscribe mock reads 2026-05-13 02:58:29 +01:00
Peter Steinberger
8f37126df7 test: dedupe session status mock reads 2026-05-13 02:57:13 +01:00
Peter Steinberger
919c8f1da5 test: dedupe models config mock reads 2026-05-13 02:56:04 +01:00
Peter Steinberger
191e9b68d7 test: dedupe compaction safeguard mock reads 2026-05-13 02:54:59 +01:00
Pavan Kumar Gondhi
a3fda2ada9 Limit hook CLI tool authority [AI] (#81065)
* fix: limit hook cli tool authority

* docs: add changelog entry for PR merge
2026-05-13 07:24:41 +05:30
Peter Steinberger
ac3aaad70c test: dedupe message tool mock reads 2026-05-13 02:53:44 +01:00
Peter Steinberger
6ace272a4b test: dedupe tts command mock reads 2026-05-13 02:52:35 +01:00
Peter Steinberger
9b4568c78f test: dedupe channel kernel mock reads 2026-05-13 02:51:21 +01:00
Pavan Kumar Gondhi
1c85eff9b1 Require admin scope for node device token management [AI] (#81067)
* fix: require admin for node device token management

* addressing review-skill

* addressing review-skill

* addressing review-skill

* addressing review-skill

* addressing claude review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-13 07:20:35 +05:30
Peter Steinberger
e2965b5f96 test: dedupe openresponses mock reads 2026-05-13 02:50:18 +01:00
Peter Steinberger
0e9ebe0a92 test: dedupe gateway agent mock reads 2026-05-13 02:49:13 +01:00
Peter Steinberger
dfd63a2145 test: dedupe gateway watch tmux mock reads 2026-05-13 02:48:11 +01:00
Peter Steinberger
cc6da043bd test: dedupe apns http2 mock reads 2026-05-13 02:47:01 +01:00
Pavan Kumar Gondhi
b7e0decf0c Restrict chat sender allowlist matching [AI] (#80898)
* fix: restrict chat sender allowlist matching

* fix: restrict chat sender allowlist matching

* addressing codex review

* fix: complete sender allowlist root cause

* addressing codex review

* addressing codex review

* fix: complete root-cause handling

* addressing review-skill

* addressing codex review

* addressing review-skill

* addressing codex review

* addressing codex review

* fix: complete chat sender allowlist handling

* addressing codex review

* fix: complete root-cause handling

* addressing codex review

* fix: complete root-cause handling

* addressing codex review

* fix: cover sender matcher conversation target opt-in

* addressing review-skill

* addressing codex review

* fix: require explicit chat target sender matching

* addressing review-skill

* addressing codex review

* addressing codex review

* fix: require explicit chat target sender matching

* addressing codex review

* fix: require explicit chat target sender matching

* addressing codex review

* addressing codex review

* fix: require explicit chat target sender matching

* docs: add changelog entry for PR merge
2026-05-13 07:16:27 +05:30
Peter Steinberger
e3a4280788 test: dedupe fetch auth mock reads 2026-05-13 02:44:01 +01:00
Peter Steinberger
73ae1decdf test: dedupe tts contract mock reads 2026-05-13 02:42:04 +01:00
Peter Steinberger
0adc4ed0e7 test: dedupe agent command delivery mock reads 2026-05-13 02:39:43 +01:00
Peter Steinberger
90ea70b63b test: dedupe reply tag mock reads 2026-05-13 02:38:21 +01:00
Peter Steinberger
50f38cc0de test: dedupe subagent announce mock reads 2026-05-13 02:36:59 +01:00
Peter Steinberger
f507f52e19 test: dedupe cron hook prompt reads 2026-05-13 02:35:37 +01:00
Peter Steinberger
a5668efb7a test: dedupe cron session identity mock reads 2026-05-13 02:34:11 +01:00
Peter Steinberger
f9b3733f77 test: dedupe chat abort authorization mock reads 2026-05-13 02:31:53 +01:00
Peter Steinberger
c456e6fa97 test: dedupe chat abort persistence mock reads 2026-05-13 02:30:26 +01:00
Peter Steinberger
e3916e2606 test: dedupe plugin provider mock reads 2026-05-13 02:28:33 +01:00
Peter Steinberger
d0b3b1e1a4 test: dedupe soft chunk reply reads 2026-05-13 02:26:28 +01:00
Peter Steinberger
b7741b6f8c test: dedupe model fallback mock reads 2026-05-13 02:25:06 +01:00
Peter Steinberger
f537b06e8d test: dedupe gateway tool mock reads 2026-05-13 02:23:20 +01:00
Peter Steinberger
4aedf91028 test: dedupe followup runner mock reads 2026-05-13 02:22:08 +01:00
Peter Steinberger
9307df225d test: dedupe chat directive mock reads 2026-05-13 02:20:46 +01:00
Peter Steinberger
e7f6dfa925 test: dedupe incomplete turn attempt reads 2026-05-13 02:18:43 +01:00
Peter Steinberger
e17e881653 test: dedupe gateway plugin mock reads 2026-05-13 02:17:03 +01:00
Peter Steinberger
a9f34bf1f5 test: dedupe config cli log payload reads 2026-05-13 02:15:39 +01:00
Peter Steinberger
5e44f53c5b test: dedupe gateway cron mock reads 2026-05-13 02:13:28 +01:00
Peter Steinberger
e64a9a0507 test: dedupe update cli mock reads 2026-05-13 02:11:06 +01:00
Peter Steinberger
caa7b8a81d test: dedupe media reply mock reads 2026-05-13 02:09:23 +01:00
Peter Steinberger
dd923d9752 test: clear command mock call at usage 2026-05-13 02:07:53 +01:00
Peter Steinberger
5ad3f7adaa test: dedupe command helper mock reads 2026-05-13 02:05:55 +01:00
Peter Steinberger
28b19f4c66 test: dedupe command mock call reads 2026-05-13 02:04:09 +01:00
Peter Steinberger
38bab38ce7 fix: normalize per-agent gemini config refs 2026-05-13 02:02:54 +01:00
Peter Steinberger
bd8e986bb2 test: dedupe doctor security mock read 2026-05-13 01:57:55 +01:00
Peter Steinberger
6014aa5688 test: dedupe channels config write mock read 2026-05-13 01:56:32 +01:00
Peter Steinberger
019dd6282e test: dedupe status json mock read 2026-05-13 01:55:06 +01:00
Peter Steinberger
b5290d0692 test: dedupe agents delete mock read 2026-05-13 01:53:17 +01:00
Peter Steinberger
45f0f4a5ea test: dedupe channel doctor mock read 2026-05-13 01:52:05 +01:00
Peter Steinberger
c36089c417 test: dedupe launchctl note mock read 2026-05-13 01:50:52 +01:00
Peter Steinberger
05ea6054e3 test: dedupe channels status mock read 2026-05-13 01:49:06 +01:00
Peter Steinberger
bf16038b5c test: dedupe models forward mock read 2026-05-13 01:47:52 +01:00
Peter Steinberger
367c600849 test: dedupe doctor memory mock reads 2026-05-13 01:46:13 +01:00
Peter Steinberger
068e6e0291 test: dedupe auth choice install mock read 2026-05-13 01:44:36 +01:00
Peter Steinberger
832ab4787c test: dedupe models status mock read 2026-05-13 01:43:24 +01:00
Peter Steinberger
60f53f5d58 test: dedupe models list mock read 2026-05-13 01:41:59 +01:00
Peter Steinberger
a32c2e6cf5 test: dedupe status report mock read 2026-05-13 01:40:19 +01:00
Peter Steinberger
856b3efeba test: dedupe empty allowlist mock read 2026-05-13 01:39:02 +01:00
Peter Steinberger
c2b46b1331 test: dedupe channels config mock read 2026-05-13 01:37:53 +01:00
Peter Steinberger
0904357eb9 test: dedupe auth choice provider mock read 2026-05-13 01:36:27 +01:00
Peter Steinberger
97c8944eeb test: dedupe dashboard links mock read 2026-05-13 01:35:25 +01:00
Peter Steinberger
02ddaafd99 test: dedupe local daemon mock read 2026-05-13 01:34:22 +01:00
Peter Steinberger
00c99972df test: dedupe channels logs mock read 2026-05-13 01:32:59 +01:00
Peter Steinberger
ccd51b40dd test: dedupe oauth tls mock read 2026-05-13 01:31:59 +01:00
Peter Steinberger
963207d265 test: dedupe bootstrap size mock read 2026-05-13 01:30:54 +01:00
Peter Steinberger
8504029d73 test: dedupe configure daemon mock read 2026-05-13 01:29:36 +01:00
Peter Steinberger
e92806278d test: dedupe local auth choice mock read 2026-05-13 01:28:37 +01:00
Peter Steinberger
74171908cb test: dedupe configure gateway mock read 2026-05-13 01:27:35 +01:00
Sarah Fortune
d06f0a0ee7 fix(install): don't abort install.ps1 when git writes to stderr (#80834)
PowerShell 7+ honors $ErrorActionPreference=Stop for native commands,
so git's normal progress line ("From https://...") on stderr during
`git pull --rebase` would turn into a terminating error and abort the
installer immediately after a fresh clone — before pnpm install/build
ever runs. The existing `2>$null` redirects the display but the error
record is still generated.

Wrap the git status / pull calls in try/catch so the pull stays
best-effort and the rest of the installer can proceed. Reproduced on
Windows 11 ARM under PowerShell 7.x with -InstallMethod git.
2026-05-12 17:26:30 -07:00
Peter Steinberger
31ea86bf7d test: dedupe agents identity mock read 2026-05-13 01:25:54 +01:00
Peter Steinberger
003782a521 test: dedupe channels list mock read 2026-05-13 01:24:51 +01:00
Peter Steinberger
3356aafe3a test: dedupe status json mock read 2026-05-13 01:23:49 +01:00
Peter Steinberger
532fea836b test: dedupe flows mock read 2026-05-13 01:22:28 +01:00
Peter Steinberger
ccb9c68487 test: dedupe sandbox mock read 2026-05-13 01:21:33 +01:00
Peter Steinberger
48eb4e39b2 test: dedupe api key mock read 2026-05-13 01:20:16 +01:00
Peter Steinberger
5f5a0cf916 test: dedupe models shared mock read 2026-05-13 01:19:16 +01:00
Peter Steinberger
945d46c2b7 test: dedupe daemon install mock read 2026-05-13 01:18:11 +01:00
Sarah Fortune
e7c9e84a42 feat(onboard): add --skip-hooks flag (#81220) 2026-05-12 17:17:26 -07:00
Peter Steinberger
373fb93693 test: dedupe status runtime mock read 2026-05-13 01:16:00 +01:00
Peter Steinberger
57863c6009 test: dedupe doctor claude mock read 2026-05-13 01:14:18 +01:00
sallyom
f65251d0ec docs: note tool result detail redaction 2026-05-12 20:13:26 -04:00
nimbleenigma
277eb16652 fix: redact persisted tool result details
Refresh PR #80444 on current upstream main.
2026-05-12 20:13:26 -04:00
Peter Steinberger
250c26d02c test: dedupe backup verify mock read 2026-05-13 01:12:49 +01:00
Peter Steinberger
bf92aa7bc0 test: dedupe doctor browser mock read 2026-05-13 01:11:45 +01:00
Peter Steinberger
c6249e4809 test: dedupe doctor transcript mock read 2026-05-13 01:10:22 +01:00
Peter Steinberger
fccee9485c test: dedupe status service mock read 2026-05-13 01:09:16 +01:00
Peter Steinberger
4b33ade05e test: dedupe doctor auth mock read 2026-05-13 01:08:06 +01:00
Peter Steinberger
cf77ad5025 test: dedupe backup mock read 2026-05-13 01:06:38 +01:00
Peter Steinberger
9147a53274 fix: normalize nested gemini preview config ids 2026-05-13 01:05:25 +01:00
Peter Steinberger
f8953d94bd test: dedupe nodes tool mock read 2026-05-13 01:01:32 +01:00
Peter Steinberger
b8c0edf91c test: dedupe gateway tool mock read 2026-05-13 00:59:30 +01:00
Peter Steinberger
6d631d3adf test: dedupe cron tool mock read 2026-05-13 00:58:26 +01:00
Peter Steinberger
93a81865f0 test: dedupe embedded subscribe warning read 2026-05-13 00:56:52 +01:00
Peter Steinberger
5147d2849f test: dedupe coding tools mock read 2026-05-13 00:55:45 +01:00
Peter Steinberger
8830527536 test: dedupe model catalog mock read 2026-05-13 00:54:38 +01:00
Peter Steinberger
30442d9e4e test: dedupe pi project settings mock read 2026-05-13 00:53:31 +01:00
sallyom
14a9bb98b7 fix(config-audit): guard scrub rename after temp write
Signed-off-by: sallyom <somalley@redhat.com>
2026-05-12 19:52:52 -04:00
YB0y
432b94989b fix(config-audit): scrub pre-redactor argv values from historical config-audit.jsonl entries (#80777)
PR #75095 added `redactConfigAuditArgv` so newly-written entries in
`~/.openclaw/logs/config-audit.jsonl` mask token-shaped values, but the
audit log has no rotation, retention, or one-shot scrub. Users who ran
`openclaw config set <path> <secret-value>` between commit `748d6821d2`
(audit added 2026-02-14) and `a853c5e8c2` (redactor merged 2026-05-01)
still have plaintext Slack, Telegram, gateway, etc. tokens sitting in
`config-audit.jsonl` at rest after upgrading.

Add `scrubConfigAuditLog` in `src/config/io.audit.ts` that reads the
audit log, rewrites every record's `argv` / `execArgv` fields through
the existing forward redactor, and writes the file back atomically
(`*.scrub.tmp` + rename, mode 0o600). Idempotent — already-masked
entries pass through unchanged. Malformed lines are preserved verbatim
and counted as `skipped` so the scrub never destroys forensic content
it cannot understand. Concurrent-append guard: re-stat the audit log
immediately before rename and abort (no on-disk change) if the file
grew during the scrub, so a parallel appendConfigAuditRecord call is
never overwritten by the rename swap. Wire into the doctor health flow
as `runConfigAuditScrubHealth`: scan-only on a normal `openclaw doctor`
(prints the count and suggests `--fix`); rewrite atomically on
`openclaw doctor --fix` with a "rotate any credentials" note; print a
"stop the gateway and rerun" hint on the abort path. No plaintext
backup file is produced; file mode and parent dir mode are preserved.

Per repo CLAUDE.md ("Legacy config repair: doctor/fix paths, not
startup/load-time core migrations") the scrub is gated to `--fix`
and runs only when the user opts in.

Verified:
- pnpm install --frozen-lockfile
- pnpm test src/config/io.audit.test.ts
- pnpm test src/commands/doctor-config-flow.test.ts
- pnpm tsgo:core:test
- pnpm exec oxfmt --check --threads=1 src/config/io.audit.ts src/config/io.audit.test.ts src/commands/doctor-config-audit-scrub.ts src/flows/doctor-health-contributions.ts

Closes #80777
2026-05-12 19:52:52 -04:00
Peter Steinberger
9ae29c8bb1 test: dedupe pi tools schema mock read 2026-05-13 00:52:27 +01:00
Sarah Fortune
48529f1a96 feat(onboard): offer codex migration after harness install (#81192)
Add a post-install seam so the wizard can prompt the user to import their
existing Codex CLI state (skills, archived config/hooks, advisory cached
plugins) through the existing `openclaw migrate codex` flow once the
harness plugin is in place. Fires on both fresh installs and repair runs;
the user can decline at any time.

Trigger sites, both routing through one helper:

- src/plugins/provider-auth-choice.ts: after
  `ensureCodexRuntimePluginForModelSelection` reports `installed: true`,
  dynamically import `offerPostInstallMigrations` and call it before the
  wizard moves on.
- src/commands/onboard-non-interactive/local/auth-choice.plugin-providers.ts:
  same call shape with `nonInteractive: true`, so the helper emits a hint
  line only and never mutates state.

Helper (src/wizard/setup.post-install-migration.ts) is generic, not
Codex-hardcoded — it resolves migration providers via the manifest
`migrationProviders` contract, filters to providers owned by plugins the
caller flags as installed in this onboarding step, runs `provider.detect`,
and on TTY hands accepted runs to `migrateDefaultCommand`. All detect,
prompt, and migrate failures are swallowed so onboarding never aborts on
this optional offer.

Also harden the Codex app-server subprocess lifecycle now that `detect()`
runs from a hotter onboarding path: isolate the plugin-install
`plugin/read` call (extensions/codex/src/migration/apply.ts) and have the
isolated request wait for child exit with a SIGKILL fallback
(extensions/codex/src/app-server/request.ts) so parents are not held open
by an orphaned codex binary.

Tests:

- src/wizard/setup.post-install-migration.test.ts (new, 10 cases)
- src/commands/onboard-non-interactive/local/auth-choice.plugin-providers.test.ts
  extended with hint-call assertions and a not-required-no-offer case.
2026-05-12 16:51:27 -07:00
Peter Steinberger
37237a5129 test: dedupe auth profile mock read 2026-05-13 00:50:55 +01:00
Peter Steinberger
ce21937c97 test: dedupe cli helper mock read 2026-05-13 00:49:56 +01:00
Peter Steinberger
20e2206eac test: dedupe exec followup mock reads 2026-05-13 00:48:42 +01:00
Peter Steinberger
21a46f48d2 test: dedupe pi tool adapter log reads 2026-05-13 00:47:32 +01:00
Peter Steinberger
1ade7a53af test: dedupe cron scope mock reads 2026-05-13 00:43:49 +01:00
Peter Steinberger
f2935ca3ec test: dedupe sandbox manage mock reads 2026-05-13 00:41:53 +01:00
Peter Steinberger
a0833ed20b test: dedupe skills install mock reads 2026-05-13 00:40:42 +01:00
Peter Steinberger
9c3e08b346 test: dedupe subagent announce mock reads 2026-05-13 00:39:10 +01:00
Peter Steinberger
7964a49378 test: dedupe subagent spawn mock reads 2026-05-13 00:37:52 +01:00
Peter Steinberger
5051024366 test: dedupe subagent thread mock reads 2026-05-13 00:36:47 +01:00
Peter Steinberger
b540882703 test: dedupe music generate mock reads 2026-05-13 00:35:16 +01:00
Peter Steinberger
3c27f7428b test: dedupe cf markdown mock reads 2026-05-13 00:33:58 +01:00
Peter Steinberger
3436fc2f72 test: dedupe web search mock reads 2026-05-13 00:32:48 +01:00
Peter Steinberger
caa4cf7f0f test: dedupe web fetch mock reads 2026-05-13 00:31:44 +01:00
Peter Steinberger
0e4f2c53c7 test: dedupe command control mock reads 2026-05-13 00:30:24 +01:00
Peter Steinberger
df7a71afc6 test: dedupe agent runner execution mock reads 2026-05-13 00:29:14 +01:00
Peter Steinberger
b3cc2c17fc test: dedupe secret resolution mock reads 2026-05-13 00:27:20 +01:00
Peter Steinberger
a7b9bce139 test: dedupe acp command mock reads 2026-05-13 00:25:54 +01:00
Peter Steinberger
33419d7d1b test: dedupe commands core mock reads 2026-05-13 00:21:44 +01:00
Peter Steinberger
ba625e2cff test: dedupe models command mock reads 2026-05-13 00:18:15 +01:00
Peter Steinberger
f2b560ff5d test: dedupe session restart mock reads 2026-05-13 00:16:04 +01:00
Peter Steinberger
b46e5ae60c test: dedupe session usage mock reads 2026-05-13 00:13:54 +01:00
Peter Steinberger
0b165f708f test: dedupe subagents focus mock reads 2026-05-13 00:11:14 +01:00
Peter Steinberger
65d801cf8a test: dedupe reply dispatch mock reads 2026-05-13 00:09:13 +01:00
Peter Steinberger
e15cce76c7 test: dedupe get reply mock reads 2026-05-13 00:06:48 +01:00
Peter Steinberger
73e47fc6a9 test: dedupe session lifecycle mock reads 2026-05-13 00:04:44 +01:00
Peter Steinberger
f96cfeeb73 test: dedupe gateway cli mock reads 2026-05-13 00:02:45 +01:00
Peter Steinberger
86c4482c58 test: dedupe message thread mock reads 2026-05-13 00:01:15 +01:00
Peter Steinberger
8998e536fa test: dedupe cli route mock reads 2026-05-12 23:59:23 +01:00
Peter Steinberger
1cd736afd2 test: dedupe update cli mock reads 2026-05-12 23:57:58 +01:00
Peter Steinberger
d3099ff0de test: dedupe agent acp mock reads 2026-05-12 23:55:54 +01:00
Peter Steinberger
73907fdf5c test: dedupe channel setup mock reads 2026-05-12 23:54:01 +01:00
Peter Steinberger
4cd356fa2a test: dedupe channels remove mock reads 2026-05-12 23:52:31 +01:00
Peter Steinberger
87f5fb3ab2 test: dedupe doctor startup note mock reads 2026-05-12 23:51:02 +01:00
Peter Steinberger
6676be413e test: dedupe doctor sandbox mock reads 2026-05-12 23:49:46 +01:00
Peter Steinberger
6769b37c36 test: dedupe doctor workspace mock reads 2026-05-12 23:48:32 +01:00
Peter Steinberger
19599c268c test: dedupe doctor repair mock reads 2026-05-12 23:47:20 +01:00
Peter Steinberger
870e6f0ace test: dedupe doctor migration mock reads 2026-05-12 23:45:42 +01:00
Peter Steinberger
c4d4e5d315 test: dedupe message command mock reads 2026-05-12 23:44:26 +01:00
Peter Steinberger
51886077bd test: dedupe sessions cleanup mock reads 2026-05-12 23:43:09 +01:00
Peter Steinberger
2f21db25b0 test: dedupe status fast json mock reads 2026-05-12 23:41:39 +01:00
Peter Steinberger
afe2e07181 test: dedupe status scan mock reads 2026-05-12 23:40:29 +01:00
Peter Steinberger
b3c74c10c9 test: dedupe cron delivery mock reads 2026-05-12 23:39:09 +01:00
Peter Steinberger
1974e6f7b5 test: dedupe cron heartbeat mock reads 2026-05-12 23:37:55 +01:00
Peter Steinberger
b9d3843aff test: dedupe chat attachment mock reads 2026-05-12 23:36:35 +01:00
Peter Steinberger
73abe9e98a test: dedupe control ui auto root mock reads 2026-05-12 23:35:23 +01:00
Peter Steinberger
8a6c18a08a test: dedupe control ui http mock reads 2026-05-12 23:32:42 +01:00
Peter Steinberger
3779c10f27 test: dedupe managed image mock reads 2026-05-12 23:30:44 +01:00
Peter Steinberger
37d01fdd4a test: dedupe server channels mock reads 2026-05-12 23:29:04 +01:00
Peter Steinberger
55aadd2d48 test: dedupe server close mock reads 2026-05-12 23:27:26 +01:00
Peter Steinberger
85f89442c5 test: dedupe agent create event mock reads 2026-05-12 23:25:35 +01:00
Peter Steinberger
c34559d91d test: dedupe channels status mock reads 2026-05-12 23:24:01 +01:00
Kevin Lin
bc44f3824f fix: improve Codex migration selector enter 2026-05-12 15:23:28 -07:00
Peter Steinberger
ec7962fdc3 test: dedupe diagnostics mock reads 2026-05-12 23:21:48 +01:00
Peter Steinberger
096a331ab2 test: dedupe doctor response mock reads 2026-05-12 23:20:16 +01:00
Peter Steinberger
29ba6f8312 test: dedupe nodes pending mock reads 2026-05-12 23:18:10 +01:00
Peter Steinberger
fd79013b8f test: dedupe plugin approval mock reads 2026-05-12 23:15:29 +01:00
Peter Steinberger
ed3df9cbb8 test: dedupe tools catalog mock reads 2026-05-12 23:13:32 +01:00
Peter Steinberger
5ab28bf164 test: dedupe restart sentinel mock reads 2026-05-12 23:11:46 +01:00
Peter Steinberger
d79d6b2e5c test: dedupe startup log mock reads 2026-05-12 23:10:01 +01:00
Peter Steinberger
2c69c41643 test: dedupe sessions list mock reads 2026-05-12 23:08:25 +01:00
Peter Steinberger
b3ee777664 test: dedupe ws connection mock reads 2026-05-12 23:06:37 +01:00
Peter Steinberger
0768b4f2ad test: dedupe tools invoke mock reads 2026-05-12 23:05:20 +01:00
Peter Steinberger
e8a8675128 test: dedupe install flow mock reads 2026-05-12 23:03:59 +01:00
Peter Steinberger
fc94d7541c test: dedupe fetch guard mock reads 2026-05-12 23:02:32 +01:00
Peter Steinberger
c6ebc1d7e8 test: dedupe apns relay mock reads 2026-05-12 23:00:48 +01:00
Peter Steinberger
a3ff7aa02c test: dedupe run node mock reads 2026-05-12 22:59:34 +01:00
Peter Steinberger
3eaefda824 test: dedupe runtime llm mock reads 2026-05-12 22:57:53 +01:00
Peter Steinberger
d42b3c2b4a test: dedupe web fetch provider mock reads 2026-05-12 22:56:41 +01:00
Peter Steinberger
c9d7ba8690 test: dedupe wired hook error mock reads 2026-05-12 22:55:08 +01:00
Peter Steinberger
413580bef2 test: dedupe qa lab live gateway mock reads 2026-05-12 22:53:58 +01:00
Peter Steinberger
ec2944dc82 test: dedupe qa lab agent process mock reads 2026-05-12 22:52:33 +01:00
Peter Steinberger
65c5c3faf8 test: dedupe git install mock reads 2026-05-12 22:50:20 +01:00
Peter Steinberger
cf1987bbe9 test: dedupe plugin install mock reads 2026-05-12 22:48:58 +01:00
Peter Steinberger
6bd565d9f2 test: dedupe provider runtime mock reads 2026-05-12 22:46:49 +01:00
Peter Steinberger
96b2ef812d test: dedupe qa runner mock reads 2026-05-12 22:44:33 +01:00
Peter Steinberger
af8f3552e4 test: dedupe session maintenance mock reads 2026-05-12 22:42:15 +01:00
Peter Steinberger
9531befca5 test: dedupe heartbeat override mock reads 2026-05-12 22:40:54 +01:00
Peter Steinberger
f469cc69d3 test: dedupe approval handler mock reads 2026-05-12 22:39:17 +01:00
Solomon Neas
48af99ed30 fix(agents/harness): pass tool results through tool-result middleware safely (#78743)
Skip tool-result middleware validation when no handler is registered, and
sanitize incoming tool result `details` (functions, symbols, bigints,
cycles, oversized payloads) before middleware sees them. Tool emitters
legitimately produce raw dependency payloads on `details`, and the
harness owes any registered middleware a JSON-safe view of that payload;
otherwise a no-op middleware (e.g. bundled tokenjuice on the pi runtime)
causes the validator to reject every tool result and silently substitute
a failure sentinel, dropping outbound Discord messages, exec output,
cron results, and any other tool whose payload carries non-serializable
values.
2026-05-12 14:37:06 -07:00
Peter Steinberger
75a2e959b2 test: dedupe sessions thinking mock reads 2026-05-12 22:36:44 +01:00
Edward Abrams
b247b1432f fix(heartbeat): multi-agent cadence — parallel broadcast, per-agent busy check, prompt assembly, connect-timeout, doctor warning (#80470)
* fix(heartbeat): unblock beads cadence — parallel broadcast, agent-scoped busy check, full HEARTBEAT.md prompt, connect-timeout, doctor warning

* docs(changelog): note heartbeat cadence fixes

* fix(heartbeat): address review feedback

* fix(heartbeat): append HEARTBEAT.md directives to commitment-only task dispatch (review feedback)

* docs(changelog): extend heartbeat fix entry — commitment-only task dispatch path (review feedback)

* fix(heartbeat): clear connect timer on synchronous baseFn throw (review feedback)

When the provider stream function passed to streamWithIdleTimeout throws

synchronously during setup, the connect watchdog timer was left armed

and could fire onIdleTimeout later with a stale error, keeping the

process open past the real failure. Wrap the synchronous baseFn(...)

invocation in a try/catch that clears the connect timer before

rethrowing, and add a regression test that asserts onIdleTimeout is

not invoked after the synchronous throw.

* docs(changelog): note round-4 heartbeat fix (review feedback)

Bump the heartbeat fixes list from six to seven and document the

synchronous-baseFn-throw connect-timer cleanup added in the prior

commit.

* fix(heartbeat): honor omitted doctor target (review feedback)

* fix(heartbeat): merge doctor heartbeat defaults (review feedback)

Teach the heartbeat session-target doctor warning to enumerate the same agents as the runtime heartbeat runner and merge agents.defaults.heartbeat with per-agent overrides before checking pinned sessions.

Add regression coverage for default-only heartbeat.session pins and explicit agent heartbeat entries that inherit the default session.

Validation:
- pnpm test src/commands/doctor-heartbeat-session-target.test.ts
- pnpm tsgo:core
- pnpm tsgo:core:test
- pnpm config:schema:check
- pnpm exec oxlint src/commands/doctor-heartbeat-session-target.ts src/commands/doctor-heartbeat-session-target.test.ts
- pnpm exec oxfmt --check src/commands/doctor-heartbeat-session-target.ts src/commands/doctor-heartbeat-session-target.test.ts
- git diff --check

Beads: openclaw-8zp

* test(heartbeat): avoid redundant doctor assertion (review feedback)

The CI lint shard flags the non-null assertion in the heartbeat doctor regression test. Keep the same test setup while using an explicit guard so the test still narrows the fixture before mutating the heartbeat entry.

Validation:
- pnpm exec oxlint src/commands/doctor-heartbeat-session-target.test.ts
- pnpm test src/commands/doctor-heartbeat-session-target.test.ts
- pnpm tsgo:core:test
- git diff --check

Beads: openclaw-8zp

* docs(config): refresh baseline after heartbeat branch update

* fix(heartbeat): narrow doctor session warnings (review feedback)
2026-05-12 14:36:25 -07:00
Peter Steinberger
aef80a2940 test: dedupe gateway startup mock reads 2026-05-12 22:35:08 +01:00
Peter Steinberger
ae9b7041ef test: dedupe gateway push mock reads 2026-05-12 22:33:51 +01:00
Peter Steinberger
041906e2d5 test: dedupe models auth-status mock reads 2026-05-12 22:29:35 +01:00
Peter Steinberger
efb404b14f test: dedupe agents mutate mock reads 2026-05-12 22:27:00 +01:00
Peter Steinberger
2d4ac9a7f5 test: dedupe gateway aux mock reads 2026-05-12 22:24:34 +01:00
Peter Steinberger
de8022ba0e test: dedupe chat abort mock reads 2026-05-12 22:21:48 +01:00
Peter Steinberger
0428a6dd6f test: dedupe status scan mock reads 2026-05-12 22:20:02 +01:00
Shakker
67ead6ec0e test: payload error text output 2026-05-12 22:19:49 +01:00
Shakker
73723368b8 test: loop compaction log output 2026-05-12 22:19:14 +01:00
Shakker
d1c2ea0cba test: alert incomplete turn warnings 2026-05-12 22:18:39 +01:00
Shakker
369d252317 test: maintain context event output 2026-05-12 22:17:51 +01:00
Shakker
ed1d2db3da test: emit fs bridge script output 2026-05-12 22:17:25 +01:00
Peter Steinberger
46bd83498e test: dedupe models scan mock reads 2026-05-12 22:17:00 +01:00
Shakker
482a05a542 test: hide gh config home hint 2026-05-12 22:16:46 +01:00
Shakker
a5912b92f7 test: quarantine dangerous skill warnings 2026-05-12 22:16:02 +01:00
Shakker
4754b585f4 test: deliver command error output 2026-05-12 22:15:27 +01:00
Shakker
342d697276 test: single default account warning output 2026-05-12 22:14:59 +01:00
Peter Steinberger
8b6328d791 test: dedupe provider catalog mock reads 2026-05-12 22:14:50 +01:00
Shakker
6630766e7e test: disambiguate acp log output 2026-05-12 22:14:11 +01:00
Shakker
71d2e41bb0 test: bundle daemon secret warnings 2026-05-12 22:13:20 +01:00
Peter Steinberger
daffccddb6 test: dedupe doctor locks mock reads 2026-05-12 22:13:00 +01:00
Shakker
bb10e2b22d test: stringify daemon install warnings 2026-05-12 22:12:33 +01:00
Shakker
3653a231cc test: fuse auth choice error output 2026-05-12 22:12:04 +01:00
Shakker
a0f5cac723 test: dedicate gh config hint output 2026-05-12 22:11:35 +01:00
Peter Steinberger
77fb105aad test: dedupe configure wizard mock reads 2026-05-12 22:11:16 +01:00
Shakker
f9c87de73f test: condense gateway mismatch notes 2026-05-12 22:10:56 +01:00
Shakker
736b8c676b test: coalesce capability cli errors 2026-05-12 22:10:25 +01:00
Shakker
c4d26b9e0c test: compress plugin uninstall logs 2026-05-12 22:10:00 +01:00
Shakker
3cfcaf80d0 test: unify daemon status log assertions 2026-05-12 22:09:35 +01:00
Shakker
6e8d0605c3 test: concatenate cron list logs 2026-05-12 22:08:58 +01:00
Peter Steinberger
b51a7cb35e test: dedupe channel setup mock reads 2026-05-12 22:08:43 +01:00
Shakker
171d3e4fa2 test: assemble sandbox command output 2026-05-12 22:08:23 +01:00
Shakker
102cdd8d32 test: aggregate completion timeout logs 2026-05-12 22:07:47 +01:00
Solomon Neas
314903417f fix(memory-core): prevent staged dream candidates from leaking into MEMORY.md (#68774)
* fix(memory-core): prevent staged dream candidates from leaking into MEMORY.md

* fix(memory-core): correct PromotionComponents shape in dream-fence test fixture
2026-05-12 14:07:43 -07:00
Peter Steinberger
706699bd24 test: dedupe agents bind mock reads 2026-05-12 22:06:56 +01:00
Shakker
e156b4299c test: token gateway install warnings 2026-05-12 22:05:36 +01:00
Peter Steinberger
fd3f654f20 test: dedupe cli program mock reads 2026-05-12 22:05:30 +01:00
Shakker
6d91d60615 test: onboard search provider notes 2026-05-12 22:04:49 +01:00
Shakker
881878da39 test: spare state integrity files 2026-05-12 22:03:54 +01:00
Peter Steinberger
4472066237 test: dedupe gateway cli mock reads 2026-05-12 22:03:46 +01:00
Shakker
726ecc4987 test: prompt auth choice messages 2026-05-12 22:02:49 +01:00
Shakker
e6c09b90cb test: fetch claude usage urls 2026-05-12 22:02:20 +01:00
Peter Steinberger
a8dd5653ee test: dedupe exec approvals cli mock reads 2026-05-12 22:02:03 +01:00
Shakker
5959a99646 test: queue outbound log text 2026-05-12 22:01:40 +01:00
Shakker
201dd735a0 test: log diagnostic messages 2026-05-12 22:00:59 +01:00
Peter Steinberger
0d4f4bab94 test: dedupe config cli mock reads 2026-05-12 22:00:36 +01:00
Shakker
d4c9aaf53a test: image agent log filenames 2026-05-12 22:00:18 +01:00
Shakker
c0f2e20660 test: hook gateway event text 2026-05-12 21:59:43 +01:00
Shakker
ac3f06fd4f test: rebase update runner commands 2026-05-12 21:59:11 +01:00
Peter Steinberger
d1e53c9488 test: dedupe acp cli mock reads 2026-05-12 21:58:47 +01:00
Shakker
4fd15fcce2 test: ping health snapshot urls 2026-05-12 21:58:35 +01:00
y471823206
3b9796ce9b Handle generic provider internal errors (#49401)
Merged via squash.

Prepared head SHA: 492caa49a9
Co-authored-by: y471823206 <2311651347@qq.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-12 23:58:27 +03:00
Shakker
2ed2fbb55d test: service gateway doctor notes 2026-05-12 21:57:56 +01:00
Peter Steinberger
87d8545c97 test: dedupe media get-reply mock reads 2026-05-12 21:57:18 +01:00
Shakker
ed20e5e10c test: present command output text 2026-05-12 21:57:00 +01:00
Shakker
bf9fd2cfcd test: secret gateway warning text 2026-05-12 21:55:55 +01:00
Peter Steinberger
f3b5dc80f9 test: dedupe agent runner misc mock reads 2026-05-12 21:55:29 +01:00
Shakker
168bb4fac8 test: note wizard finalize calls 2026-05-12 21:55:01 +01:00
Shakker
71cdb6ab9a test: display cli output text 2026-05-12 21:54:12 +01:00
Shakker
016852186d test: observe config warning text 2026-05-12 21:53:17 +01:00
Shakker
9ff2627b7d test: squelch signal client logs 2026-05-12 21:52:38 +01:00
Shakker
c80152eadd test: canonicalise plugin discovery paths 2026-05-12 21:52:03 +01:00
Peter Steinberger
712ceabb40 test: dedupe agent runner memory mock reads 2026-05-12 21:51:44 +01:00
Shakker
559a744594 test: offer slack monitor text 2026-05-12 21:50:13 +01:00
Shakker
cee32280c6 test: weave matrix message assertions 2026-05-12 21:49:38 +01:00
Peter Steinberger
8792341cf6 test: dedupe trigger handling mock reads 2026-05-12 21:49:26 +01:00
Shakker
9456cc850a test: signal plugin warning text 2026-05-12 21:48:49 +01:00
Shakker
8d5623acc8 test: search tui no matches output 2026-05-12 21:48:07 +01:00
Shakker
f7646f9fde test: shutter browser tab cleanup urls 2026-05-12 21:47:37 +01:00
Peter Steinberger
98ca0858f4 test: dedupe web guarded fetch mock reads 2026-05-12 21:47:12 +01:00
Shakker
f8ceffde7c test: watch memory path assertions 2026-05-12 21:46:57 +01:00
Shakker
9656cd365b test: erase discord progress labels 2026-05-12 21:46:17 +01:00
Shakker
c716a30a58 test: block discord picker nav ids 2026-05-12 21:45:49 +01:00
Peter Steinberger
1fe4e9a8f0 test: dedupe video tool mock reads 2026-05-12 21:45:39 +01:00
Shakker
ad882f681d test: hush discord provider logs 2026-05-12 21:45:04 +01:00
Shakker
5396510370 test: point media wav argument 2026-05-12 21:43:55 +01:00
Peter Steinberger
9be1be8f1e test: dedupe sessions send a2a mock reads 2026-05-12 21:43:49 +01:00
Shakker
693c775a7f test: tag provider unit assertions 2026-05-12 21:42:48 +01:00
Peter Steinberger
1725b4ae49 test: dedupe workspace skills warning mock reads 2026-05-12 21:42:02 +01:00
Shakker
40b3236415 test: probe qa lab message snapshots 2026-05-12 21:41:42 +01:00
Shakker
8930897220 test: fasten active memory log lines 2026-05-12 21:40:48 +01:00
Kevin Lin
233d65f09d docs: split plugin docs navigation
Split plugin docs navigation into reader-intent groups.
2026-05-12 13:40:12 -07:00
Peter Steinberger
d71a2427c0 test: dedupe skills install command mock reads 2026-05-12 21:40:00 +01:00
Shakker
05c83c7bd4 test: steady whatsapp status assertions 2026-05-12 21:38:32 +01:00
Peter Steinberger
22f6be52ee test: dedupe provider transport policy mock reads 2026-05-12 21:38:21 +01:00
Shakker
6890ef4952 test: reserve telegram fallback assertions 2026-05-12 21:37:25 +01:00
Peter Steinberger
4ef0d45a91 test: dedupe pi subscribe tool result mock reads 2026-05-12 21:36:45 +01:00
Shakker
2f306546ab test: cradle memory dreaming assertions 2026-05-12 21:36:21 +01:00
Shakker
22235e85de test: caption feishu streaming updates 2026-05-12 21:35:36 +01:00
Peter Steinberger
9cdb59ec4f test: dedupe pi message handler mock reads 2026-05-12 21:35:10 +01:00
Shakker
97a991d037 test: screen ollama setup request probes 2026-05-12 21:34:42 +01:00
Peter Steinberger
a330cba9f8 test: dedupe pi compaction log mock reads 2026-05-12 21:33:42 +01:00
Shakker
f0c016c212 test: dodge msteams graph shares 2026-05-12 21:32:50 +01:00
Shakker
b97d07683a test: heal matrix doctor changes 2026-05-12 21:32:17 +01:00
Peter Steinberger
05a2fed3b7 test: dedupe pi usage reporting mock reads 2026-05-12 21:32:14 +01:00
Shakker
c90635d023 test: vault dreaming repair archives 2026-05-12 21:31:40 +01:00
Shakker
2eba3dabb7 test: reject slack download image content 2026-05-12 21:31:03 +01:00
Peter Steinberger
188bbe92e5 test: dedupe pi failover warning mock reads 2026-05-12 21:30:50 +01:00
Shakker
178a50e017 test: triage telegram status issues 2026-05-12 21:30:11 +01:00
Shakker
70817ed5fa test: locate signal config issues 2026-05-12 21:29:39 +01:00
Peter Steinberger
5dd5dc3bcc test: dedupe embedded pi runner mock reads 2026-05-12 21:29:25 +01:00
Shakker
b5cb5fa711 test: score memory wiki lint codes 2026-05-12 21:28:56 +01:00
Shakker
c1bfc7b3de test: deny googlechat body reads 2026-05-12 21:28:20 +01:00
Shakker
a76bebd2e6 test: etch discord status patches 2026-05-12 21:27:50 +01:00
Peter Steinberger
95e9b87d69 test: dedupe pi lsp windows spawn mock reads 2026-05-12 21:27:30 +01:00
Shakker
5c56ac7efd test: advertise bonjour warning checks 2026-05-12 21:26:42 +01:00
Peter Steinberger
d286e16a37 test: dedupe browser plugin tools mock reads 2026-05-12 21:26:05 +01:00
Shakker
4cfbfc73e0 test: splice matrix notice bodies 2026-05-12 21:25:33 +01:00
Shakker
1b645b21fc test: joiner synology warning checks 2026-05-12 21:25:03 +01:00
Shakker
dbf5b213af test: mute telegram account warning scan 2026-05-12 21:24:26 +01:00
Peter Steinberger
4091be857d test: dedupe implicit provider discovery mock reads 2026-05-12 21:24:07 +01:00
Shakker
d20ba302f8 test: partition bundled entry prefixes 2026-05-12 21:23:47 +01:00
Kevin Lin
eba73e593a build(canvas): stop tracking a2ui bundle hash (#81141) 2026-05-12 13:23:12 -07:00
Shakker
fd8ba6ae63 test: survey slack message schema props 2026-05-12 21:22:27 +01:00
Peter Steinberger
8f4941fd12 test: dedupe model catalog visibility mock reads 2026-05-12 21:22:09 +01:00
Shakker
2b2d696f89 test: vet telegram markdown chunks 2026-05-12 21:21:46 +01:00
Shakker
7fa771b665 test: ground memory lancedb hook checks 2026-05-12 21:21:01 +01:00
Peter Steinberger
db529f7517 test: dedupe cli runner supervisor capture mock reads 2026-05-12 21:20:54 +01:00
Shakker
0659780b21 test: sift openai catalog ids 2026-05-12 21:19:44 +01:00
Peter Steinberger
b36b0de04e test: dedupe bash exec runtime mock reads 2026-05-12 21:19:36 +01:00
Shakker
b7afe26a54 test: surface plugin registry diagnostics 2026-05-12 21:18:39 +01:00
Peter Steinberger
f3a03e1870 test: dedupe acp spawn mock reads 2026-05-12 21:18:20 +01:00
Shakker
33e5f29d0a test: bar codex computer use setup calls 2026-05-12 21:17:56 +01:00
Shakker
97e44aca75 test: recount codex plugin refresh calls 2026-05-12 21:17:19 +01:00
Peter Steinberger
346cc29fc2 test: dedupe acp spawn parent stream mock reads 2026-05-12 21:16:41 +01:00
Shakker
650b145686 test: delineate acp spawn relay calls 2026-05-12 21:16:10 +01:00
Shakker
fed2b9f132 test: stipulate hermes migration warnings 2026-05-12 21:15:01 +01:00
Shakker
bebb36caa5 test: affirm codex native auth calls 2026-05-12 21:13:33 +01:00
Peter Steinberger
ad1947732d test: dedupe signal container fetch reads 2026-05-12 21:13:22 +01:00
Shakker
8cc5870b49 test: sharpen codex migration warnings 2026-05-12 21:12:27 +01:00
Peter Steinberger
4b81881700 test: dedupe qa channel inbound mock reads 2026-05-12 21:11:05 +01:00
Peter Steinberger
86bcd179a7 test: dedupe openai realtime keychain reads 2026-05-12 21:09:35 +01:00
Shakker
6c44a6b21f test: elide run main null guard 2026-05-12 21:07:14 +01:00
Peter Steinberger
2f33554ed4 test: dedupe mattermost slash log reads 2026-05-12 21:07:04 +01:00
Shakker
116282a2c0 test: summon sandbox docker create 2026-05-12 21:05:44 +01:00
Peter Steinberger
c299249b4f test: dedupe matrix media failure mock reads 2026-05-12 21:05:11 +01:00
Shakker
75001adc7e test: carry matrix chunk config 2026-05-12 21:04:17 +01:00
Peter Steinberger
fd75588190 test: dedupe matrix profile mock reads 2026-05-12 21:03:11 +01:00
Shakker
cd98df601c test: compel uninstall plan params 2026-05-12 21:02:16 +01:00
Kevin Lin
9ff5250792 fix(codex): gate migration on app readiness (#80815)
* fix(codex): gate migration on app readiness

* fix(codex): preserve source auth during migration

* fix(codex): isolate migration source app probes

* docs(codex): align migration readiness reasons

* docs(codex): remove stale auth-required source reason

* fix(codex): narrow native auth profile resolver input

* fix: clarify codex migration subscription gating

* refactor: simplify codex migration subscription gate

* fix: make codex app verification optional

* docs: clarify codex app inventory cache

* test: avoid map spread in migration test
2026-05-12 13:01:22 -07:00
Shakker
5c4a723f7c test: demand gateway agent payloads 2026-05-12 21:01:00 +01:00
Peter Steinberger
a1d7fb1273 test: dedupe lmstudio setup mock reads 2026-05-12 21:00:54 +01:00
Shakker
044b4175b3 test: winnow config validation issues 2026-05-12 20:59:14 +01:00
Peter Steinberger
2e45a8ff44 test: dedupe line webhook payload reads 2026-05-12 20:59:10 +01:00
Peter Steinberger
b499d8f60c test: dedupe gradium speech fetch reads 2026-05-12 20:57:38 +01:00
Shakker
a814173e74 test: lone plugin allow warning 2026-05-12 20:56:24 +01:00
Peter Steinberger
de235b96f0 test: dedupe feishu reaction mock reads 2026-05-12 20:55:42 +01:00
Shakker
9b9e73ad59 test: stack missing plugin warnings 2026-05-12 20:54:57 +01:00
Shakker
af20c89e83 test: weigh codex turn results 2026-05-12 20:53:50 +01:00
Peter Steinberger
bc26023b7e test: dedupe feishu comment mock reads 2026-05-12 20:53:45 +01:00
Shakker
3e425dde0d test: mine compaction branch messages 2026-05-12 20:52:19 +01:00
Peter Steinberger
eb46fa15ae test: dedupe feishu bot menu mock reads 2026-05-12 20:51:45 +01:00
Shakker
b428427108 test: carve overflow timeout payloads 2026-05-12 20:51:05 +01:00
Shakker
7c5b3283d6 test: supply codex auth profile store 2026-05-12 20:49:47 +01:00
Peter Steinberger
6a012282a4 test: dedupe discord monitor mock reads 2026-05-12 20:49:44 +01:00
Shakker
046d6fc0ae test: seek cron list log text 2026-05-12 20:48:33 +01:00
Shakker
8f55f0d38c test: collect status reaction emojis 2026-05-12 20:47:45 +01:00
Peter Steinberger
9b52daf595 test: dedupe diffs browser mock reads 2026-05-12 20:47:25 +01:00
Shakker
3a37bb717c test: account plugin repair outcomes 2026-05-12 20:46:39 +01:00
Shakker
c5a227163e test: report plugin repair records 2026-05-12 20:44:51 +01:00
Peter Steinberger
c3399806b3 test: dedupe heartbeat ghost reminder mock reads 2026-05-12 20:44:43 +01:00
Shakker
8423884a51 test: negate realtime response events 2026-05-12 20:43:33 +01:00
Shakker
ee40ce6d4b test: ledger session runtime options 2026-05-12 20:42:28 +01:00
Peter Steinberger
906dd432cf test: dedupe exec approval mock reads 2026-05-12 20:41:37 +01:00
Shakker
a455edc2b1 test: stamp task registry exact records 2026-05-12 20:40:52 +01:00
Peter Steinberger
652a56fc74 test: dedupe startup migration log reads 2026-05-12 20:39:27 +01:00
Shakker
ed4c287bf3 test: clinch forced realtime barge-in 2026-05-12 20:38:21 +01:00
Shakker
5768d55db8 test: trail realtime barge-in events 2026-05-12 20:37:25 +01:00
Peter Steinberger
3f26f3ddfd test: dedupe gateway update mock reads 2026-05-12 20:36:55 +01:00
Shakker
0452ad6d1a test: plumb doctor peer link repair call 2026-05-12 20:36:26 +01:00
Shakker
9623bb0af7 test: peg idle timeout stream args 2026-05-12 20:35:17 +01:00
Shakker
b60ae89aa4 test: settle plugin repair noops 2026-05-12 20:33:52 +01:00
Peter Steinberger
d18bbfe7ae test: dedupe gateway config reload mock reads 2026-05-12 20:33:34 +01:00
Shakker
ea7f74ffc9 test: idle disabled plugin repair results 2026-05-12 20:31:00 +01:00
Peter Steinberger
1b9603e7c1 test: dedupe whatsapp session mock reads 2026-05-12 20:30:06 +01:00
Shakker
ba54c0e060 test: unlock synology schema passthrough 2026-05-12 20:29:12 +01:00
Shakker
81fe17c4a6 test: regularize codex collab statuses 2026-05-12 20:27:32 +01:00
Shakker
a5aadea756 test: persist codex collab terminal message 2026-05-12 20:26:56 +01:00
Peter Steinberger
1993b2a40c test: dedupe openrouter media mock reads 2026-05-12 20:26:40 +01:00
Shakker
354bb11702 test: originate codex collab task payloads 2026-05-12 20:26:01 +01:00
Shakker
108507f6a2 test: terminate codex subagent statuses 2026-05-12 20:24:55 +01:00
Shakker
5f68002509 test: shadow codex subagent task payloads 2026-05-12 20:24:10 +01:00
Shakker
f0e381d6e9 test: transmit context ingest identity 2026-05-12 20:22:57 +01:00
Shakker
886e9223c9 test: rotate compaction context rows 2026-05-12 20:21:53 +01:00
Shakker
dacb8cf08a test: profile openrouter media descriptor 2026-05-12 20:20:09 +01:00
Shakker
f58515431e test: draft browser think command 2026-05-12 20:19:18 +01:00
Shakker
58bb7a50ef test: declare openrouter stt request 2026-05-12 20:18:19 +01:00
Peter Steinberger
ce085e5fa8 test: dedupe gateway client mock reads 2026-05-12 20:17:49 +01:00
Shakker
d8a2d1aaa9 test: relay gateway bridge payloads 2026-05-12 20:17:17 +01:00
Shakker
0ad0ff32fe test: pipe googlechat webhook limits 2026-05-12 20:16:11 +01:00
Shakker
0d9c38ffdf test: measure msteams upload options 2026-05-12 20:15:09 +01:00
Shakker
f6ee35fc86 test: decode tool card raw payload 2026-05-12 20:13:51 +01:00
Shakker
2eb302db1f test: imprint openrouter stt payloads 2026-05-12 20:13:10 +01:00
Peter Steinberger
82882ddf1a test: dedupe gateway boot mock reads 2026-05-12 20:12:52 +01:00
Shakker
b3ea131d51 test: box codex activation diagnostics 2026-05-12 20:11:54 +01:00
Shakker
975fd2a038 test: collate feishu doc descendants 2026-05-12 20:11:13 +01:00
Shakker
288eee88b1 test: sieve usage cache card 2026-05-12 20:10:20 +01:00
Peter Steinberger
acef9920df test: dedupe tasks command log reads 2026-05-12 20:09:55 +01:00
Shakker
5782d3441e test: clamp googlemeet cli registrations 2026-05-12 20:09:38 +01:00
Shakker
d14fa499a6 test: marshal gateway chat responses 2026-05-12 20:08:19 +01:00
Peter Steinberger
d356f84801 test: dedupe models list registry reads 2026-05-12 20:05:56 +01:00
Shakker
2ff3514037 test: portray channel status rows 2026-05-12 20:04:47 +01:00
Shakker
17dd725150 test: broadcast node pairing payloads 2026-05-12 20:03:29 +01:00
Peter Steinberger
513c717cd3 test: dedupe gateway status mock reads 2026-05-12 20:02:55 +01:00
Shakker
d05624aa3c test: assay exec command analysis fields 2026-05-12 20:02:02 +01:00
Shakker
d3f959a83a test: verbalize partial reply chunks 2026-05-12 20:01:19 +01:00
Peter Steinberger
91ae344c19 test: dedupe channels add mock reads 2026-05-12 20:00:04 +01:00
Shakker
383485e785 test: articulate node pairing requests 2026-05-12 19:59:47 +01:00
Shakker
b60f785777 test: certify bootstrap approval status 2026-05-12 19:58:41 +01:00
Shakker
4071fc6288 test: excise tool result details exactly 2026-05-12 19:57:57 +01:00
Peter Steinberger
0dbe2e9e12 test: dedupe nodes approval timeout mock reads 2026-05-12 19:57:38 +01:00
Shakker
c9d28775ec test: reprise optional install retry 2026-05-12 19:56:38 +01:00
Shakker
a0a91f8028 test: unwrap cmd transport argv 2026-05-12 19:55:54 +01:00
Shakker
d7f7a71981 test: purify health probe snapshots 2026-05-12 19:55:08 +01:00
Peter Steinberger
c964da8d58 test: dedupe daemon install mock reads 2026-05-12 19:54:55 +01:00
Shakker
129b147871 test: qualify model auth checker options 2026-05-12 19:54:32 +01:00
Shakker
b304155f66 test: confine respawn bridge options 2026-05-12 19:53:38 +01:00
Shakker
94c46c606a test: reflect side alias events 2026-05-12 19:52:59 +01:00
Peter Steinberger
a3534aedae test: dedupe channel auth mock reads 2026-05-12 19:52:39 +01:00
Shakker
69ea7b115d test: encase discovery log calls 2026-05-12 19:52:08 +01:00
Shakker
bb692899ab test: linearize launchd command calls 2026-05-12 19:51:23 +01:00
Shakker
f634799b45 test: capsize tool location traversal 2026-05-12 19:50:35 +01:00
Shakker
a263c4c58f test: ordinalize ledger replay chunks 2026-05-12 19:49:42 +01:00
Peter Steinberger
57db08504d test: dedupe sessions spawn hook reads 2026-05-12 19:49:17 +01:00
Shakker
e523183e46 test: schematize session mode requests 2026-05-12 19:49:00 +01:00
Shakker
492336414d test: thread media-only inbound context 2026-05-12 19:47:45 +01:00
Shakker
fdcd83da08 test: inscribe command config writes 2026-05-12 19:46:59 +01:00
Peter Steinberger
44f2cc71d5 test: dedupe subagent steer restart mock reads 2026-05-12 19:46:05 +01:00
Shakker
24e8a28057 test: forward daemon probe timeouts exactly 2026-05-12 19:45:50 +01:00
Shakker
b7cd7cb914 test: pinpoint session target discovery 2026-05-12 19:45:11 +01:00
Shakker
1e4155eb2e test: truncate acp deliveries exactly 2026-05-12 19:44:32 +01:00
Peter Steinberger
1f8c0dfc64 test: dedupe subagent orphan recovery mock reads 2026-05-12 19:44:14 +01:00
Shakker
061ef36397 test: disallow elevated allowlist failures 2026-05-12 19:43:58 +01:00
Shakker
008a837e5e test: retrieve cron jobs exactly 2026-05-12 19:42:39 +01:00
Peter Steinberger
85dbd478a6 test: dedupe subagent announce mock reads 2026-05-12 19:42:18 +01:00
Shakker
8e5e326de2 test: flag suppressed model refs 2026-05-12 19:41:50 +01:00
Peter Steinberger
71aec03dd9 test: dedupe ssh sandbox mock reads 2026-05-12 19:39:52 +01:00
Shakker
fa8965a4de test: singularize union validation issues 2026-05-12 19:39:00 +01:00
Peter Steinberger
ff64d8dde7 test: dedupe capability cli mock reads 2026-05-12 19:37:37 +01:00
Shakker
7901e7a454 test: enact launchd stop calls 2026-05-12 19:37:01 +01:00
Shakker
c5dd54431d test: script scheduled restart calls 2026-05-12 19:35:25 +01:00
Peter Steinberger
48e7f24565 test: dedupe cron gateway mock reads 2026-05-12 19:35:01 +01:00
Shakker
ebaa674bdc test: purge stale proof labels 2026-05-12 19:33:02 +01:00
Peter Steinberger
973e978aee test: dedupe session repair log reads 2026-05-12 19:32:49 +01:00
Shakker
b32e870e38 test: revisit active reaction calls 2026-05-12 19:31:49 +01:00
Peter Steinberger
2416fdece9 test: dedupe model diagnostic hook reads 2026-05-12 19:30:55 +01:00
Shakker
97207192b5 test: timeline status reaction cleanup 2026-05-12 19:30:32 +01:00
Shakker
50dd00ade6 test: chronicle turn record failure 2026-05-12 19:29:14 +01:00
Peter Steinberger
6398836079 test: dedupe embedded subscribe final filter reads 2026-05-12 19:29:04 +01:00
Shakker
d6bde4994c test: wrap blockquote style ir 2026-05-12 19:27:59 +01:00
Shakker
8483659477 test: slot ci dependency shard 2026-05-12 19:27:03 +01:00
Shakker
c54a3e6f78 test: rank boundary check guards 2026-05-12 19:26:26 +01:00
Peter Steinberger
8cd6e8ee42 test: dedupe embedded subscribe block reply reads 2026-05-12 19:26:17 +01:00
Shakker
14cd8193db test: position prerelease liveish check 2026-05-12 19:24:55 +01:00
Peter Steinberger
b5dc9a578b test: dedupe exec host followup mock reads 2026-05-12 19:24:11 +01:00
Shakker
e75c63fb08 test: furnish status json payload 2026-05-12 19:23:49 +01:00
Shakker
8a8cb1b8d5 test: concretize video override normalization 2026-05-12 19:22:39 +01:00
Shakker
f2ce07cd67 test: serialize config tuple baseline 2026-05-12 19:21:58 +01:00
Peter Steinberger
0ab328c915 test: dedupe exec approval mock reads 2026-05-12 19:21:15 +01:00
Shakker
ceaa5c08d6 test: crystallize blockquote spacing 2026-05-12 19:20:37 +01:00
Shakker
6dbe3b187c test: delimit command span formatting 2026-05-12 19:19:30 +01:00
Shakker
6e79a06d50 test: encompass beta verifier args 2026-05-12 19:18:40 +01:00
Peter Steinberger
ef8e6650ae test: dedupe anthropic transport mock reads 2026-05-12 19:17:27 +01:00
Shakker
7fd1f5c73c test: omit opus build allowlist 2026-05-12 19:17:08 +01:00
Shakker
52cbb7de33 test: literalize media fetch redaction 2026-05-12 19:16:12 +01:00
Shakker
ff580f2fb6 test: bracket file context output 2026-05-12 19:14:57 +01:00
Peter Steinberger
fc28f9376e test: dedupe compaction safeguard mock reads 2026-05-12 19:14:36 +01:00
Shakker
364212c6c0 test: summarize skill frontmatter exactly 2026-05-12 19:13:58 +01:00
Shakker
0d0832c24d test: compare provider index previews 2026-05-12 19:11:32 +01:00
Shakker
5ce8410041 test: disclose custom acp backend hint 2026-05-12 19:11:32 +01:00
Shakker
1f4cf100e8 test: compose waiting status message 2026-05-12 19:11:32 +01:00
Peter Steinberger
66421d413f test: dedupe maintenance cli mock reads 2026-05-12 19:10:46 +01:00
Shakker
b5706597c1 test: reproduce memory ingest page 2026-05-12 19:09:31 +01:00
Shakker
23725bf11f test: sequence zai model ids 2026-05-12 19:09:31 +01:00
Peter Steinberger
d548adb610 test: tighten channel catalog mock assertions 2026-05-12 19:08:47 +01:00
Shakker
ce6ba9a263 test: warn on shared agent dirs 2026-05-12 19:06:20 +01:00
Shakker
c22ea053d1 test: merge tuple doc metadata 2026-05-12 19:05:55 +01:00
Shakker
99a976e527 test: demonstrate raw redaction output 2026-05-12 19:05:16 +01:00
Shakker
796126912d test: scrub auth state warning 2026-05-12 19:04:30 +01:00
Shakker
50420d9e8f test: map runtime channel capabilities 2026-05-12 19:04:30 +01:00
Peter Steinberger
63a44ed310 test: dedupe system cli mock reads 2026-05-12 19:04:19 +01:00
Shakker
1bd0455072 test: index shell env expected keys 2026-05-12 19:02:27 +01:00
Shakker
ea4c365a4c test: phrase deferred followup tools 2026-05-12 19:02:27 +01:00
Shakker
493b2c918c test: catalog core tool profiles 2026-05-12 19:02:27 +01:00
Peter Steinberger
06938c9117 test: dedupe tool context guard mock reads 2026-05-12 19:01:54 +01:00
Shakker
e0841015e3 test: constrain typing mode issue paths 2026-05-12 19:00:01 +01:00
Shakker
9d9816b307 test: read qa workspace marker 2026-05-12 19:00:01 +01:00
Shakker
8ba6d3e207 test: show openai default allowlist 2026-05-12 19:00:01 +01:00
Shakker
8d71a42294 test: echo optional channel setup hint 2026-05-12 19:00:01 +01:00
Peter Steinberger
ad3ce47224 test: dedupe live model switch mock reads 2026-05-12 18:58:04 +01:00
Shakker
806d1f3cca test: identify logging size issue 2026-05-12 18:57:20 +01:00
Shakker
5497371ff0 test: pin e2e vitest setup 2026-05-12 18:57:04 +01:00
Shakker
ae571575f8 test: pin live vitest setup 2026-05-12 18:56:52 +01:00
Shakker
6abe2526d0 test: preserve discord gateway fallback log 2026-05-12 18:56:09 +01:00
Shakker
174e7ddffd test: name google setup entries 2026-05-12 18:56:08 +01:00
Shakker
6e562f5163 test: order telegram updates 2026-05-12 18:56:08 +01:00
Shakker
eecbc596b3 test: detail audit surface summary 2026-05-12 18:56:08 +01:00
Peter Steinberger
3d70d037aa test: dedupe embedded subscribe lifecycle mock reads 2026-05-12 18:55:45 +01:00
Shakker
ac9cddf353 test: print cli parse errors 2026-05-12 18:54:06 +01:00
Shakker
133fe11618 test: arrange cli failure lines 2026-05-12 18:54:06 +01:00
Shakker
c34a982f87 test: resolve docs links exactly 2026-05-12 18:54:06 +01:00
Peter Steinberger
c2bbb73e18 test: dedupe setup registry mock reads 2026-05-12 18:53:38 +01:00
Shakker
29a087be5a test: transcribe sherpa usage output 2026-05-12 18:52:29 +01:00
Shakker
a231036436 test: mark table block ir text 2026-05-12 18:52:14 +01:00
Shakker
7194be8fb8 test: capture docker enoent guidance 2026-05-12 18:51:58 +01:00
Shakker
3a2220f0a5 test: enumerate persisted auth channels 2026-05-12 18:51:23 +01:00
Shakker
8554e851af test: list pdf tool registration 2026-05-12 18:51:23 +01:00
Shakker
068bbb474b test: spell qwen doctor hint 2026-05-12 18:51:23 +01:00
Peter Steinberger
5d68e645ce test: dedupe overflow compaction mock reads 2026-05-12 18:51:19 +01:00
Shakker
3eeab53b80 test: state discord voice contract 2026-05-12 18:50:02 +01:00
Shakker
61903a2f08 test: outline qa markdown report 2026-05-12 18:49:48 +01:00
Shakker
e7c1d10f1d test: seal matrix logger redaction 2026-05-12 18:49:37 +01:00
Shakker
2bd58b5cfa test: distinguish allowed value summaries 2026-05-12 18:48:37 +01:00
Shakker
2e7cf45ed2 test: mirror btw inline rows 2026-05-12 18:48:37 +01:00
Shakker
83bf5ce4f3 test: require subagent wait guidance 2026-05-12 18:48:37 +01:00
Peter Steinberger
6861d8a6d7 test: dedupe subagent lifecycle mock reads 2026-05-12 18:48:06 +01:00
Shakker
542ee2f77b test: fix browser tab error guidance 2026-05-12 18:47:21 +01:00
Shakker
4b4adc767a test: specify markdown table fallback 2026-05-12 18:47:21 +01:00
Shakker
cc9197e51e test: nail daemon runtime status text 2026-05-12 18:47:20 +01:00
Peter Steinberger
4b41e591fe test: dedupe directory cli mock reads 2026-05-12 18:46:03 +01:00
Shakker
f054295e48 test: bind matrix mention html output 2026-05-12 18:45:40 +01:00
brokemac79
58700db5ff fix(gateway): suppress heartbeat tool events in webchat (#80378) 2026-05-12 10:45:16 -07:00
Shakker
45cf560f4e test: tighten matrix markdown html basics 2026-05-12 18:44:47 +01:00
Shakker
b2f6e06e13 test: verify sidebar status label 2026-05-12 18:43:42 +01:00
Peter Steinberger
4d74353064 test: dedupe auth profile runtime mock reads 2026-05-12 18:43:28 +01:00
Shakker
2a95f2cd48 test: assert markdown fallback structure 2026-05-12 18:42:48 +01:00
Peter Steinberger
052724416b test: dedupe btw mock reads 2026-05-12 18:40:39 +01:00
Shakker
864eb07d44 test: lock browser slash imports 2026-05-12 18:39:39 +01:00
Shakker
e2f512ce49 test: localize copy code markup 2026-05-12 18:38:01 +01:00
Shakker
dd75205d9f test: encode remaining www autolinks 2026-05-12 18:37:02 +01:00
Shakker
1611539b03 test: freeze unsafe markdown links 2026-05-12 18:36:03 +01:00
Peter Steinberger
4339a18657 test: dedupe attempt execution mock reads 2026-05-12 18:35:56 +01:00
Shakker
bd3d1fbb58 test: define markdown structural blocks 2026-05-12 18:34:21 +01:00
Shakker
62fff1f738 test: specify basic markdown rendering 2026-05-12 18:33:32 +01:00
Peter Steinberger
3c8bf48bb5 test: dedupe gateway usage mock reads 2026-05-12 18:33:17 +01:00
Shakker
ffc7d88473 test: codify markdown code blocks 2026-05-12 18:32:23 +01:00
Shakker
ad4bc5f80d test: capture unsafe markdown sanitizing 2026-05-12 18:31:00 +01:00
Peter Steinberger
7d9232a9a9 test: dedupe codex command mock reads 2026-05-12 18:30:47 +01:00
Shakker
77233877ac test: describe markdown image output 2026-05-12 18:29:43 +01:00
Shakker
fafe11bc67 test: escape task details exactly 2026-05-12 18:29:01 +01:00
Shakker
c60308239f test: detail task list markdown 2026-05-12 18:28:02 +01:00
Peter Steinberger
b5f2e4b5bb test: complete auto reply mock call helpers 2026-05-12 18:27:15 +01:00
Shakker
a043e7b7b3 test: spell escaped html output 2026-05-12 18:26:45 +01:00
Shakker
119dd0ee57 test: pin protocol CJK link rendering 2026-05-12 18:25:26 +01:00
Shakker
7d7d5809ab test: leave plain domains unlinked 2026-05-12 18:24:01 +01:00
clawsweeper[bot]
81cd5028a5 ci: add missing extension and channel labels to labeler.yml (#81095)
Summary:
- This PR adds `.github/labeler.yml` changed-file rules for 22 bundled plugin directories that currently have no dedicated labeler entry.
- Reproducibility: not applicable. as a CI metadata PR rather than a product bug. The gap is source-verifiable ...  with current-main `.github/labeler.yml`, which shows the added plugin paths exist and are unlabeled today.

Automerge notes:
- No ClawSweeper repair was needed after automerge opt-in.

Validation:
- ClawSweeper review passed for head eef42948d3.
- Required merge gates passed before the squash merge.

Prepared head SHA: eef42948d3
Review: https://github.com/openclaw/openclaw/pull/81095#issuecomment-4432997258

Co-authored-by: clawsweeper <274271284+clawsweeper[bot]@users.noreply.github.com>
Co-authored-by: bing <33149547+bing0901@users.noreply.github.com>
2026-05-12 17:23:35 +00:00
Peter Steinberger
cab7c4536e test: avoid mutating grouped render params 2026-05-12 18:23:28 +01:00
Peter Steinberger
bce0e9e0be test: dedupe cli runner spawn mock reads 2026-05-12 18:23:28 +01:00
Shakker
8536340e89 test: fence www autolink boundaries 2026-05-12 18:23:09 +01:00
Shakker
1a6b1aeb9d test: preserve quoted www autolinks 2026-05-12 18:22:06 +01:00
Shakker
6ddc2b5f49 test: fix www autolink suffix output 2026-05-12 18:21:14 +01:00
Shakker
8f10a86842 test: render basic www autolinks exactly 2026-05-12 18:20:02 +01:00
Shakker
d267880017 test: anchor slash command refreshes 2026-05-12 18:18:56 +01:00
Peter Steinberger
cae1263198 test: dedupe feishu reply dispatcher mock reads 2026-05-12 18:18:26 +01:00
Shakker
9fa1d9bf36 test: parse assistant media metadata urls 2026-05-12 18:17:38 +01:00
Shakker
5cefebd352 test: trace stored attachment previews 2026-05-12 18:16:54 +01:00
Shakker
038a968e36 test: color context notice exactly 2026-05-12 18:15:57 +01:00
Shakker
df6bc365bf test: quote websocket constructor errors 2026-05-12 18:15:06 +01:00
Shakker
94dc1e32c2 test: name update mismatch banner 2026-05-12 18:14:08 +01:00
Peter Steinberger
797ce4c05c test: dedupe slack slash mock reads 2026-05-12 18:13:53 +01:00
Shakker
d161053caa test: define dreaming error states 2026-05-12 18:13:24 +01:00
Shakker
d08a407610 test: state agent tool errors 2026-05-12 18:12:47 +01:00
Shakker
b881243dc6 test: spell out chat controller errors 2026-05-12 18:12:06 +01:00
Shakker
1d31583e0d test: pin gateway close messages 2026-05-12 18:11:12 +01:00
Shakker
49029cbdcc test: specify chat attachment transcript 2026-05-12 18:10:38 +01:00
Peter Steinberger
1e3a7548d9 test: dedupe update cli mock reads 2026-05-12 18:10:15 +01:00
Shakker
46ca9cf9c4 test: trim mismatched thinking defaults 2026-05-12 18:08:31 +01:00
Shakker
7b4fd3d67a test: alias slash commands exactly 2026-05-12 18:07:06 +01:00
Peter Steinberger
0f390fc820 test: dedupe telegram bot mock reads 2026-05-12 18:06:03 +01:00
Shakker
362ebc9c4f test: export chat markdown exactly 2026-05-12 18:04:50 +01:00
Shakker
5d9f16a093 test: tally performance event buffer 2026-05-12 18:03:41 +01:00
Shakker
378fff4330 test: nest session option labels 2026-05-12 18:02:52 +01:00
Peter Steinberger
78e9717d9b test: dedupe whatsapp send mock reads 2026-05-12 18:02:40 +01:00
Shakker
a390424442 test: sign gateway auth payloads 2026-05-12 18:01:27 +01:00
Peter Steinberger
c3c4510942 test: dedupe agent event mock reads 2026-05-12 18:00:04 +01:00
Shakker
cb0de89ef4 test: prune stored gateway scopes 2026-05-12 17:59:05 +01:00
Shakker
63c0f2894e test: chain channel save recovery 2026-05-12 17:58:08 +01:00
Shakker
cd34b0ce54 test: line model picker options 2026-05-12 17:57:23 +01:00
Peter Steinberger
df89ad90d8 test: dedupe voice call mock reads 2026-05-12 17:57:15 +01:00
Shakker
e5e1e7b489 test: derive custom theme colors 2026-05-12 17:56:03 +01:00
Shakker
35af092508 test: total usage helper tools 2026-05-12 17:55:18 +01:00
Shakker
a407eba98c test: engrave tool card payloads 2026-05-12 17:54:20 +01:00
Peter Steinberger
c4b106bcfe test: dedupe node wake mock calls 2026-05-12 17:53:56 +01:00
Shakker
fe46705640 test: zero config form unsupported paths 2026-05-12 17:53:04 +01:00
Shakker
8829fcaaf0 test: print tool helper previews 2026-05-12 17:52:07 +01:00
Shakker
44b7f5bceb test: table navigation metadata 2026-05-12 17:51:08 +01:00
Shakker
10f166a0fd test: sketch dreaming scene rows 2026-05-12 17:50:07 +01:00
Galin Iliev
4b28312bd8 fix(azure):Drain split provider stream frames (#80927)
Merged via squash.

Prepared head SHA: 03a7e1fec3
Co-authored-by: galiniliev <5711535+galiniliev@users.noreply.github.com>
Co-authored-by: galiniliev <5711535+galiniliev@users.noreply.github.com>
Reviewed-by: @galiniliev
2026-05-12 09:49:51 -07:00
Shakker
8d823a98c0 test: summarize peak error rows 2026-05-12 17:48:32 +01:00
Peter Steinberger
103664dd23 test: dedupe control ui response reads 2026-05-12 17:48:27 +01:00
pashpashpash
36b9da5c91 Keep Codex media tools backed by auth profiles (#81059)
* fix(codex): pass auth profiles to dynamic tools

* fix: bump protobufjs past advisory range
2026-05-13 01:46:21 +09:00
Shakker
6053532bd2 test: checkpoint sessions compaction text 2026-05-12 17:45:50 +01:00
Peter Steinberger
43316c2909 test: dedupe qa matrix mock calls 2026-05-12 17:44:26 +01:00
Peter Steinberger
6a5290e49e test: dedupe migrate mock calls 2026-05-12 17:38:47 +01:00
Shakker
65b608388a test: pare voice option exclusions 2026-05-12 17:37:42 +01:00
Shakker
687f4be9ec test: stage dreaming scene buttons 2026-05-12 17:36:55 +01:00
Shakker
9cbfc843a1 test: recite dream diary prose 2026-05-12 17:36:14 +01:00
Shakker
230be4e91c test: cleanse login raw errors 2026-05-12 17:35:05 +01:00
Peter Steinberger
6a099e5971 test: dedupe model picker mock calls 2026-05-12 17:34:46 +01:00
Shakker
07f68b1b4d test: diagnose login connection guidance 2026-05-12 17:33:57 +01:00
Shakker
63563713c6 test: pair login context guidance 2026-05-12 17:33:21 +01:00
Shakker
505aa38079 test: prescribe login auth guidance 2026-05-12 17:32:33 +01:00
Shakker
fe04523211 test: option session override selects 2026-05-12 17:31:32 +01:00
Shakker
5f081c8cd5 test: column sessions table 2026-05-12 17:30:39 +01:00
Peter Steinberger
05fabfbc9c test: dedupe google meet mock calls 2026-05-12 17:29:52 +01:00
Shakker
b98e97210b test: unhide raw config body 2026-05-12 17:29:15 +01:00
Shakker
bfc5d99828 test: flatten malformed config values 2026-05-12 17:28:45 +01:00
Shakker
ddfa97eba2 test: arrange config tabs 2026-05-12 17:27:32 +01:00
Shakker
2cb8a0c4fb test: retain cron advanced labels 2026-05-12 17:26:49 +01:00
Shakker
d7dfd4a8b2 test: navigate cron run links 2026-05-12 17:26:02 +01:00
Peter Steinberger
a8bc83edf4 test: dedupe diagnostics otel mock calls 2026-05-12 17:25:57 +01:00
Shakker
3aeec2e4a4 test: wire cron suggestion lists 2026-05-12 17:25:00 +01:00
Shakker
5681cfd839 test: distinguish cron delivery options 2026-05-12 17:24:14 +01:00
Shakker
641eaeecf3 test: gather localized selectors 2026-05-12 17:23:27 +01:00
Shakker
706b9a2ef7 test: announce slash option exactly 2026-05-12 17:22:34 +01:00
Shakker
637afd6a11 test: sequence thinking option labels 2026-05-12 17:21:06 +01:00
Shakker
a728e6aaf6 test: expect config section titles 2026-05-12 17:19:26 +01:00
Peter Steinberger
6cfb532afd test: dedupe feishu drive mock calls 2026-05-12 17:19:17 +01:00
Shakker
0c5e33480e test: honor wildcard raw redaction 2026-05-12 17:18:20 +01:00
Shakker
3589827635 test: disclose raw redaction state 2026-05-12 17:17:48 +01:00
Shakker
c630aa3488 test: prove config reveal reset 2026-05-12 17:17:08 +01:00
Shakker
16f2b22b33 test: mask config raw secrets 2026-05-12 17:14:49 +01:00
Shakker
b5f8e4c18a test: notice raw mode lockout 2026-05-12 17:13:34 +01:00
Peter Steinberger
72d9ea3b76 test: dedupe matrix send mock calls 2026-05-12 17:13:20 +01:00
Shakker
628eeda84a test: limit scoped config labels 2026-05-12 17:12:41 +01:00
Shakker
ae773272ac test: clear config diff panel 2026-05-12 17:12:00 +01:00
Shakker
0918f3823b test: open config diff rows 2026-05-12 17:11:07 +01:00
Shakker
1f1a5c205c test: quote theme importer hints 2026-05-12 17:09:59 +01:00
Shakker
adb8d553e4 test: mark imported theme metadata 2026-05-12 17:09:19 +01:00
Peter Steinberger
3598938458 test: dedupe openresponses mock calls 2026-05-12 17:09:07 +01:00
Shakker
c5574eb796 test: redact secret ref input 2026-05-12 17:08:23 +01:00
Shakker
c967410bed test: unpack device pairing rows 2026-05-12 17:07:34 +01:00
Shakker
87a4da89e3 test: badge agent tool provenance 2026-05-12 17:05:43 +01:00
Shakker
9be8d38f95 test: freeze exec approval expiry 2026-05-12 17:04:46 +01:00
Peter Steinberger
c0e287f3c1 test: dedupe embedded attempt mock calls 2026-05-12 17:04:11 +01:00
Shakker
e15bb302e0 test: translate exec approval chrome 2026-05-12 17:03:22 +01:00
Shakker
4fe36dc608 test: inventory cron filter options 2026-05-12 17:02:20 +01:00
Shakker
9808fd6802 test: localize talk button title 2026-05-12 17:01:21 +01:00
Shakker
a230aefb40 test: itemize login failure panel 2026-05-12 17:00:24 +01:00
Peter Steinberger
8c6dd5bddc test: dedupe outbound delivery mock calls 2026-05-12 16:59:51 +01:00
Shakker
9076ce0a7d test: outline cron advanced controls 2026-05-12 16:56:32 +01:00
Shakker
24fa9ba6a4 test: expose cron edit controls 2026-05-12 16:55:20 +01:00
Shakker
a5557d1fb5 test: index cron validation status 2026-05-12 16:54:47 +01:00
Peter Steinberger
4f1bee9f8b test: dedupe telegram send mock calls 2026-05-12 16:54:31 +01:00
Ayaan Zaidi
4272ce1597 chore(voice-call): note Telnyx realtime PR (#81024) (thanks @dynamite-bud) 2026-05-12 21:23:50 +05:30
Ayaan Zaidi
665c29d4dc fix(voice-call): bind Telnyx realtime streams to issued calls 2026-05-12 21:23:50 +05:30
Rudra
148e5467b5 fix: align Telnyx stream lifecycle parsing with carrier docs
Two parsing bugs caught by Codex review on the Telnyx Media Streaming
PR:

Lifecycle webhook event names had a stray `call.` prefix that never
matched Telnyx's documented event types. Telnyx surfaces stream
lifecycle as `streaming.started` and `streaming.stopped` (no prefix);
stream errors arrive as `{event:"error"}` JSON frames over the
WebSocket, not as carrier webhooks. Drop the bogus
`call.streaming.failed` case from the webhook parser and add a new
`error` frame kind to the StreamFrameAdapter union so the realtime
handler can log failures instead of silently dropping them.

Telnyx WebSocket frames carry `stream_id` at the top level of the
envelope and `call_control_id` inside the `start` object; the
Telnyx adapter was reading `start.stream_id` (always undefined) and
defaulting `providerCallId` to the constructor-supplied value
regardless of what the carrier sent. Read both fields from the
documented locations and fall back to the constructor providerCallId
only when the carrier frame omits them.

Tests updated to reflect the carrier-documented frame shapes; new
fixture covers `{event:"error"}` round-trip through the adapter.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-12 21:23:50 +05:30
Rudra
b28e3b378e test: cover Telnyx Media Streaming for voice-call realtime
Adds tests across the touched surface: StreamFrameAdapter for both
Twilio (with streamSid) and Telnyx (without), the generalized
RealtimeAudioPacer carrying both envelopes, Telnyx provider
dial-time and answer-action streaming params with the
call.streaming.failed -> call.error mapping, manager
streamSessionIssuer wiring for Telnyx outbound, and the widened
realtime + telnyx config gate.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-12 21:23:50 +05:30
Rudra
bb1b075118 feat: add Telnyx Media Streaming for voice-call realtime
Wires bidirectional PCMU WebSocket audio for Telnyx so realtime
providers (OpenAI Realtime, etc.) can drive Telnyx calls the same
way they drive Twilio. Telnyx attaches Media Streaming at dial
time and answer-action time per the documented canonical patterns
(no actions/streaming_start call needed).

New StreamFrameAdapter abstraction owns provider-shaped frame
parsing and outbound serialization, so realtime-handler.ts stays
carrier-agnostic. RealtimeAudioPacer is generalized to accept any
serializer. The provider-twilio realtime gate widens to accept
telnyx.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-12 21:23:50 +05:30
Shakker
a517434261 test: read cron error bodies 2026-05-12 16:52:13 +01:00
Shakker
a665c004c1 test: scope cron history subtitle 2026-05-12 16:51:12 +01:00
Shakker
f1569b4afd test: read cron due metadata 2026-05-12 16:50:21 +01:00
Shakker
d0c2cce07e test: name stale cron job 2026-05-12 16:49:13 +01:00
Shakker
d6a65e928b test: tabulate cron delivery fields 2026-05-12 16:48:10 +01:00
Shakker
0aed7c5090 test: select localized welcome copy 2026-05-12 16:47:04 +01:00
Shakker
80c615daee test: bind pairing hint commands 2026-05-12 16:45:47 +01:00
Peter Steinberger
cb957fe0d2 test: dedupe telegram delivery mock calls 2026-05-12 16:44:58 +01:00
Shakker
4b4b8d9305 test: rely on context detail text 2026-05-12 16:43:54 +01:00
Shakker
23a4d5298d test: target chat detail labels 2026-05-12 16:42:57 +01:00
Shakker
ec082a7790 test: route chat loading assertions 2026-05-12 16:41:42 +01:00
Peter Steinberger
fcd1073b72 test: dedupe auto-reply dispatch mock calls 2026-05-12 16:41:33 +01:00
Shakker
7d208f3a5d test: scope localized agent refresh 2026-05-12 16:39:47 +01:00
Shakker
678cd504e8 test: order advanced review controls 2026-05-12 16:38:36 +01:00
Shakker
aef22e659b test: pin wiki preview truncation 2026-05-12 16:37:09 +01:00
Shakker
34e69362d9 test: read parsed dream entry 2026-05-12 16:36:21 +01:00
Shakker
aac9c9bc96 test: specify diary empty states 2026-05-12 16:35:32 +01:00
Shakker
4941c919d9 test: detail wiki enablement cta 2026-05-12 16:34:42 +01:00
Shakker
44001b7d25 test: extract diary insight fields 2026-05-12 16:33:56 +01:00
Peter Steinberger
e215dfcadf test: dedupe outbound matrix mock calls 2026-05-12 16:33:49 +01:00
Shakker
b0cdb5b3ce test: normalize dreaming status detail 2026-05-12 16:32:57 +01:00
Shakker
2174cabcbe test: anchor live canvas preview 2026-05-12 16:31:39 +01:00
Shakker
19a70d98b1 test: separate visible canvas rows 2026-05-12 16:30:52 +01:00
Shakker
4289e4c834 test: locate hidden canvas details 2026-05-12 16:30:07 +01:00
Peter Steinberger
5e009ed142 test: dedupe subagent announce mock calls 2026-05-12 16:29:54 +01:00
Shakker
a46fa1d952 test: describe canvas embed frame 2026-05-12 16:29:23 +01:00
Shakker
ba23d9ac71 test: resolve document media link 2026-05-12 16:28:19 +01:00
Peter Steinberger
2379da6cf1 test: dedupe qa matrix cli mock calls 2026-05-12 16:27:30 +01:00
Shakker
263d7cbf27 test: recheck media retry state 2026-05-12 16:22:45 +01:00
Shakker
52a958727b test: verify platform media checks 2026-05-12 16:22:12 +01:00
Peter Steinberger
c5135c1efd test: dedupe qa matrix message body mock calls 2026-05-12 16:22:00 +01:00
Shakker
f56a091607 test: identify blocked media fields 2026-05-12 16:21:09 +01:00
Gavin Zeng
a7f1c7b672 fix(exec): skip heartbeat wake for subagent sessions (#66749)
Merged via squash.

Prepared head SHA: 86bf841519
Co-authored-by: ggzeng <20488795+ggzeng@users.noreply.github.com>
Co-authored-by: altaywtf <9790196+altaywtf@users.noreply.github.com>
Reviewed-by: @altaywtf
2026-05-12 18:21:03 +03:00
Shakker
3c8ff0af26 test: separate same-origin media state 2026-05-12 16:20:24 +01:00
Shakker
372ed1e5e4 test: differentiate media auth refresh 2026-05-12 16:19:54 +01:00
Shakker
ca87dabac0 test: trace local media ticket cards 2026-05-12 16:19:17 +01:00
Shakker
565e612a5b test: confirm assistant media surfaces 2026-05-12 16:18:35 +01:00
Peter Steinberger
d24254ef5f test: dedupe telegram bot mock call 2026-05-12 16:17:54 +01:00
Shakker
4a5009f8d1 test: bind tool catalog warning 2026-05-12 16:15:17 +01:00
Peter Steinberger
730cbb356f test: dedupe bonjour advertiser mock calls 2026-05-12 16:15:03 +01:00
Peter Steinberger
7b52b60051 test: dedupe codex side question mock calls 2026-05-12 16:13:08 +01:00
Shakker
7058b5a859 test: structure sessions empty states 2026-05-12 16:12:56 +01:00
Shakker
81ba006442 test: narrow runtime filter result 2026-05-12 16:12:24 +01:00
Shakker
e1ebe46d12 test: scope identity filter rows 2026-05-12 16:11:35 +01:00
Peter Steinberger
250e16d3c9 test: dedupe codex conversation mock calls 2026-05-12 16:11:24 +01:00
Shakker
8a2dae7050 test: select compaction disclosure 2026-05-12 16:10:52 +01:00
Shakker
e40fa869da test: inspect session details fields 2026-05-12 16:10:12 +01:00
Peter Steinberger
b2d8a92f48 test: dedupe feishu docx mock calls 2026-05-12 16:09:16 +01:00
Shakker
4dd0231ecc test: parse grouped tool outputs 2026-05-12 16:08:11 +01:00
Pavan Kumar Gondhi
9ac4272b35 fix: harden safe-bin argument validation [AI] (#80999)
* fix: reject shell expansion in safe-bin tokens

* fix: complete safe-bin shell payload handling

* addressing codex review

* addressing ci

* addressing ci

* addressing codex review

* docs: add changelog entry for PR merge
2026-05-12 20:37:58 +05:30
Peter Steinberger
186de9daa0 test: dedupe feishu outbound mock calls 2026-05-12 16:06:08 +01:00
Shakker
cbb73134ef test: expand grouped tool blocks 2026-05-12 16:05:05 +01:00
Peter Steinberger
fdb2d3a083 test: dedupe googlechat auth mock calls 2026-05-12 16:04:22 +01:00
Shakker
78c0ba016c test: query run control buttons 2026-05-12 16:04:04 +01:00
Shakker
45b68a2c20 test: label session filter field 2026-05-12 16:03:06 +01:00
Peter Steinberger
fa0c23c8ba test: dedupe googlechat target mock calls 2026-05-12 16:02:29 +01:00
Shakker
6390733519 test: read grouped meta spans 2026-05-12 16:02:14 +01:00
Shakker
af5f6a3276 test: place delete confirms exactly 2026-05-12 16:01:26 +01:00
Shakker
2030a6390c test: catalogue agent tool details 2026-05-12 16:00:29 +01:00
Peter Steinberger
7121791735 test: dedupe matrix client mock calls 2026-05-12 15:59:47 +01:00
Shakker
188fa93862 test: address agent tabs directly 2026-05-12 15:59:31 +01:00
Shakker
a20a213daa test: find quick settings rows 2026-05-12 15:58:50 +01:00
Pavan Kumar Gondhi
a5dce367ce fix: scan plugin runtime entries during install [AI] (#80998)
* fix: scan plugin runtime entries during install

* addressing review-skill

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 20:28:40 +05:30
Peter Steinberger
b076215e82 test: dedupe memory search mock calls 2026-05-12 15:57:57 +01:00
Shakker
33ca27f4f6 test: parse tool card raw details 2026-05-12 15:57:32 +01:00
Shakker
c423ef2e34 test: split tool card block checks 2026-05-12 15:56:38 +01:00
Shakker
44de39a1df test: filter config form tag labels 2026-05-12 15:56:01 +01:00
Peter Steinberger
b28714307d test: dedupe minimax speech mock calls 2026-05-12 15:55:38 +01:00
Shakker
166361c5eb test: frame markdown sidebar slots 2026-05-12 15:55:13 +01:00
Shakker
c77f199fd6 test: resolve lazy view text 2026-05-12 15:53:58 +01:00
Peter Steinberger
f3d5a9926f test: dedupe nostr inbound mock calls 2026-05-12 15:53:31 +01:00
Shakker
151de16001 test: render side result slots 2026-05-12 15:52:50 +01:00
Shakker
4a83448662 test: shape context notice controls 2026-05-12 15:52:05 +01:00
Peter Steinberger
cb8b7ff891 test: dedupe ollama embedding mock calls 2026-05-12 15:51:45 +01:00
Shakker
449da806bd test: name session source toggles 2026-05-12 15:51:16 +01:00
Peter Steinberger
7a9613e66b test: dedupe openai tts mock calls 2026-05-12 15:49:59 +01:00
Peter Steinberger
49d42bea6e test: dedupe openrouter video mock calls 2026-05-12 15:48:23 +01:00
Shakker
b0cd70f021 test: grade session status badges 2026-05-12 15:47:13 +01:00
Peter Steinberger
360b0769db test: dedupe qqbot websocket mock calls 2026-05-12 15:46:33 +01:00
Peter Steinberger
67ac7ee200 test: dedupe signal client mock calls 2026-05-12 15:45:01 +01:00
Shakker
94e7678be4 test: expand preview class checks 2026-05-12 15:44:49 +01:00
Shakker
8c134178d6 test: isolate mount fallback elements 2026-05-12 15:44:14 +01:00
Shakker
b8db4fc859 test: preserve focus shell classes 2026-05-12 15:43:31 +01:00
Peter Steinberger
cc736fdf1c test: dedupe signal monitor mock calls 2026-05-12 15:43:14 +01:00
Shakker
b80f5c2ea5 test: lock mobile controls classes 2026-05-12 15:42:56 +01:00
Shakker
3e1360cfea test: map navigation shell classes 2026-05-12 15:42:20 +01:00
Shakker
b14f91bd86 test: require config action buttons 2026-05-12 15:41:03 +01:00
Peter Steinberger
7c8d32211d test: dedupe speech tts mock calls 2026-05-12 15:40:41 +01:00
Peter Steinberger
094f6d83c7 test: dedupe telegram dispatch mock calls 2026-05-12 15:38:59 +01:00
Shakker
859977e5d8 test: define custom theme style sync 2026-05-12 15:38:07 +01:00
Shakker
14a95bffb5 test: capture tool card action class 2026-05-12 15:37:28 +01:00
Peter Steinberger
26afc763b3 test: dedupe telegram command menu mock calls 2026-05-12 15:37:11 +01:00
Shakker
7c2c91a0fa test: track divider dragging class 2026-05-12 15:35:39 +01:00
Shakker
b9e0babe04 test: match chat avatar initials 2026-05-12 15:34:59 +01:00
Shakker
10e6d7eb3e test: spell out agent tool classes 2026-05-12 15:34:04 +01:00
Shakker
24f0ae7937 test: list active quick profile classes 2026-05-12 15:33:16 +01:00
Peter Steinberger
f4ae21cb0a test: dedupe telegram channel post mock calls 2026-05-12 15:33:06 +01:00
Shakker
3fdb2b78c5 test: pin chat status indicators 2026-05-12 15:32:41 +01:00
Shakker
1dbf788619 test: enumerate chat control classes 2026-05-12 15:31:29 +01:00
Peter Steinberger
2bfbe25239 test: dedupe telegram fetch mock calls 2026-05-12 15:30:17 +01:00
Shakker
13111d8e27 test: verify mount fallback copy 2026-05-12 15:29:21 +01:00
Shakker
ffbeb53838 test: target lazy view states 2026-05-12 15:28:31 +01:00
Shakker
98f72eda21 test: tighten context notice text 2026-05-12 15:27:50 +01:00
Shakker
8e068bc72c test: locate config tag result 2026-05-12 15:27:06 +01:00
Peter Steinberger
684e13c7fd test: dedupe vydra fetch mock calls 2026-05-12 15:26:51 +01:00
Shakker
646ef0c78f test: anchor config hint label 2026-05-12 15:26:06 +01:00
Peter Steinberger
f6418812ef test: dedupe whatsapp media cap mock calls 2026-05-12 15:24:54 +01:00
Peter Steinberger
99f9b78bcd test: dedupe whatsapp process mock calls 2026-05-12 15:22:22 +01:00
Shakker
26df0e4782 test: pin cron run filters 2026-05-12 15:22:06 +01:00
Shakker
ac3bf79d9d test: assert debug callout class 2026-05-12 15:21:16 +01:00
Shakker
3b2735f3ee test: check dreaming tab labels 2026-05-12 15:20:41 +01:00
Peter Steinberger
4e3b952b70 test: dedupe feishu comment mock calls 2026-05-12 15:19:46 +01:00
Peter Steinberger
a34d45e2a1 test: dedupe feishu media mock calls 2026-05-12 15:17:31 +01:00
Peter Steinberger
ca2523f9d5 test: dedupe line download mock calls 2026-05-12 15:14:46 +01:00
Peter Steinberger
185ace0155 test: dedupe synology chat http mock calls 2026-05-12 15:12:36 +01:00
Peter Steinberger
2298889cb9 test: dedupe telegram session metadata mock calls 2026-05-12 15:09:56 +01:00
Pavan Kumar Gondhi
b6a94d4ef9 Require auth for sandbox browser CDP relay [AI] (#81002)
* fix: require auth for sandbox browser cdp relay

* addressing review-skill

* addressing review-skill

* addressing review-skill

* addressing codex review

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 19:37:32 +05:30
Peter Steinberger
ed2a451363 test: dedupe whatsapp audio mock calls 2026-05-12 15:06:58 +01:00
Pavan Kumar Gondhi
65d7232218 fix: detect carried exec command forms [AI] (#81000)
* fix: detect carried inline exec forms

* addressing review-skill

* addressing codex review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 19:36:04 +05:30
Peter Steinberger
64b7be436c test: dedupe export session write mock calls 2026-05-12 15:04:54 +01:00
Pavan Kumar Gondhi
731af9c96b Reject truncated exec approval commands [AI] (#81001)
* fix: reject truncated exec approval commands

* docs: add changelog entry for PR merge
2026-05-12 19:33:42 +05:30
Peter Steinberger
8d41e4d53f test: dedupe daemon install mock calls 2026-05-12 15:02:28 +01:00
Pavan Kumar Gondhi
50f4440c96 Enforce inline shell wrapper payload matching [AI] (#80978)
* fix: enforce inline shell wrapper payload matching

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing claude review

* addressing claude review

* fix: complete shell wrapper allowlist handling

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 19:30:18 +05:30
Peter Steinberger
b1131cddbd test: dedupe claude doctor note mock calls 2026-05-12 14:59:03 +01:00
Peter Steinberger
bf4ab7ecf0 test: dedupe models list runtime mock calls 2026-05-12 14:57:30 +01:00
Peter Steinberger
07748507cc test: dedupe chat directive mock calls 2026-05-12 14:55:53 +01:00
Shakker
086aec8d85 test: compare inherited session keys 2026-05-12 14:55:13 +01:00
Shakker
5f83ddba9f test: match session identity cells 2026-05-12 14:54:26 +01:00
Shakker
313df5814d test: locate markdown preview label 2026-05-12 14:53:38 +01:00
Peter Steinberger
3b7fdb3033 test: dedupe heartbeat tool response mock calls 2026-05-12 14:52:21 +01:00
Shakker
e101ee184b test: preserve localized agent tabs 2026-05-12 14:51:51 +01:00
Shakker
e21efc6ccc test: check active tool profile state 2026-05-12 14:50:37 +01:00
Peter Steinberger
e2c32806c1 test: dedupe anthropic vertex stream mock calls 2026-05-12 14:50:30 +01:00
Shakker
806a3bce68 test: list whatsapp action buttons 2026-05-12 14:49:27 +01:00
Shakker
9bfa2d031f test: order quick identity titles 2026-05-12 14:48:56 +01:00
Peter Steinberger
3b45ad6960 test: dedupe matrix device mock calls 2026-05-12 14:48:14 +01:00
Peter Steinberger
a45b96fd88 test: dedupe matrix message mock calls 2026-05-12 14:46:43 +01:00
Shakker
eea3e2c0f7 test: record assistant avatar source fields 2026-05-12 14:45:53 +01:00
Peter Steinberger
bfb595b5ce test: dedupe memory narrative mock calls 2026-05-12 14:45:02 +01:00
Peter Steinberger
fce4f10e96 test: dedupe ollama web search mock calls 2026-05-12 14:43:10 +01:00
Peter Steinberger
33568988a6 test: dedupe status scan mock calls 2026-05-12 14:39:18 +01:00
Peter Steinberger
f1ce79ba6c test: dedupe server channel startup mock calls 2026-05-12 14:36:57 +01:00
Peter Steinberger
89cd10157b test: dedupe tools catalog respond calls 2026-05-12 14:34:45 +01:00
Peter Steinberger
1e543fa844 test: dedupe gateway post attach mock calls 2026-05-12 14:32:29 +01:00
Peter Steinberger
cf924fd1e8 test: dedupe heartbeat reply body mock calls 2026-05-12 14:29:12 +01:00
Peter Steinberger
10c09d9b73 test: dedupe bedrock mantle stream mock calls 2026-05-12 14:26:38 +01:00
Peter Steinberger
8f645dba24 test: dedupe browser registration mock calls 2026-05-12 14:24:31 +01:00
Shakker
d08072285c test: bind clawhub detail dialog text 2026-05-12 14:24:15 +01:00
Shakker
4116f8cedf test: target clawhub result fields 2026-05-12 14:22:57 +01:00
Shakker
6f46d12778 test: isolate agent skills tab count 2026-05-12 14:21:42 +01:00
Peter Steinberger
997c28c50c test: dedupe feishu monitor cleanup mock calls 2026-05-12 14:20:45 +01:00
Shakker
831eebfadd test: verify debug security callout text 2026-05-12 14:19:27 +01:00
Peter Steinberger
3303b2fc05 test: dedupe matrix monitor mock calls 2026-05-12 14:18:27 +01:00
Shakker
67267cb2ad test: scope cache hit overview assertion 2026-05-12 14:17:02 +01:00
Peter Steinberger
85e0137472 test: dedupe qa credential lease fetch calls 2026-05-12 14:15:54 +01:00
Shakker
322d9be225 test: tighten sqlite-vec error contracts 2026-05-12 14:15:23 +01:00
Peter Steinberger
fad2484477 fix: canonicalize qualified gemini pro preview refs 2026-05-12 14:12:35 +01:00
Peter Steinberger
45a8a25947 test: dedupe telegram media e2e mock calls 2026-05-12 14:07:05 +01:00
Peter Steinberger
d9f2b64be1 test: dedupe tlon guarded fetch calls 2026-05-12 14:04:38 +01:00
Peter Steinberger
37c38d1756 test: dedupe whatsapp session mock calls 2026-05-12 14:02:47 +01:00
Shakker
d26ab41372 test: require exact http failures 2026-05-12 14:01:56 +01:00
Peter Steinberger
7665b3926c test: dedupe configure auth allowlist calls 2026-05-12 13:59:05 +01:00
Peter Steinberger
a1cae45654 test: dedupe talk handler mock calls 2026-05-12 13:57:06 +01:00
Peter Steinberger
076bf848a1 test: dedupe heartbeat ghost mock calls 2026-05-12 13:54:24 +01:00
Peter Steinberger
8ecdd353ef test: dedupe approval forwarder mock calls 2026-05-12 13:52:24 +01:00
Shakker
e14b54596f test: name default local embedding model 2026-05-12 13:51:13 +01:00
Peter Steinberger
8aca690939 test: dedupe health snapshot mock calls 2026-05-12 13:50:28 +01:00
Peter Steinberger
5ec4573604 test: dedupe codex elicitation mock calls 2026-05-12 13:48:28 +01:00
Peter Steinberger
db79b1cc5e test: dedupe ollama setup mock calls 2026-05-12 13:46:26 +01:00
Peter Steinberger
4b2a502c5b test: dedupe heartbeat reply mock calls 2026-05-12 13:44:30 +01:00
Peter Steinberger
9b07f80559 test: dedupe node event mock calls 2026-05-12 13:40:28 +01:00
Peter Steinberger
fe0e2e6f41 test: dedupe telegram native command mock calls 2026-05-12 13:38:34 +01:00
Shakker
1c44d31aab test: map multilingual query tokens 2026-05-12 13:37:38 +01:00
Peter Steinberger
14b871efd9 test: dedupe codex registration mock calls 2026-05-12 13:36:21 +01:00
Peter Steinberger
e6551e63ba test: dedupe auto-reply delivery mock calls 2026-05-12 13:34:16 +01:00
Peter Steinberger
88714d6803 fix: normalize oauth auth-result config patches 2026-05-12 13:31:42 +01:00
Shakker
a538e58075 test: anchor consult runtime prompt 2026-05-12 13:31:03 +01:00
Shakker
fa97442740 test: freeze voice consult prompt 2026-05-12 13:30:00 +01:00
Shakker
31bdbfe59b test: codify usage chart sizing 2026-05-12 13:28:59 +01:00
Peter Steinberger
0a028a3a8a test: dedupe openai http agent mock calls 2026-05-12 13:22:36 +01:00
Bob
fe79efc31b fix: surface silent model fallback failures (#80917)
Merged via squash.

Prepared head SHA: 59be6e2db5
Co-authored-by: dutifulbob <261991368+dutifulbob@users.noreply.github.com>
Co-authored-by: osolmaz <2453968+osolmaz@users.noreply.github.com>
Reviewed-by: @osolmaz
2026-05-12 15:19:10 +03:00
Shakker
9c125e821f test: enumerate config preset defaults 2026-05-12 13:18:26 +01:00
Peter Steinberger
7187d2754e test: dedupe matrix group history mock calls 2026-05-12 13:18:08 +01:00
Shakker
9e09dfe512 test: parse talk file log fields 2026-05-12 13:17:21 +01:00
Peter Steinberger
258002917b test: dedupe whatsapp delivery mock calls 2026-05-12 13:16:05 +01:00
Shakker
3b5e189125 test: quantify fallback error allocation 2026-05-12 13:15:38 +01:00
Peter Steinberger
8e848919e7 test: dedupe zalo group gating mock calls 2026-05-12 13:14:08 +01:00
Shakker
0746fda37c test: specify session export content 2026-05-12 13:13:20 +01:00
Shakker
c3c72a7cfb test: assert peak error summaries 2026-05-12 13:10:26 +01:00
clawsweeper[bot]
d44553dade fix(gateway): wire max_completion_tokens/max_tokens through openai-http (#81013)
Summary:
- The branch adds Chat Completions token-cap fields to the Gateway request type, forwards them as agent stream parameters, and documents/tests the behavior.
- Reproducibility: yes. Source inspection gives a high-confidence current-main path: send `max_completion_toke ... tokens` to `/v1/chat/completions` and observe that the current handler never sets `streamParams.maxTokens`.

Automerge notes:
- PR branch already contained follow-up commit before automerge: fix(gateway): wire max_completion_tokens/max_tokens through openai-http

Validation:
- ClawSweeper review passed for head a9c39f7d4a.
- Required merge gates passed before the squash merge.

Prepared head SHA: a9c39f7d4a
Review: https://github.com/openclaw/openclaw/pull/81013#issuecomment-4430303959

Co-authored-by: Bingsen <dingheng.huang@urbanic.com>
Co-authored-by: clawsweeper <274271284+clawsweeper[bot]@users.noreply.github.com>
2026-05-12 12:08:07 +00:00
Shakker
be7ca5d828 test: lock qmd backend collections 2026-05-12 13:07:56 +01:00
Peter Steinberger
04ee5985c4 test: dedupe control plane response mock calls 2026-05-12 13:06:58 +01:00
Shakker
66f16b81b9 test: pin query expansion expectations 2026-05-12 13:05:53 +01:00
Peter Steinberger
e9431e2dd4 test: dedupe codex run attempt hook mock calls 2026-05-12 13:04:34 +01:00
Peter Steinberger
c9ec1dea71 test: dedupe codex shared client mock calls 2026-05-12 13:01:48 +01:00
Peter Steinberger
f7f9312c7a test: dedupe matrix replies send mock calls 2026-05-12 12:59:22 +01:00
Peter Steinberger
756f9bb2f1 test: dedupe usage sessions mock calls 2026-05-12 12:57:39 +01:00
Peter Steinberger
5940d0d4b1 test: dedupe codex approval gateway mock calls 2026-05-12 12:55:50 +01:00
Peter Steinberger
3c82b144bb test: dedupe mattermost send mock calls 2026-05-12 12:53:52 +01:00
Peter Steinberger
32d5cd9a28 test: dedupe channels list log mock calls 2026-05-12 12:50:26 +01:00
Peter Steinberger
6d10e7d784 test: dedupe gateway hook run mock calls 2026-05-12 12:48:42 +01:00
Peter Steinberger
632c1bc0ba test: dedupe brave fetch mock calls 2026-05-12 12:45:31 +01:00
Super Zheng
4223dd2886 fix: enable native require fast path on Windows for plugin-sdk root alias (#80878)
Merged via squash.

Prepared head SHA: 87446445b6
Co-authored-by: medns <1575008+medns@users.noreply.github.com>
Co-authored-by: odysseus0 <8635094+odysseus0@users.noreply.github.com>
Reviewed-by: @odysseus0
2026-05-12 04:43:55 -07:00
Super Zheng
a92d5fe77d feat(agents): make run loop retry limits configurable in openclaw.json (#80661)
Merged via squash.

Prepared head SHA: d595d51a5a
Co-authored-by: medns <1575008+medns@users.noreply.github.com>
Co-authored-by: odysseus0 <8635094+odysseus0@users.noreply.github.com>
Reviewed-by: @odysseus0
2026-05-12 04:43:12 -07:00
Peter Steinberger
8a051395b7 test: dedupe matrix handler send mock calls 2026-05-12 12:42:04 +01:00
Super Zheng
380daf2f50 feat(gateway): inject isHeartbeat into agent event broadcast payload (#80610)
Merged via squash.

Prepared head SHA: cb254108a1
Co-authored-by: medns <1575008+medns@users.noreply.github.com>
Co-authored-by: odysseus0 <8635094+odysseus0@users.noreply.github.com>
Reviewed-by: @odysseus0
2026-05-12 04:41:14 -07:00
Peter Steinberger
4e29ee516b test: dedupe slack interaction mock calls 2026-05-12 12:39:58 +01:00
Ayaan Zaidi
f506ced2b3 docs(changelog): note onboarding auth fix (#80913) (thanks @rubencu) 2026-05-12 17:08:18 +05:30
Ayaan Zaidi
a6faeecf52 refactor(onboard): simplify model auth candidates 2026-05-12 17:08:18 +05:30
Rubén Cuevas
9600646449 test(onboard): type model check auth mocks 2026-05-12 17:08:18 +05:30
Rubén Cuevas
379ba2e8ae fix(onboard): short-circuit model auth check 2026-05-12 17:08:18 +05:30
Rubén Cuevas
31eaa106c5 fix(onboard): accept Codex auth in model check 2026-05-12 17:08:18 +05:30
Peter Steinberger
74fbbf503f test: dedupe matrix approval mock calls 2026-05-12 12:37:16 +01:00
Peter Steinberger
ed53339f8f test: dedupe mcp transport fetch mock calls 2026-05-12 12:34:57 +01:00
Peter Steinberger
dc0ebdfef8 test: guard codex command mock calls 2026-05-12 12:31:16 +01:00
Peter Steinberger
275acdaeba test: guard feishu reply dispatcher mock calls 2026-05-12 12:29:09 +01:00
Peter Steinberger
0c6cc68eb3 test: guard slack slash mock calls 2026-05-12 12:27:12 +01:00
Peter Steinberger
75f5d6d9b5 test: guard auto reply media mock calls 2026-05-12 12:24:20 +01:00
Peter Steinberger
3e3057509b test: dedupe models auth status mock calls 2026-05-12 12:22:21 +01:00
Peter Steinberger
837cb8f5b0 test: dedupe doctor memory note assertions 2026-05-12 12:20:31 +01:00
Ayaan Zaidi
3718ef1985 docs(agents): distill PR routing guidance 2026-05-12 16:50:29 +05:30
Rubén Cuevas
3fe2c0e71f docs: clarify PR workflow gitcrawl fallback 2026-05-12 16:50:29 +05:30
Peter Steinberger
50c31707fa test: dedupe tools effective mock calls 2026-05-12 12:18:49 +01:00
Peter Steinberger
30c17fed20 test: guard whatsapp send api mock calls 2026-05-12 12:16:20 +01:00
Peter Steinberger
3a4c97c291 test: guard server chat agent event mock calls 2026-05-12 12:14:15 +01:00
Peter Steinberger
8846a2a89f test: guard voice call mock calls 2026-05-12 12:12:14 +01:00
Ayaan Zaidi
5abb4b18c8 fix(telegram): simplify context boundary plumbing 2026-05-12 16:40:42 +05:30
VACInc
afd7339bd2 fix telegram context session start boundary 2026-05-12 16:40:42 +05:30
VACInc
b31afcbc17 fix telegram context reset boundary 2026-05-12 16:40:42 +05:30
Peter Steinberger
d3e39f0c94 test: dedupe models status log parsing 2026-05-12 12:10:08 +01:00
Peter Steinberger
1e5b12ae73 test: guard node invoke wake mock calls 2026-05-12 12:08:05 +01:00
Peter Steinberger
efacb91818 test: guard control ui http mock calls 2026-05-12 12:06:00 +01:00
Ayaan Zaidi
1675b2ff30 docs(changelog): mention docker auth profile key mount (#80991) 2026-05-12 16:35:53 +05:30
Ayaan Zaidi
c025291df7 docs(docker): document auth profile key mount 2026-05-12 16:35:53 +05:30
Ayaan Zaidi
c3e3146639 fix(docker): persist auth profile key mount 2026-05-12 16:35:53 +05:30
Pavan Kumar Gondhi
3aeb55b5e7 fix(node-pairing): replace changed pending requests [AI] (#80894)
* fix: replace changed node pairing requests

* fix: replace changed node pairing requests

* addressing codex review

* addressing codex review

* addressing ci

* fix: complete node pairing permission handling

* addressing review-skill

* addressing codex review

* addressing codex review

* addressing ci

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 16:33:55 +05:30
Peter Steinberger
3013369e99 test: guard migrate command mock calls 2026-05-12 12:03:52 +01:00
Pavan Kumar Gondhi
1b22384c11 Rate limit Google Chat webhook requests [AI] (#80974)
* fix: rate limit google chat webhook requests

* addressing claude review

* addressing ci

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 16:31:28 +05:30
Peter Steinberger
a943e4b766 test: guard model picker mock calls 2026-05-12 12:00:08 +01:00
Peter Steinberger
eb422fe44b test: guard diagnostics otel mock calls 2026-05-12 11:58:43 +01:00
Peter Steinberger
69298b18cf test: guard feishu drive mock calls 2026-05-12 11:57:20 +01:00
Pavan Kumar Gondhi
8c9dbe3e71 fix(feishu): normalize webhook rate-limit client keys [AI] (#80975)
* fix: normalize Feishu webhook rate limit keys

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 16:26:12 +05:30
Peter Steinberger
636636ca92 test: guard google meet mock calls 2026-05-12 11:56:05 +01:00
Peter Steinberger
7625a8b6d6 test: guard openresponses mock calls 2026-05-12 11:54:29 +01:00
Peter Steinberger
f82b9adfb1 test: guard matrix send mock calls 2026-05-12 11:52:11 +01:00
Peter Steinberger
0586da70db test: guard telegram bot core mock calls 2026-05-12 11:50:44 +01:00
Peter Steinberger
4ea089b7fe test: guard auto-reply dispatch mock calls 2026-05-12 11:45:09 +01:00
Peter Steinberger
aa9799320d test: guard telegram bot mock calls 2026-05-12 11:42:50 +01:00
Pavan Kumar Gondhi
2d00bedc1e fix(auth): prevent bootstrap pairing scope changes [AI] (#80976)
* fix: prevent bootstrap pairing scope changes before redemption

* docs: add changelog entry for PR merge
2026-05-12 16:11:35 +05:30
Peter Steinberger
abd2ba1fe0 test: guard telegram send mock calls 2026-05-12 11:40:13 +01:00
Peter Steinberger
a12caa8b86 test: guard outbound delivery mock calls 2026-05-12 11:38:39 +01:00
Peter Steinberger
4bc47a3a75 test: guard telegram delivery mock calls 2026-05-12 11:37:03 +01:00
Pavan Kumar Gondhi
5ef8d1ab5e Validate Control UI loopback retry endpoints [AI] (#80900)
* fix: validate loopback retry endpoints

* fix: validate loopback retry endpoints

* docs: add changelog entry for PR merge
2026-05-12 16:06:00 +05:30
Pavan Kumar Gondhi
fd12a48ee1 Harden exported markdown link rendering [AI] (#80902)
* fix: sanitize exported markdown links

* fix: sanitize exported markdown links

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 16:05:19 +05:30
Pavan Kumar Gondhi
da6f32bedf fix(gateway): honor minimal discovery mode for wide-area DNS-SD [AI] (#80903)
* fix: respect discovery mode for wide-area cli path

* addressing codex review

* docs: add changelog entry for PR merge
2026-05-12 16:03:50 +05:30
Peter Steinberger
d164f8cc74 test: guard qa matrix mock call assertions 2026-05-12 11:31:18 +01:00
Pavan Kumar Gondhi
889afc7c31 slack: enforce reaction notification policy [AI] (#80907)
* fix: enforce slack reaction notification policy

* addressing claude review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 16:00:44 +05:30
Pavan Kumar Gondhi
652f5f9b10 Enforce gateway command scopes by caller context [AI] (#80891)
* fix: enforce gateway command scopes by caller context

* fix: enforce gateway command scopes by caller context

* addressing codex review

* addressing claude review

* addressing claude review

* addressing ci

* docs: add changelog entry for PR merge
2026-05-12 15:59:22 +05:30
Peter Steinberger
be5483f240 test: guard core mock call assertions 2026-05-12 11:29:16 +01:00
Pavan Kumar Gondhi
a4da627da1 Enforce Slack plugin approval button authorization [AI] (#80899)
* fix: enforce slack plugin approval button authorization

* fix: enforce slack plugin approval button authorization

* addressing codex review

* addressing codex review

* docs: add changelog entry for PR merge
2026-05-12 15:56:24 +05:30
Peter Steinberger
97b9d77196 test: guard extension runtime mock calls 2026-05-12 11:24:21 +01:00
Ayaan Zaidi
485e04266c docs(changelog): note telegram html rendering fix (#80977) 2026-05-12 15:54:01 +05:30
Ayaan Zaidi
f6adc78f06 fix(telegram): keep durable html unsanitized 2026-05-12 15:54:01 +05:30
Ayaan Zaidi
b480b29dc7 fix(telegram): preserve supported html replies 2026-05-12 15:54:01 +05:30
Pavan Kumar Gondhi
de47989731 Recognize PowerShell -ec inline commands [AI] (#80893)
* fix: recognize PowerShell -ec inline command flag

* fix: recognize PowerShell -ec inline command flag

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* addressing codex review

* fix: recognize PowerShell encoded command prefixes

* addressing review-skill

* addressing review-skill

* addressing codex review

* addressing codex review

* docs: add changelog entry for PR merge
2026-05-12 15:53:10 +05:30
Pavan Kumar Gondhi
6e498a1f62 fix(qqbot): authorize approval button callbacks [AI] (#80892)
* fix: authorize qqbot approval buttons

* fix: authorize qqbot approval buttons

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 15:51:13 +05:30
Peter Steinberger
2ec1a27c9f test: guard extension channel mock calls 2026-05-12 11:19:53 +01:00
Peter Steinberger
6a230a108a test: guard extension messaging mock calls 2026-05-12 11:15:37 +01:00
Peter Steinberger
ea05be12b4 test: guard extension provider mock calls 2026-05-12 11:11:04 +01:00
Shakker
7bb2d20303 test: remove duplicate gateway startup case 2026-05-12 11:09:49 +01:00
Peter Steinberger
04139a7d44 test: guard extension app mock calls 2026-05-12 11:07:04 +01:00
Peter Steinberger
7215945b06 test: guard gateway infra mock calls 2026-05-12 11:03:37 +01:00
Peter Steinberger
7a9f770a63 test: guard command model mock calls 2026-05-12 11:00:43 +01:00
Pavan Kumar Gondhi
47eb2d48d4 Scrub streamable MCP redirect headers [AI] (#80906)
* fix: scrub streamable mcp redirect headers

* addressing review-skill

* addressing codex review

* addressing claude review

* docs: add changelog entry for PR merge
2026-05-12 15:28:54 +05:30
Peter Steinberger
e196a43694 test: guard auto reply runner mock calls 2026-05-12 10:58:34 +01:00
Peter Steinberger
81b7d670cd test: guard cron infra ui mock calls 2026-05-12 10:56:25 +01:00
Peter Steinberger
067666df90 test: guard gateway call assertions 2026-05-12 10:53:58 +01:00
Ayaan Zaidi
99598284c1 docs(changelog): credit matrix runtime install fix (#80876) (thanks @kinjitakabe) 2026-05-12 15:22:10 +05:30
Ayaan Zaidi
0792223a87 refactor(matrix): simplify dependency availability check 2026-05-12 15:22:10 +05:30
kinjitakabe
760501fc38 fix(matrix): stop runtime npm install from parent-derived cwd
`ensureMatrixSdkInstalled` previously derived an install `cwd` via fixed
two-segment traversal from `import.meta.url` and spawned `npm install`
(or `pnpm install`) when Matrix packages were missing. Under the
externalized plugin layout the derived path is a scope directory like
`<config>/npm/node_modules/@openclaw`, so npm walks up to the managed
project root and prunes undeclared siblings. Under the legacy bundled
layout it would target `<global-prefix>/lib/node_modules` and could
delete unrelated global CLIs.

Matrix is now a pure availability check: if any required package fails
to resolve, it throws an actionable error pointing the operator at the
supported repair commands (`openclaw plugins update matrix`,
`openclaw doctor --fix`). This matches extensions/AGENTS.md:
"Runtime never installs deps; install/update/doctor are repair points."

The exported signature stays backwards-compatible (all params optional;
`confirm` and `runtime` are accepted but ignored). `resolveMissingMatrixPackages`
gains an optional `resolveFn` seam for testability, mirroring the existing
`ensureMatrixCryptoRuntime` injection pattern.

Fixes #80758.
2026-05-12 15:22:10 +05:30
Peter Steinberger
067e83d121 test: guard command call assertions 2026-05-12 10:50:38 +01:00
Pavan Kumar Gondhi
aeb1ba9a53 fix(memory-wiki): require admin scope for ingest [AI] (#80897)
* fix: require admin scope for wiki ingest

* fix: require admin scope for wiki ingest

* docs: add changelog entry for PR merge

* docs: add changelog entry for PR merge
2026-05-12 15:19:43 +05:30
Pavan Kumar Gondhi
c3f1f0c315 memory-wiki: require write scope for Obsidian search [AI] (#80904)
* fix: require write scope for obsidian search

* docs: add changelog entry for PR merge
2026-05-12 15:18:07 +05:30
Peter Steinberger
768637a595 test: guard auto reply command mock calls 2026-05-12 10:47:16 +01:00
Shakker
163eb08a34 test: require minimax voice catalog 2026-05-12 10:45:45 +01:00
Ayaan Zaidi
47698133f6 fix(matrix): land markdown table default (#80890) (thanks @kinjitakabe) 2026-05-12 15:15:05 +05:30
Ayaan Zaidi
8841a82f5c fix(matrix): clean markdown table default PR 2026-05-12 15:15:05 +05:30
kinjitakabe
09a2d6e571 fix(matrix): default markdown tables to bullets across Matrix clients
Matrix outbound markdown was hitting the shared `resolveMarkdownTableMode`
"code" fallback for every send because the Matrix channel plugin never
declared `defaultMarkdownTableMode` in its `messaging` block at
`extensions/matrix/src/channel.ts:452`. Tables were emitted as
`<pre><code>` fenced blocks across every Matrix client.

This change declares `defaultMarkdownTableMode: "bullets"`, matching the
Signal and WhatsApp precedent at `extensions/signal/src/shared.ts:111`
and `extensions/whatsapp/src/shared.ts:261`. The choice matches the
cross-client compatibility profile the issue filer surveyed:
Element X iOS squashes HTML `<table>` and Element X Android drops cell
text entirely (element-hq/element-x-android#1551), while bullet lists
render cleanly across every Matrix client. Operators wanting the
previous fenced-code rendering can set `channels.matrix.markdown.tables:
"code"` explicitly; clients that do render real tables can opt in with
`channels.matrix.markdown.tables: "off"` (markdown-it's `table` rule is
already enabled by default through the markdown-it default preset, so
raw markdown tables flow through to native HTML tables on that path).

Docs and the changelog entry list Matrix alongside Signal and WhatsApp
as a bullet-default channel.

Fixes #78990.
2026-05-12 15:15:05 +05:30
Peter Steinberger
9d4081b839 test: guard core support mock calls 2026-05-12 10:43:53 +01:00
Peter Steinberger
138421b6c6 test: guard gateway session mock calls 2026-05-12 10:39:47 +01:00
Peter Steinberger
a68b4a5606 test: guard gateway mock calls 2026-05-12 10:36:44 +01:00
Peter Steinberger
17237fc44f test: align release validation expectations 2026-05-12 10:32:29 +01:00
Peter Steinberger
17863b0612 test: guard status command mock calls 2026-05-12 10:31:29 +01:00
Shakker
dc70841f8b test: assert imessage reaction context 2026-05-12 10:29:47 +01:00
Peter Steinberger
7a8d86be27 test: guard doctor command mock calls 2026-05-12 10:29:04 +01:00
Peter Steinberger
b37a71f2af test: guard command mock calls 2026-05-12 10:26:20 +01:00
Shakker
f093033ee8 test: pin silent reply fallback text 2026-05-12 10:23:29 +01:00
Peter Steinberger
8e045f6670 test: guard auto reply mock calls 2026-05-12 10:22:53 +01:00
Peter Steinberger
b42227e476 test: guard whatsapp mock calls 2026-05-12 10:19:51 +01:00
Shakker
54bbf40add test: pin invalid-config restart guidance 2026-05-12 10:17:17 +01:00
Peter Steinberger
22667fb096 test: guard messaging extension mock calls 2026-05-12 10:16:36 +01:00
Shakker
43332ce3fa test: check post-core helper calls 2026-05-12 10:15:22 +01:00
Shakker
3c47ab331e test: check post-core warning payloads 2026-05-12 10:14:08 +01:00
Shakker
10372bd23e test: check delivery retry backoff 2026-05-12 10:12:59 +01:00
Shakker
fcfa2617a8 test: check plugin payload failures 2026-05-12 10:11:43 +01:00
Peter Steinberger
cce9a9ef2a test: guard mixed extension mock calls 2026-05-12 10:10:52 +01:00
Shakker
135071b33f test: check media read roots 2026-05-12 10:08:06 +01:00
Peter Steinberger
1e46929d3e test: guard matrix mock calls 2026-05-12 10:07:36 +01:00
Peter Steinberger
b3ded351e3 test: guard extension provider mock calls 2026-05-12 10:04:45 +01:00
Shakker
dbbb7f0aaf test: check skills json formatting 2026-05-12 10:01:24 +01:00
Peter Steinberger
a765668e63 test: guard extension one-hit mock calls 2026-05-12 10:00:29 +01:00
Peter Steinberger
7965342425 test: guard subagent announce mock calls 2026-05-12 09:57:19 +01:00
Peter Steinberger
20319d6909 test: guard embedded attempt mock calls 2026-05-12 09:54:18 +01:00
Peter Steinberger
e3c674d64b test: guard cli runner mock calls 2026-05-12 09:51:50 +01:00
Peter Steinberger
98bf4ed640 test: guard agent cli attempt mock calls 2026-05-12 09:50:11 +01:00
Peter Steinberger
ce67f75930 test: guard agent eight-hit mock calls 2026-05-12 09:48:23 +01:00
Peter Steinberger
e4498e0cd5 test: guard agent seven-hit mock calls 2026-05-12 09:45:55 +01:00
Shakker
db30000220 test: check logs follow notices 2026-05-12 09:45:01 +01:00
Peter Steinberger
2b295a5679 test: guard agent six-hit mock calls 2026-05-12 09:43:16 +01:00
Peter Steinberger
69f3ac80df test: guard agent five-hit mock calls 2026-05-12 09:40:35 +01:00
Peter Steinberger
2afca35577 test: guard agent four-hit mock calls 2026-05-12 09:34:12 +01:00
Shakker
dda4632d38 test: check progress log output 2026-05-12 09:29:45 +01:00
Peter Steinberger
be911a1d74 test: guard remaining three-hit mock calls 2026-05-12 09:27:45 +01:00
Shakker
9cc4827e9b test: check qmd update defaults 2026-05-12 09:27:28 +01:00
Peter Steinberger
521ac5da42 test: guard embedded three-hit mock calls 2026-05-12 09:25:20 +01:00
Shakker
c920053005 test: check startup memory stat failure 2026-05-12 09:25:09 +01:00
Peter Steinberger
ac017fa443 test: guard agent model config mock calls 2026-05-12 09:22:10 +01:00
Shakker
f34faf2f1c test: check diagnostics metric payloads 2026-05-12 09:20:29 +01:00
Peter Steinberger
d2ae92ad1f test: guard agent three-hit mock calls 2026-05-12 09:18:40 +01:00
Peter Steinberger
48576e7225 test: guard subagent mock calls 2026-05-12 09:15:36 +01:00
Peter Steinberger
80a9072c9e test: guard sandbox skills mock calls 2026-05-12 09:13:33 +01:00
Peter Steinberger
c6cfd12228 test: guard before tool call mock calls 2026-05-12 09:11:08 +01:00
Peter Steinberger
6252f2a097 test: guard agent two-hit mock calls 2026-05-12 09:06:01 +01:00
Peter Steinberger
e16b80a829 test: guard remaining agent mock calls 2026-05-12 09:03:39 +01:00
Peter Steinberger
e024362c20 test: guard agent utility mock calls 2026-05-12 09:00:38 +01:00
Peter Steinberger
ee40b9bbbd test: guard embedded subscribe mock calls 2026-05-12 08:58:04 +01:00
Peter Steinberger
16adcc75b0 test: guard embedded runner mock calls 2026-05-12 08:55:12 +01:00
Peter Steinberger
cb059e4006 test: guard agent runtime mock calls 2026-05-12 08:52:32 +01:00
Peter Steinberger
96288dd19c test: guard agent harness mock calls 2026-05-12 08:50:03 +01:00
Peter Steinberger
e78d0d505d test: guard agent cli mock calls 2026-05-12 08:47:34 +01:00
Peter Steinberger
7d75bffa17 fix: reuse package entry validation in update smoke 2026-05-12 08:44:00 +01:00
Peter Steinberger
be7ac231b8 test: guard agent auth bash mock calls 2026-05-12 08:42:59 +01:00
Peter Steinberger
cf885c25df test: guard pdf tool mock calls 2026-05-12 08:40:12 +01:00
Mariano
d728ff8183 fix(codex): release quiet completed app-server turns (#80776)
Merged via squash.

Prepared head SHA: 59baf4110b

Reviewed-by: @mbelinky
2026-05-12 09:39:09 +02:00
Peter Steinberger
6812215d4b test: guard message tool mock calls 2026-05-12 08:37:14 +01:00
Peter Steinberger
0fbbba0c6f ci: keep main push checks running 2026-05-12 08:35:36 +01:00
Peter Steinberger
a815ab9476 test: guard pdf provider mock calls 2026-05-12 08:34:47 +01:00
Peter Steinberger
8ee024df39 test: guard agent tool call assertions 2026-05-12 08:32:40 +01:00
Peter Steinberger
8c22d5aaaf test: guard agent image mock calls 2026-05-12 08:30:54 +01:00
Peter Steinberger
808ce04cc1 test: guard agent web mock calls 2026-05-12 08:29:21 +01:00
Peter Steinberger
815af80363 test: raise macos update smoke heap 2026-05-12 08:28:28 +01:00
Peter Steinberger
84b0c6240b test: guard agent tool mock calls 2026-05-12 08:27:13 +01:00
Peter Steinberger
1b964fac30 test: guard cron tool mock calls 2026-05-12 08:25:04 +01:00
Peter Steinberger
0b69446562 test: guard agent tool mock calls 2026-05-12 08:22:13 +01:00
Peter Steinberger
2a43e26b19 test: guard model catalog mock calls 2026-05-12 08:19:29 +01:00
Peter Steinberger
2feab20368 test: guard update cli mock calls 2026-05-12 08:17:33 +01:00
Peter Steinberger
da7f9a6267 test: guard runtime capture mock calls 2026-05-12 08:15:26 +01:00
Peter Steinberger
5ed2a9a4e2 test: guard config cli mock calls 2026-05-12 08:14:03 +01:00
Peter Steinberger
3d37afd3d2 test: guard capability cli mock calls 2026-05-12 08:12:14 +01:00
Peter Steinberger
ced66da8e1 test: guard exec approvals mock calls 2026-05-12 08:09:53 +01:00
Peter Steinberger
c070ea3974 test: guard gateway cli mock calls 2026-05-12 08:08:49 +01:00
Peter Steinberger
81d973e09d test: guard daemon cli mock calls 2026-05-12 08:07:34 +01:00
Peter Steinberger
af632f4d9e fix: raise update build heap 2026-05-12 08:06:44 +01:00
Peter Steinberger
aba8b00af3 test: guard program help mock calls 2026-05-12 08:05:29 +01:00
B.K.
109493bcdd fix(update): mandatory post-core plugin convergence before gateway restart
Summary:
- validate active plugin payloads, including openclaw.extensions entry files, after core package updates
- treat corrupt active install records without installPath as convergence failures
- prevent managed gateway recovery restart when post-core plugin convergence fails

Verification:
- CI=true pnpm test src/cli/update-cli/plugin-payload-validation.test.ts src/cli/update-cli/post-core-plugin-convergence.test.ts src/cli/update-cli.test.ts src/commands/doctor/shared/missing-configured-plugin-install.test.ts src/commands/doctor/shared/update-phase.test.ts
- CI=true pnpm check:changed
- PR checks green for 2afa84dffe
2026-05-12 08:02:10 +01:00
Peter Steinberger
e7ba2f9b0d test: guard maintenance mock calls 2026-05-12 08:01:40 +01:00
Peter Steinberger
a978f0fe36 test: guard nodes basic mock calls 2026-05-12 07:59:24 +01:00
Peter Steinberger
14042cff90 test: guard nodes media mock calls 2026-05-12 07:56:48 +01:00
Peter Steinberger
00d0d4bd19 test: guard nodes approval mock calls 2026-05-12 07:53:20 +01:00
Peter Steinberger
04a868b98d fix: skip metadata for build-excluded bundled plugins
Fix bundled plugin metadata copying to follow the build-entry set, so build-excluded plugins like QQ Bot do not leave stale dist metadata advertising missing runtime files.

Verification:
- pnpm test src/plugins/copy-bundled-plugin-metadata.test.ts test/scripts/bundled-plugin-build-entries.test.ts
- git diff --check
- pnpm openclaw gateway status --deep
- CI run 25718250461
- CodeQL run 25718250402
- CodeQL Critical Quality run 25718250418
- Real behavior proof run 25718290985
2026-05-12 07:51:11 +01:00
Peter Steinberger
a676366200 test: guard command secret target mock calls 2026-05-12 07:49:19 +01:00
Alex Naidis
a290cd633f fix(doctor): repair managed plugin peer links
Repair managed npm plugin OpenClaw peer links across doctor, install, and update flows.

- relink `peerDependencies.openclaw` packages under managed npm roots during doctor repair
- make read-only doctor preview broken peer links with a `doctor --fix` hint
- reject target plugin installs when their own peer link cannot be repaired, without blocking unrelated installs for stale sibling packages
- preserve update warning behavior for unrepairable package-local `node_modules`

Verification:
- `pnpm test src/plugins/plugin-peer-link.test.ts src/plugins/install.test.ts src/plugins/install.npm-spec.test.ts src/plugins/update.test.ts src/commands/doctor-plugin-registry.test.ts src/commands/doctor/repair-sequencing.test.ts -- --reporter=verbose`
- `pnpm exec oxfmt --check --threads=1 ...`
- `git diff --check`
- Crabbox/Testbox `tbx_01krde1jx199rnpm2rv1rdcj76`: focused tests + `pnpm check:changed`, exit 0
- Real CLI proof in PR body: read-only `openclaw doctor` warning plus `openclaw doctor --fix` symlink repair

Thanks @TheCrazyLex.
2026-05-12 07:49:08 +01:00
Peter Steinberger
ee1a278aea test: guard directory cli mock calls 2026-05-12 07:46:44 +01:00
Peter Steinberger
e7e3e903bf test: guard plugins list mock calls 2026-05-12 07:44:05 +01:00
Peter Steinberger
d40ffd95b0 test: guard plugin registry mock calls 2026-05-12 07:42:27 +01:00
Peter Steinberger
abb4f96b81 test: guard proxy cli mock calls 2026-05-12 07:40:36 +01:00
Peter Steinberger
bd3c2e75ca test: guard qr cli mock calls 2026-05-12 07:39:18 +01:00
Peter Steinberger
5908826599 test: guard command secret mock calls 2026-05-12 07:36:47 +01:00
Peter Steinberger
f863447fe1 test: guard cli route mock calls 2026-05-12 07:33:28 +01:00
Peter Steinberger
4f7ce2aa6f docs: capture crabbox before-after proof learnings 2026-05-12 07:33:24 +01:00
Peter Steinberger
a4784c955e build: refresh canvas a2ui bundle hash 2026-05-12 07:31:57 +01:00
Peter Steinberger
dd0c34f5df test: guard cli utils mock calls 2026-05-12 07:31:37 +01:00
Peter Steinberger
3b82156dff test: guard node cli mock calls 2026-05-12 07:29:54 +01:00
Peter Steinberger
3d93d127f3 test: guard gateway run mock calls 2026-05-12 07:28:41 +01:00
Zennn
39005e6aa7 Fix TUI exit after gateway disconnect (#75381)
* fix(tui): exit after gateway disconnect

* test(gateway): avoid uuid lint false positive

* test(extensions): avoid core ansi helper imports

* test: fix strip ansi helper conflicts

---------

Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-12 07:27:54 +01:00
Peter Steinberger
14cb165ddd test: guard acp cli mock calls 2026-05-12 07:27:12 +01:00
Peter Steinberger
a12b9444f1 test: guard system cli mock calls 2026-05-12 07:26:05 +01:00
Peter Steinberger
af0345f824 fix: harden dev update validation 2026-05-12 07:25:36 +01:00
Peter Steinberger
65df09647c test: guard plugins update mock calls 2026-05-12 07:23:49 +01:00
Peter Steinberger
131c415de0 test: guard models cli mock calls 2026-05-12 07:22:36 +01:00
Peter Steinberger
dad240eecd test: guard gateway run loop mock calls 2026-05-12 07:20:43 +01:00
Peter Steinberger
5a432aacd7 test: guard gateway register mock calls 2026-05-12 07:19:14 +01:00
Gabriel
53fedc7084 refactor: unify stableStringify implementations (#80457)
Centralize agent stable serialization for cache tracing, models config fingerprinting, and tool-loop hashing.

Adds focused coverage for sorted keys, true cycles, repeated references, cache-trace edge types, and circular tool-call hashing.

Verification:
- pnpm test src/agents/stable-stringify.test.ts src/agents/tool-loop-detection.test.ts src/agents/cache-trace.test.ts -- --reporter=verbose
- OPENCLAW_TESTBOX=0 pnpm check:changed
- GitHub CI: https://github.com/openclaw/openclaw/actions/runs/25716851500
- Real behavior proof: https://github.com/openclaw/openclaw/actions/runs/25717047037

Co-authored-by: Gabriel Piss <gabriel@gabeos.dev>
2026-05-12 07:18:53 +01:00
Peter Steinberger
976593bc5c test: guard program smoke mock calls 2026-05-12 07:17:42 +01:00
Peter Steinberger
acd8236ef2 test: guard channel auth mock calls 2026-05-12 07:15:51 +01:00
Peter Steinberger
7411396dbc test: guard tts contract mock calls 2026-05-12 07:14:25 +01:00
Peter Steinberger
f71aa4504a test: guard scheduled turn mock calls 2026-05-12 07:11:58 +01:00
Peter Steinberger
f6d787cc5c build: hard-pin dependency specs 2026-05-12 07:10:13 +01:00
Peter Steinberger
525e0267b1 test: guard session attachment mock calls 2026-05-12 07:09:31 +01:00
Kaspre
e30e4d1cfa test(extensions): narrow post-rebase type assertions 2026-05-12 07:08:38 +01:00
Kaspre
5375281974 fix(plugins): load untracked TS source plugins 2026-05-12 07:08:38 +01:00
Peter Steinberger
f285e53d5b test: guard runtime index mock calls 2026-05-12 07:06:58 +01:00
Peter Steinberger
6bdfb39937 test: guard runtime llm mock calls 2026-05-12 07:05:44 +01:00
Peter Steinberger
cccbfbf85c test: guard metadata registry mock calls 2026-05-12 07:04:36 +01:00
Peter Steinberger
e00f7dc0bf test: guard marketplace mock calls 2026-05-12 07:03:32 +01:00
Neerav Makwana
0ac4837878 fix(media): default terminal QR to full-block output (#77820)
Avoid node-qrcode compact (small) terminal mode, which emits a dense
ANSI final row that breaks scanning on some terminals.

Covers WhatsApp/Feishu login flows and the pairing QR CLI path.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-12 07:03:12 +01:00
Peter Steinberger
5b1d1eac12 test: guard wired hook mock calls 2026-05-12 07:02:19 +01:00
Peter Steinberger
469da5b111 test: guard install path mock calls 2026-05-12 07:01:15 +01:00
Peter Steinberger
18ead60fc1 test: guard web fetch provider mock calls 2026-05-12 07:00:06 +01:00
Peter Steinberger
433634066c test: guard plugin install mock calls 2026-05-12 06:57:58 +01:00
Peter Steinberger
0c2068fddb test: guard provider runtime mock calls 2026-05-12 06:56:44 +01:00
Shakker
2dc6b76f47 test: check qmd probe cleanup 2026-05-12 06:54:26 +01:00
Peter Steinberger
7917632e01 fix: preserve subagent session picker order (#78623) 2026-05-12 06:53:51 +01:00
chinar-amrutkar
595cc5d0dc Control UI/sessions: fix subagent nesting label prefix and ordering
- Strip "Subagent: " prefix before adding "└─ " prefix
- Insert child sessions immediately after their parent in the dropdown list
2026-05-12 06:53:51 +01:00
chinar-amrutkar
1f1817a904 Control UI/sessions: nest subagent sessions under parent with visual prefix
Subagent sessions now appear in the session picker dropdown with a "└─ "
prefix and are linked to their parent via the parentKey field when the
parent session is also present in the session list.

Fixes #77628
2026-05-12 06:53:51 +01:00
Peter Steinberger
0eb50f9f8d test: guard module loader cache mock calls 2026-05-12 06:52:40 +01:00
Shakker
e657bff6a3 test: count group runtime loads 2026-05-12 06:52:29 +01:00
Peter Steinberger
2dc0072547 build: refresh canvas a2ui bundle hash 2026-05-12 06:51:48 +01:00
Peter Steinberger
7b71987627 test: guard git install mock calls 2026-05-12 06:51:09 +01:00
remdev
a3e534c677 fix(openrouter): address stt review follow-ups
Map `.mp4` filename fallback to `m4a` so audio attachments with missing MIME resolve correctly, and fix changelog attribution formatting flagged in PR review.
2026-05-12 06:50:12 +01:00
remdev
f756b9a6f1 fix(openrouter): normalize stt mime parsing 2026-05-12 06:50:12 +01:00
remdev
5c87b692cb feat(openrouter): add inbound audio STT support 2026-05-12 06:50:12 +01:00
Peter Steinberger
0543448df8 test: guard channel catalog mock calls 2026-05-12 06:49:41 +01:00
Shakker
28adb8efb0 test: count directory cli calls 2026-05-12 06:49:21 +01:00
Peter Steinberger
0eceaefda9 test: guard setup registry mock calls 2026-05-12 06:47:54 +01:00
Shakker
5e5094a7b6 test: count compaction followup replies 2026-05-12 06:47:14 +01:00
Peter Steinberger
ce7e7a2834 fix: normalize oauth default model patches 2026-05-12 06:45:15 +01:00
Shakker
a90f65cf2a test: check acp session metadata writes 2026-05-12 06:45:08 +01:00
Shakker
2dd79fb8dc test: count followup delivery calls 2026-05-12 06:42:51 +01:00
Shakker
042a8f106e test: count inline tool execution 2026-05-12 06:41:01 +01:00
Peter Steinberger
5aede953ad test: guard channel send and stat overloads 2026-05-12 06:37:52 +01:00
Shakker
842cadda26 test: count inline action cleanup 2026-05-12 06:35:10 +01:00
Peter Steinberger
c98698aa0e chore: release 2026.5.12-beta.1 2026-05-12 06:33:41 +01:00
Shakker
9ba23d1804 test: check config write metadata 2026-05-12 06:32:17 +01:00
Peter Steinberger
f55491b208 chore: update dependencies 2026-05-12 06:31:48 +01:00
Peter Steinberger
26cc9bf2ef test: guard update cli mock calls 2026-05-12 06:31:29 +01:00
Shakker
b88965efc0 test: count plugin registry lookup 2026-05-12 06:30:33 +01:00
Peter Steinberger
b066819dda test: guard cron heartbeat target mock calls 2026-05-12 06:29:21 +01:00
Shakker
f36079b5af test: check plugin config mutation calls 2026-05-12 06:29:11 +01:00
Peter Steinberger
3f5557f92b test: guard plugin sdk mock calls 2026-05-12 06:26:47 +01:00
Peter Steinberger
6d35fb81d4 test: guard plugin sdk acp mock call 2026-05-12 06:23:28 +01:00
Shakker
b33951591e test: count typing signaler calls 2026-05-12 06:22:25 +01:00
Peter Steinberger
71c8d2405d build: forward-port release packaging fixes 2026-05-12 06:21:10 +01:00
Peter Steinberger
1ed83d0ed2 test: use renamed pi ai package
(cherry picked from commit 3c51059ae4)
2026-05-12 06:21:10 +01:00
Peter Steinberger
2e8f8f8b3a fix: keep release fast pretag check branch-safe
(cherry picked from commit 5a14f7b500)
2026-05-12 06:21:10 +01:00
Peter Steinberger
38593cc8fc fix: preserve beta verifier parse errors
(cherry picked from commit 454f6ed402)
2026-05-12 06:21:10 +01:00
Peter Steinberger
a4acd33097 ci: speed up beta release verification
(cherry picked from commit 7ca9b58a27)
2026-05-12 06:21:09 +01:00
Altay
db4c72c53d fix(ci): keep Docker patch smoke on pnpm workspace config
(cherry picked from commit c501d4b923)
2026-05-12 06:21:09 +01:00
Peter Steinberger
abb5fc6522 build: refresh generated protocol models
(cherry picked from commit b8b948e208)
2026-05-12 06:21:09 +01:00
scoootscooob
294cdf973b fix: reread config on in-process gateway restart (#80161)
* fix: reread config on in-process gateway restart

* fix: refresh swift protocol model

(cherry picked from commit 537bcada37)
2026-05-12 06:21:09 +01:00
Peter Steinberger
d86cf646fc ci: skip OpenAI install tool smoke
(cherry picked from commit 50f229c0f6)
2026-05-12 06:21:09 +01:00
Peter Steinberger
50f62beb8a ci: use faster OpenAI model for installer proof
(cherry picked from commit d05ed07260)
2026-05-12 06:21:09 +01:00
Peter Steinberger
9297e1c0e9 ci: parallelize OpenAI installer proof turns
(cherry picked from commit 690eb73520)
2026-05-12 06:21:09 +01:00
Peter Steinberger
25e513e078 fix(agents): preserve OpenAI event streams
(cherry picked from commit 5d8b500929)
2026-05-12 06:21:09 +01:00
Peter Steinberger
2682d5efab test(agents): type stream setup timeout mock
(cherry picked from commit 5157ee268f)
2026-05-12 06:21:09 +01:00
Peter Steinberger
40db71b320 fix(agents): cap provider setup timeout
(cherry picked from commit 575ee22448)
2026-05-12 06:21:09 +01:00
Peter Steinberger
19a3962f9a fix(agents): abort timed out stream setup
(cherry picked from commit dccf55ffb6)
2026-05-12 06:21:09 +01:00
Peter Steinberger
a7668e8257 fix(agents): enforce idle timeout during stream setup
(cherry picked from commit 7d5cccaef4)
2026-05-12 06:21:09 +01:00
Peter Steinberger
c0b443aa9f ci: use current OpenAI model for release smokes
(cherry picked from commit 72ffd3a464)
2026-05-12 06:21:09 +01:00
Shakker
fab8657f85 test: count followup cleanup signals 2026-05-12 06:20:45 +01:00
Ayaan Zaidi
ca9489b43a docs(changelog): note read eof offset fix (#75536) (thanks @vyctorbrzezowski) 2026-05-12 10:50:42 +05:30
Ayaan Zaidi
3c9c91fb35 fix(agents): treat read offsets past eof as empty 2026-05-12 10:50:42 +05:30
Peter Steinberger
2d69e3227a test: guard daemon install mock calls 2026-05-12 06:20:11 +01:00
Shakker
d68d8e6b2d test: count dispatch idle marker 2026-05-12 06:18:37 +01:00
Peter Steinberger
4f67eaee68 test: guard proxy validation mock call 2026-05-12 06:18:07 +01:00
Shakker
91f01917ca test: count realtime voice callbacks 2026-05-12 06:16:51 +01:00
Peter Steinberger
1e7d5d6201 test: guard fetch ssrf mock calls 2026-05-12 06:15:37 +01:00
Peter Steinberger
651c62040f test: guard daemon install integration mock call 2026-05-12 06:13:55 +01:00
Ayaan Zaidi
c3f310cc14 fix(agents): land post-compaction workspace refresh (#75532) (thanks @vyctorbrzezowski) 2026-05-12 10:42:46 +05:30
vyctorbrzezowski
d5c67d712e fix(agents): use run workspace for post-compaction context 2026-05-12 10:42:46 +05:30
Peter Steinberger
8b51d89d60 test: guard daemon lifecycle mock call 2026-05-12 06:12:16 +01:00
Shakker
354a6ddefd test: check minted gateway token format 2026-05-12 06:11:09 +01:00
Peter Steinberger
3c66de8010 test: guard daemon probe mock calls 2026-05-12 06:10:24 +01:00
Ayaan Zaidi
16cfc83643 ci(mantis): fix telegram run wait before checkout 2026-05-12 10:39:27 +05:30
Peter Steinberger
b859e0f2ba test: guard cron delivery dispatch mock call 2026-05-12 06:08:53 +01:00
Shakker
bec7217630 test: count compaction summary calls 2026-05-12 06:08:33 +01:00
Peter Steinberger
bf7e3ff94d test: guard cron model override mock call 2026-05-12 06:07:19 +01:00
Peter Steinberger
42aa65dcb4 test: guard cron skills snapshot mock call 2026-05-12 06:06:08 +01:00
Shakker
30083c796b test: check compaction auth lookup 2026-05-12 06:06:00 +01:00
Peter Steinberger
71f04eedbc test: guard cron model preflight mock call 2026-05-12 06:04:50 +01:00
Peter Steinberger
b7dfacd9bb test: guard cron payload fallback mock call 2026-05-12 06:03:40 +01:00
Shakker
48e62b7757 test: check orphan repair reply 2026-05-12 06:03:33 +01:00
Ayaan Zaidi
ef9a820949 docs(changelog): credit active memory Telegram DM fix (#75533) (thanks @vyctorbrzezowski) 2026-05-12 10:32:12 +05:30
Ayaan Zaidi
4b40daf0ee test(active-memory): clean threaded DM coverage 2026-05-12 10:32:12 +05:30
vyctorbrzezowski
1ee29fb0ae fix(active-memory): classify threaded telegram dms 2026-05-12 10:32:12 +05:30
Peter Steinberger
21fe98a77c test: tighten core mock call helpers 2026-05-12 06:01:12 +01:00
Peter Steinberger
c860104b22 test: guard cron interim retry mock calls 2026-05-12 05:58:34 +01:00
Shakker
6fdcb10480 test: check subagent announce dispatch 2026-05-12 05:58:21 +01:00
Peter Steinberger
d2a9b8405c test: guard daemon service mock call 2026-05-12 05:57:16 +01:00
Shakker
e6b32e6609 test: check compaction branch summary input 2026-05-12 05:56:35 +01:00
Peter Steinberger
e89d1b2593 test: guard ssrf dispatcher mock call 2026-05-12 05:56:05 +01:00
Peter Steinberger
8084cbc345 test: guard daemon restart mock call 2026-05-12 05:55:10 +01:00
Shakker
724e7dba0a test: check tool search controls 2026-05-12 05:54:02 +01:00
Peter Steinberger
e4a5dd9c91 test: guard doctor gateway mock call 2026-05-12 05:53:50 +01:00
Shakker
e3c9675e87 test: check context engine session keys 2026-05-12 05:51:23 +01:00
Peter Steinberger
503eee14a0 test: guard cron session key mock calls 2026-05-12 05:50:57 +01:00
Peter Steinberger
5efd4b8e88 test: guard status summary mock calls 2026-05-12 05:47:57 +01:00
Shakker
b62750ac7e test: check node media payloads 2026-05-12 05:44:51 +01:00
Peter Steinberger
29d478f866 test: guard plugin hooks mock call 2026-05-12 05:44:37 +01:00
Peter Steinberger
92a4bb6c33 test: guard plugin lifecycle mock calls 2026-05-12 05:43:04 +01:00
Peter Steinberger
ed6db3cd23 test: guard plugin services mock call 2026-05-12 05:41:21 +01:00
Andy Ye
7624b0d16d fix(imessage): surface Full Disk Access probe failures
Preserve canonical iMessage Full Disk Access probe failures through non-sensitive health snapshots and status output, promote imsg denial banners to the public remediation message, and add a narrow audit exception for the reviewed Mistral advisory false-positive.
2026-05-11 21:41:08 -07:00
Shakker
a6892a5af3 test: check sanitized bootstrap files 2026-05-12 05:40:48 +01:00
Peter Steinberger
3e1a3e1a36 test: guard cron ops mock calls 2026-05-12 05:39:31 +01:00
Peter Steinberger
900aa25efd test: guard doctor platform notes mock calls 2026-05-12 05:37:57 +01:00
Peter Steinberger
93c5e0c4e0 test: guard tui event mock call 2026-05-12 05:36:29 +01:00
Shakker
58becd8d8e test: check partial reply payloads 2026-05-12 05:35:44 +01:00
Peter Steinberger
91bdeaeea9 test: guard commands info mock call 2026-05-12 05:34:36 +01:00
Peter Steinberger
d7f6bf3693 test: guard gateway status mock calls 2026-05-12 05:33:08 +01:00
Shakker
7e5730921a test: isolate gateway start mock calls 2026-05-12 05:32:19 +01:00
Peter Steinberger
1e894369a0 test: guard auto-reply dispatch mock call 2026-05-12 05:31:20 +01:00
Peter Steinberger
b4b4a77f47 test: guard sdk status mock call 2026-05-12 05:30:01 +01:00
Shakker
6a36ba034e test: count plugin uninstall side effects 2026-05-12 05:28:51 +01:00
Peter Steinberger
66190a890c test: guard cli run-main mock call 2026-05-12 05:27:41 +01:00
Peter Steinberger
10d590a666 test: guard optional tool mock calls 2026-05-12 05:26:27 +01:00
Shakker
ef99cc670e test: check scoped command secret targets 2026-05-12 05:25:10 +01:00
Peter Steinberger
4fe8f98faa test: guard reply media mock calls 2026-05-12 05:24:34 +01:00
Peter Steinberger
74d7c3254b test: guard gateway shutdown mock calls 2026-05-12 05:23:26 +01:00
Shakker
e8f3b48555 test: count subagent registry persistence 2026-05-12 05:22:06 +01:00
Peter Steinberger
a786d8dfcb test: guard inbound claim logger mock calls 2026-05-12 05:20:50 +01:00
Peter Steinberger
ff7e6c7fb3 test: guard container spawn mock call 2026-05-12 05:19:12 +01:00
sallyom
e1795256d5 fix(docker): avoid external Dockerfile frontend pull
Signed-off-by: sallyom <somalley@redhat.com>
2026-05-12 00:19:04 -04:00
Peter Steinberger
9677da3dd6 test: guard usage command mock calls 2026-05-12 05:17:24 +01:00
Shakker
5638ace844 test: tighten cli output assertions 2026-05-12 05:16:58 +01:00
Peter Steinberger
ff54363dd4 test: guard channel loader jiti mock call 2026-05-12 05:15:49 +01:00
Peter Steinberger
be233081e2 test: guard session hook mock calls 2026-05-12 05:14:05 +01:00
Shakker
e35bc01ade test: count cli command calls 2026-05-12 05:13:33 +01:00
Peter Steinberger
78fd1f18c5 test: guard status usage mock calls 2026-05-12 05:11:36 +01:00
Peter Steinberger
35174ea046 test: guard plugin doctor jiti mock call 2026-05-12 05:10:19 +01:00
Peter Steinberger
17fd01e228 test: guard exec approval delivery mock calls 2026-05-12 05:09:05 +01:00
Peter Steinberger
0756f7501a test: guard exec policy config mock call 2026-05-12 05:07:27 +01:00
Shakker
3c430f10e6 test: count owned tool hook calls 2026-05-12 05:07:20 +01:00
Peter Steinberger
b56f68fedc test: guard cron enqueue mock calls 2026-05-12 05:06:07 +01:00
Peter Steinberger
39b6f06661 test: guard acp manager mock calls 2026-05-12 05:04:35 +01:00
Shakker
49cef49ff9 test: count model switch side effects 2026-05-12 05:04:25 +01:00
Peter Steinberger
43793f6e52 test: guard acp startup mock calls 2026-05-12 05:03:11 +01:00
Peter Steinberger
54f0ab2e73 test: guard acp stop reason mock call 2026-05-12 05:01:57 +01:00
Shakker
43eb72b27a test: count compaction hook calls 2026-05-12 05:01:32 +01:00
Peter Steinberger
31e33b029b test: guard acp permission relay mock call 2026-05-12 04:59:13 +01:00
Shakker
5c65a22c8c test: count gateway lock release 2026-05-12 04:58:02 +01:00
Peter Steinberger
3d8f8c8fcc test: guard outbound media mock calls 2026-05-12 04:57:27 +01:00
Peter Steinberger
43cb4d0447 fix: normalize gemini auth login default 2026-05-12 04:56:08 +01:00
Shakker
79f7fc6e19 test: guard downgrade update path 2026-05-12 04:55:15 +01:00
Shakker
187b4a6b79 test: assert indexed tagline 2026-05-12 04:52:12 +01:00
Peter Steinberger
897bc1c355 test: guard exec host socket mock calls 2026-05-12 04:49:33 +01:00
Shakker
bb817002cc test: count update follow-up calls 2026-05-12 04:49:01 +01:00
Peter Steinberger
7fd5d45ae4 test: guard shell env mock calls 2026-05-12 04:48:31 +01:00
Peter Steinberger
f34b1a4958 test: guard tui shell mock call 2026-05-12 04:46:56 +01:00
Peter Steinberger
afc05f85b7 test: guard message hook mock calls 2026-05-12 04:45:49 +01:00
Shakker
9f61642ba9 test: count prompt readline close 2026-05-12 04:45:41 +01:00
Peter Steinberger
02eccba8e6 test: guard channel status plugin mock call 2026-05-12 04:44:45 +01:00
Peter Steinberger
24f23cffe9 test: guard acp lifecycle mock calls 2026-05-12 04:43:50 +01:00
Shakker
23cc8f37b4 test: count restart helper unrefs 2026-05-12 04:43:07 +01:00
Peter Steinberger
b5eb214e4e test: guard launchd handoff mock calls 2026-05-12 04:42:36 +01:00
Peter Steinberger
e9d13cba0a test: guard session store write mock call 2026-05-12 04:41:22 +01:00
Peter Steinberger
c7d34ffee8 test: guard transcript update mock call 2026-05-12 04:40:17 +01:00
Shakker
4ebca4c314 test: count plugin install enable calls 2026-05-12 04:39:10 +01:00
Shakker
250b35691f test: count plugin install config reads 2026-05-12 04:36:27 +01:00
Peter Steinberger
352a394bcc test: guard plugin cleanup timeout mock call 2026-05-12 04:35:10 +01:00
Shakker
f9f232d8fb test: count plugin install refreshes 2026-05-12 04:33:35 +01:00
Peter Steinberger
51e83c4d23 test: guard configure gateway mock call 2026-05-12 04:32:39 +01:00
Peter Steinberger
315cfa47b4 test: guard backup verify mock call 2026-05-12 04:31:44 +01:00
Shakker
77138281ea test: count formatted bundled skills 2026-05-12 04:30:57 +01:00
Peter Steinberger
dc3654b544 test: guard backup registration mock call 2026-05-12 04:29:58 +01:00
Peter Steinberger
bf71a896d8 test: guard status registration mock call 2026-05-12 04:28:58 +01:00
Shakker
5cca9bad0d test: count secrets configure prompt 2026-05-12 04:28:15 +01:00
Peter Steinberger
c49ffedc1f test: guard plugin policy cli mock call 2026-05-12 04:27:47 +01:00
Peter Steinberger
3b85a4ba79 test: guard browser doctor mock call 2026-05-12 04:26:27 +01:00
Peter Steinberger
bf2b40866d test: guard agent runtime config mock calls 2026-05-12 04:25:34 +01:00
Shakker
366b5cf738 test: count channel login calls 2026-05-12 04:25:28 +01:00
Peter Steinberger
2b705957bb test: guard device pairing doctor mock calls 2026-05-12 04:24:38 +01:00
Shakker
fd05a6e9dd test: count routed plugin registry loads 2026-05-12 04:22:54 +01:00
Peter Steinberger
16ce9c1618 test: guard channel send mock calls 2026-05-12 04:22:10 +01:00
Peter Steinberger
6a1ae65b5c test: guard channel lifecycle mock calls 2026-05-12 04:21:01 +01:00
Shakker
d6e63ee3b2 test: count plugin uninstall planning 2026-05-12 04:19:18 +01:00
Peter Steinberger
f468f0f61f test: guard windows exec mock calls 2026-05-12 04:19:02 +01:00
Peter Steinberger
9433f7984b test: guard plugin uninstall mock call 2026-05-12 04:17:16 +01:00
Shakker
b2f3ae2a14 test: count session status store writes 2026-05-12 04:16:43 +01:00
Peter Steinberger
aac9028f89 test: guard fetch timeout mock calls 2026-05-12 04:16:12 +01:00
Peter Steinberger
339b0e164f fix: normalize gemini provider catalog defaults 2026-05-12 04:14:35 +01:00
Shakker
98c1d1f6f3 test: count fallback rate-limit checks 2026-05-12 04:13:34 +01:00
Shakker
df87c2fc56 test: count final tag reply callbacks 2026-05-12 04:10:42 +01:00
Peter Steinberger
ba152d4b63 test: guard security audit mock calls 2026-05-12 04:09:49 +01:00
Shakker
b14cf842c8 test: count subagent completion retries 2026-05-12 04:08:02 +01:00
Peter Steinberger
daeced9f94 test: reuse plugin cli mock call helper 2026-05-12 04:07:24 +01:00
Peter Steinberger
60ff7b2f69 test: guard heartbeat subagent mock call 2026-05-12 04:06:05 +01:00
Vincent Koc
d6d7b048ff docs(help): correct built-in opus/gpt aliases to match DEFAULT_MODEL_ALIASES 2026-05-12 11:04:19 +08:00
Peter Steinberger
efdd3745aa test: guard windows task restart mock calls 2026-05-12 04:04:09 +01:00
Shakker
f07ac11723 test: count sandbox prune removals 2026-05-12 04:03:56 +01:00
Peter Steinberger
7116cc8a2c test: guard runtime web tools mock arg 2026-05-12 04:02:08 +01:00
Peter Steinberger
8ff3a20390 test: guard status json mock calls 2026-05-12 04:01:13 +01:00
Shakker
a40a6eb91c test: count media handler tool output 2026-05-12 04:01:03 +01:00
Peter Steinberger
2ea90f6f49 test: guard gateway service install mock call 2026-05-12 04:00:02 +01:00
Peter Steinberger
5647846fd7 test: guard channel turn finalize mock calls 2026-05-12 03:58:54 +01:00
Shakker
630bbbdc7c test: count verbose tool result callbacks 2026-05-12 03:57:55 +01:00
Peter Steinberger
b9cd2fcc2b test: guard approval gateway mock call 2026-05-12 03:57:35 +01:00
Peter Steinberger
21a80ced0e test: guard label generator mock calls 2026-05-12 03:56:31 +01:00
Peter Steinberger
64e7cfa668 test: guard doctor transcript mock call 2026-05-12 03:55:17 +01:00
Peter Steinberger
5435480e5f test: guard backup log mock call 2026-05-12 03:54:25 +01:00
Peter Steinberger
14e6f0d62e test: guard heartbeat typing mock call 2026-05-12 03:53:28 +01:00
Shakker
b23b092fcc test: count music completion announcements 2026-05-12 03:52:51 +01:00
Peter Steinberger
928d171001 test: guard doctor auth repair mock call 2026-05-12 03:52:07 +01:00
Peter Steinberger
b7bdb083bb test: guard realtime websocket mock calls 2026-05-12 03:51:05 +01:00
Peter Steinberger
ca95f20c6f test: reuse watch-node mock call guard 2026-05-12 03:50:10 +01:00
Shakker
cb2b399368 test: count media completion announcements 2026-05-12 03:49:11 +01:00
Peter Steinberger
3c562dcaa8 test: guard heartbeat prefix mock call 2026-05-12 03:48:42 +01:00
Peter Steinberger
cbc0f68515 test: guard managed npm root mock call 2026-05-12 03:47:37 +01:00
Peter Steinberger
1b8410adb9 test: guard crestodian rescue mock calls 2026-05-12 03:46:40 +01:00
Peter Steinberger
dd5fd3805b test: guard cron fast-mode mock calls 2026-05-12 03:45:29 +01:00
Shakker
4cb35e4bff test: count exec followup results 2026-05-12 03:44:56 +01:00
Peter Steinberger
71f4b68163 test: guard channel mcp mock call 2026-05-12 03:43:03 +01:00
Shakker
39bd6dab3c test: assert chutes token refresh request 2026-05-12 03:42:12 +01:00
Peter Steinberger
4ef76083c0 test: guard auth choice mock helper 2026-05-12 03:41:51 +01:00
Peter Steinberger
42fff3de8e test: guard provider flow mock calls 2026-05-12 03:40:48 +01:00
Peter Steinberger
6538dc58a3 test: guard sandbox media scp mock call 2026-05-12 03:39:45 +01:00
Shakker
5e0b8cd271 test: count announcement gateway attempts 2026-05-12 03:39:36 +01:00
Peter Steinberger
4c8d01e2a7 test: guard wired hook mock call 2026-05-12 03:38:01 +01:00
Peter Steinberger
e87fd7aa30 fix: normalize google gemini preview config 2026-05-12 03:36:58 +01:00
ai-hpc
7b9282323b fix(doctor): render legacy migration panel as preview when --fix is not passed
loadAndMaybeMigrateDoctorConfig emitted four legacy migration / config-mutation changeLines under a fixed "Doctor changes" panel title even when shouldRepair was false, so a read-only doctor run printed past-tense "Removed agents.defaults.agentRuntime" alongside the "Legacy config keys detected" panel saying the key was still ignored. Centralize the preview-aware title selection in a single emitDoctorChangesPanel helper and route the four emit sites (legacy step, normalized compatibility, plugin auto-enable, channel stale cleanup) through it, so the panel renders as "Doctor changes preview" in non-repair runs and "Doctor changes" with --fix. Mirrors the existing precedent for unknown-config-key emission a few lines below.
2026-05-11 22:36:42 -04:00
Shakker
c098766c9b test: count btw context builds 2026-05-12 03:32:35 +01:00
Peter Steinberger
b4c92f40bd test: guard channel setup mock calls 2026-05-12 03:29:47 +01:00
Shakker
baa11835a0 test: count single-pass compaction summaries 2026-05-12 03:29:34 +01:00
Shakker
28dd756d9f test: count ssh sandbox sessions 2026-05-12 03:26:56 +01:00
Peter Steinberger
c41fd134d0 test: guard realtime talk consult mock call 2026-05-12 03:25:00 +01:00
Peter Steinberger
8cbb2f8027 test: guard plugin tools mock calls 2026-05-12 03:23:36 +01:00
Peter Steinberger
5388428c66 test: guard echo transcript mock call 2026-05-12 03:22:18 +01:00
Shakker
1a1b6d8d88 test: count minimax vlm requests 2026-05-12 03:22:12 +01:00
Peter Steinberger
9fd5cf48a6 test: guard tlon sse mock calls 2026-05-12 03:20:55 +01:00
Peter Steinberger
dea633e7dd test: guard foundry provider mock call 2026-05-12 03:19:53 +01:00
Shakker
53ef9154b8 test: count sandbox bridge shell calls 2026-05-12 03:19:44 +01:00
Peter Steinberger
3c6e0b4a95 test: guard image understanding mock calls 2026-05-12 03:18:01 +01:00
Peter Steinberger
b2f6c29301 test: guard pairing cli mock calls 2026-05-12 03:16:01 +01:00
Peter Steinberger
8bddf0efe1 test: guard voice-call realtime mock calls 2026-05-12 03:14:40 +01:00
Shakker
087f1e060b test: check cli runner fallback calls 2026-05-12 03:13:34 +01:00
Peter Steinberger
0d4e6676dc test: guard voice-call webhook mock calls 2026-05-12 03:12:50 +01:00
Peter Steinberger
899730dad6 test: guard voice-call response mock calls 2026-05-12 03:10:46 +01:00
Shakker
8d4fd26233 test: check exec heartbeat routing 2026-05-12 03:10:37 +01:00
Peter Steinberger
8d35fc2197 test: guard voice-call notify mock calls 2026-05-12 03:09:24 +01:00
sallyom
c7623f706f test: cover timeout after tool media
Signed-off-by: sallyom <somalley@redhat.com>
2026-05-11 22:09:20 -04:00
Dwayne
89f2326c52 style: apply oxlint auto-formatting 2026-05-11 22:09:20 -04:00
Dwayne
db57da50c9 fix: reintroduce partial-fragment drop for clean timeouts 2026-05-11 22:09:20 -04:00
Dwayne
18f4a2d987 fix: surface explicit error on LLM idle timeout to prevent ghost turns 2026-05-11 22:09:20 -04:00
Peter Steinberger
7863643dac test: guard voice-call runtime mock calls 2026-05-12 03:08:10 +01:00
Shakker
8d29fd513c test: check markdown fetch call counts 2026-05-12 03:07:36 +01:00
Peter Steinberger
f55b305077 test: guard voice-call media stream mock calls 2026-05-12 03:05:45 +01:00
Shakker
e18859b342 test: assert thinking tag filtered text 2026-05-12 03:04:49 +01:00
Peter Steinberger
4741b4be19 test: guard cron issue enqueue mock call 2026-05-12 03:02:53 +01:00
Shakker
d3ee2a0c78 test: check synthetic auth discovery calls 2026-05-12 03:02:17 +01:00
Peter Steinberger
31c7ca5075 test: guard cron restart enqueue mock call 2026-05-12 03:01:38 +01:00
Peter Steinberger
e3b56c46f2 test: guard audio transcode mock call 2026-05-12 03:00:30 +01:00
Peter Steinberger
8b6c2bf1af test: guard memory auth mock calls 2026-05-12 02:59:25 +01:00
Shakker
9f821e5634 test: check model catalog auth queries 2026-05-12 02:59:16 +01:00
Peter Steinberger
5d32047354 test: guard tui command mock calls 2026-05-12 02:57:05 +01:00
Shakker
3abb2ee781 test: check read-only auth overlay context 2026-05-12 02:56:11 +01:00
Peter Steinberger
a8216a4ba0 test: guard tui spawn mock call 2026-05-12 02:55:51 +01:00
Peter Steinberger
cc5cdf8f1d test: guard node event mock call 2026-05-12 02:54:51 +01:00
Peter Steinberger
bdb5bd0ffb test: guard commitment telegram send mock call 2026-05-12 02:53:45 +01:00
Peter Steinberger
17b9f7a8e0 test: guard discord reaction monitor mock calls 2026-05-12 02:52:24 +01:00
Shakker
ba93e6f427 test: assert compaction sanitized inputs 2026-05-12 02:51:13 +01:00
Peter Steinberger
6ebc6cad17 test: guard discord webhook fetch mock call 2026-05-12 02:50:29 +01:00
Peter Steinberger
e1cd9275dc test: guard discord message process mock calls 2026-05-12 02:49:19 +01:00
Shakker
2bf827ae35 test: pin compaction safeguard diagnostics 2026-05-12 02:47:59 +01:00
Peter Steinberger
97d9efee37 test: guard discord preflight mock calls 2026-05-12 02:47:41 +01:00
Peter Steinberger
a010277524 test: guard discord model picker mock calls 2026-05-12 02:46:24 +01:00
Shakker
8a58fa0a21 test: assert compaction split merge calls 2026-05-12 02:44:44 +01:00
Peter Steinberger
7f4a17f565 test: guard discord component mock calls 2026-05-12 02:44:31 +01:00
Peter Steinberger
0c4e52a6b3 test: guard discord plugin dispatch mock calls 2026-05-12 02:43:17 +01:00
Peter Steinberger
7dc3e22571 test: guard discord provider proxy mock calls 2026-05-12 02:42:06 +01:00
Shakker
9b1596cf12 test: assert bootstrap warning metadata 2026-05-12 02:41:33 +01:00
Peter Steinberger
22981a2cc4 test: guard discord status-direct mock calls 2026-05-12 02:40:41 +01:00
Peter Steinberger
a3f67c2c6e test: guard discord allow-from mock calls 2026-05-12 02:37:27 +01:00
Peter Steinberger
1c09002027 test: guard discord rest proxy mock calls 2026-05-12 02:36:09 +01:00
Peter Steinberger
88c6255ed8 test: guard discord thread binding api mock calls 2026-05-12 02:34:58 +01:00
Shakker
2b54023d08 test: assert compaction instruction fallbacks 2026-05-12 02:34:01 +01:00
Peter Steinberger
578dcfbcf4 test: guard discord thread title mock calls 2026-05-12 02:33:10 +01:00
Peter Steinberger
2f4fa9cbe2 test: guard discord listener mock calls 2026-05-12 02:32:13 +01:00
Peter Steinberger
411846893c test: guard discord command arg mock calls 2026-05-12 02:31:16 +01:00
Shakker
87d03b1191 test: assert decoded image data url bytes 2026-05-12 02:31:04 +01:00
Peter Steinberger
0611e16e0f test: guard discord thread binding mock calls 2026-05-12 02:29:52 +01:00
Peter Steinberger
a0fb3c1dfd test: guard discord provider mock calls 2026-05-12 02:28:39 +01:00
Shakker
e994c996c2 test: assert cleanup completion follows run end 2026-05-12 02:28:25 +01:00
Peter Steinberger
3cbc889701 test: guard discord provider startup mock calls 2026-05-12 02:26:19 +01:00
Shakker
7517fe5aae test: match compact skill warning count 2026-05-12 02:25:49 +01:00
Peter Steinberger
d970a81138 test: guard discord component mock calls 2026-05-12 02:23:52 +01:00
Shakker
d37a6c32c3 test: assert compaction prune history ids 2026-05-12 02:22:58 +01:00
Peter Steinberger
cbfc14171b test: guard discord message utils mock calls 2026-05-12 02:21:36 +01:00
Peter Steinberger
6e1e6ecb4f test: guard discord reply delivery mock calls 2026-05-12 02:20:16 +01:00
Shakker
8fbb0eefd3 test: assert compaction split layouts 2026-05-12 02:20:13 +01:00
Peter Steinberger
fead3bfc55 test: guard discord action mock calls 2026-05-12 02:19:05 +01:00
Peter Steinberger
14d248fd18 test: guard discord threading starter mock calls 2026-05-12 02:17:41 +01:00
Shakker
2f20e247ca test: reject blank bundled skill metadata 2026-05-12 02:17:21 +01:00
Peter Steinberger
860bf921ed test: guard discord gateway supervisor mock calls 2026-05-12 02:16:34 +01:00
Peter Steinberger
0e28f4f70f test: guard browser tab selection mock calls 2026-05-12 02:15:06 +01:00
Shakker
2013700753 test: assert noop exec completion event 2026-05-12 02:14:59 +01:00
pashpashpash
85bf8cdf8f fix: add message tool delivery hint to inbound context (#80821) 2026-05-12 10:14:55 +09:00
Peter Steinberger
eab88c61e7 test: guard slack tool result mock calls 2026-05-12 02:14:05 +01:00
Peter Steinberger
1894e9f4d7 test: guard msteams attachment mock calls 2026-05-12 02:12:33 +01:00
Shakker
49d7a7a4d0 test: pin stale lock watchdog release count 2026-05-12 02:11:44 +01:00
Peter Steinberger
eb5685cfab test: guard discord send mock calls 2026-05-12 02:10:57 +01:00
Peter Steinberger
3d5fd9cc8f test: guard slack media mock calls 2026-05-12 02:09:06 +01:00
Shakker
94704b7185 test: assert materialized session ids are uuid 2026-05-12 02:08:51 +01:00
Peter Steinberger
bb5761ab03 test: guard msteams reaction mock calls 2026-05-12 02:07:39 +01:00
Peter Steinberger
c192604e36 test: guard slack action mock calls 2026-05-12 02:06:27 +01:00
Peter Steinberger
434d589f3e test: guard msteams authz mock calls 2026-05-12 02:04:25 +01:00
Peter Steinberger
2f21fe51fc test: guard discord outbound mock calls 2026-05-12 02:03:10 +01:00
Shakker
4afbd8ac49 test: assert agent wait timeout cushion 2026-05-12 02:02:54 +01:00
Peter Steinberger
e649cb92c0 test: guard discord gateway mock calls 2026-05-12 02:01:54 +01:00
Peter Steinberger
95b6c10fc7 test: guard browser session mock calls 2026-05-12 02:00:53 +01:00
Shakker
1d3ab90165 test: assert block reply chunk payloads 2026-05-12 02:00:10 +01:00
Sarah Fortune
c8998b71e2 fix(onboarding): use isolated codex app-server client for migration detect (#80822)
discoverInstalledCuratedPlugins acquired the shared Codex app-server client
to issue a one-shot plugin/list RPC against the source CODEX_HOME. The
shared slot kept the spawned child alive with stdio pipes attached to the
onboarding process, so the Node event loop never drained after the wizard
emitted its outro and the CLI appeared to hang.

The discovery RPC has its own one-off startOptions (custom CODEX_HOME,
HOME) that should never be reused for an agent session, so request it as
an isolated client. request.ts closes the child as soon as the call
returns, removing the dependence on process-exit harness disposal and
eliminating the post-onboarding hang.
2026-05-11 17:59:48 -07:00
Peter Steinberger
4bf3016096 test: guard browser batch mock calls 2026-05-12 01:57:53 +01:00
Shakker
905da673e7 test: lock down thinking block reply payload 2026-05-12 01:57:24 +01:00
Peter Steinberger
4bde5b6dfa test: guard browser agent contract mock calls 2026-05-12 01:56:24 +01:00
Peter Steinberger
e07e6c77da test: guard msteams reply dispatcher mock calls 2026-05-12 01:54:54 +01:00
Shakker
06f1cd92ed test: specify embedded approval payloads 2026-05-12 01:53:27 +01:00
Peter Steinberger
fb15b32df2 test: guard msteams oauth mock calls 2026-05-12 01:52:52 +01:00
Peter Steinberger
7857bf0c5c test: guard msteams send mock calls 2026-05-12 01:50:50 +01:00
Shakker
e732c514e2 test: specify read tool text content 2026-05-12 01:49:43 +01:00
Peter Steinberger
6f0b789f81 test: guard discord send thread mock calls 2026-05-12 01:49:25 +01:00
Peter Steinberger
68ac67d7c7 test: guard slack routing mock calls 2026-05-12 01:47:47 +01:00
Peter Steinberger
b77ca2e0ff test: guard slack lazy mock calls 2026-05-12 01:46:34 +01:00
Shakker
be6faa11ec test: specify orphaned media lifecycle order 2026-05-12 01:46:14 +01:00
Peter Steinberger
fccf28910e test: guard msteams graph mock calls 2026-05-12 01:44:46 +01:00
Peter Steinberger
b09733dab2 test: guard browser node host mock calls 2026-05-12 01:42:58 +01:00
Peter Steinberger
402da9610c test: guard slack outbound mock calls 2026-05-12 01:41:57 +01:00
Peter Steinberger
a0288dc4aa test: guard discord channel mock calls 2026-05-12 01:40:46 +01:00
Shakker
9dbae5ca95 test: specify expired auth cooldown reset 2026-05-12 01:40:29 +01:00
Peter Steinberger
bcea977531 test: guard msteams consent mock calls 2026-05-12 01:39:39 +01:00
Peter Steinberger
83154d8470 test: guard browser gateway mock calls 2026-05-12 01:38:09 +01:00
Shakker
e23d7db1f1 test: specify oauth fallback key path 2026-05-12 01:38:02 +01:00
Peter Steinberger
4835ff5ea1 test: guard discord component mock calls 2026-05-12 01:35:24 +01:00
Peter Steinberger
3426b09591 test: guard msteams sdk mock calls 2026-05-12 01:33:59 +01:00
Shakker
8530d03671 test: specify cli transcript path 2026-05-12 01:33:13 +01:00
Peter Steinberger
50ba3abf6b test: guard msteams monitor lifecycle mock calls 2026-05-12 01:31:01 +01:00
Peter Steinberger
85c57a42b4 test: guard browser route reachability mock calls 2026-05-12 01:29:34 +01:00
Peter Steinberger
3b851b41c3 test: guard slack identity fallback mock calls 2026-05-12 01:27:41 +01:00
Shakker
b46475a52b test: specify oauth profile ref ids 2026-05-12 01:27:10 +01:00
Sarah Fortune
e9421bbdec fix(onboarding): treat already-installed codex as success, update in place (#80816)
When `ensureCodexRuntimePluginForModelSelection` ran for a host that
already had `@openclaw/codex` installed under the managed npm root, the
default `mode: "install"` path in `installPluginFromNpmSpec` returned
"plugin already exists" from `ensureInstallTargetAvailable` and the
wizard marked the step as failed.

Now, when the install record points at a real package on disk, route
through the existing `repairCodexRuntimePluginInstallForModelSelection`
flow (which runs `repairMissingPluginInstallsForIds` →
`updateNpmInstalledPlugins`), forward any changes/warnings to the
runtime log, enable the plugin in cfg, and return `installed`.

A fresh install still flows through `ensureOnboardingPluginInstalled`
so the wizard progress UI is unchanged.
2026-05-11 17:26:40 -07:00
Peter Steinberger
5c4f5e0f3a test: guard slack blocks mock calls 2026-05-12 01:26:05 +01:00
Peter Steinberger
133c6a5cf5 test: guard msteams file consent mock calls 2026-05-12 01:24:48 +01:00
Peter Steinberger
8486c69315 test: guard browser chrome mock calls 2026-05-12 01:23:39 +01:00
Shakker
9e77a41fcb test: specify cli auth epoch shape 2026-05-12 01:23:03 +01:00
Peter Steinberger
015bf23fe3 test: guard msteams graph search mock calls 2026-05-12 01:22:11 +01:00
Peter Steinberger
e7397ec81f test: guard slack channel mock calls 2026-05-12 01:21:03 +01:00
Shakker
34cbc131f0 test: specify download escape side effects 2026-05-12 01:19:50 +01:00
Peter Steinberger
598f1eb704 test: guard slack approval mock calls 2026-05-12 01:19:20 +01:00
Peter Steinberger
97870f36fb test: guard msteams user agent mock calls 2026-05-12 01:18:08 +01:00
Peter Steinberger
e5a674a783 test: guard acpx runtime mock calls 2026-05-12 01:16:59 +01:00
Shakker
24e5e373e2 test: specify auth path outputs 2026-05-12 01:16:18 +01:00
Peter Steinberger
8ef408bc5e test: guard browser server launch mock calls 2026-05-12 01:15:28 +01:00
Peter Steinberger
7f8d37bdcc test: guard browser control auth mock calls 2026-05-12 01:14:22 +01:00
Peter Steinberger
9947c50968 test: guard browser snapshot mock calls 2026-05-12 01:13:24 +01:00
Shakker
b96e2a7190 test: specify compaction successor messages 2026-05-12 01:12:32 +01:00
Peter Steinberger
2547f4f1ee test: guard browser download save mock calls 2026-05-12 01:12:12 +01:00
Peter Steinberger
25ac449801 test: guard browser session fallback mock calls 2026-05-12 01:10:57 +01:00
Sarah Fortune
26b2c47feb feat(onboarding): featured provider tier in interactive picker (#80798)
* temp

* fix pnpm lock conflict

* fix(onboarding): clear oxlint findings in auth-choice-prompt
2026-05-11 17:09:32 -07:00
Peter Steinberger
9afdd3ae3b test: guard browser cli mock calls 2026-05-12 01:09:27 +01:00
Shakker
d3678b91e6 test: specify bootstrap file filtering 2026-05-12 01:08:32 +01:00
Peter Steinberger
3029da8ef9 test: guard browser profile mock calls 2026-05-12 01:06:55 +01:00
Peter Steinberger
c4df9c7135 test: guard browser service mock calls 2026-05-12 01:05:53 +01:00
Shakker
04cdba80dc test: require cli spawn arg values 2026-05-12 01:05:39 +01:00
Peter Steinberger
5fca39feeb test: guard browser doctor mock calls 2026-05-12 01:04:41 +01:00
Peter Steinberger
af30c02ca5 test: guard browser loopback mock calls 2026-05-12 01:03:05 +01:00
Shakker
82b335f6e6 test: specify agent wait timeout request 2026-05-12 01:02:51 +01:00
Peter Steinberger
4fed265d05 test: guard browser internal cdp mock calls 2026-05-12 01:01:22 +01:00
Shakker
36534558e8 test: require cli mcp config path 2026-05-12 00:59:37 +01:00
Peter Steinberger
3d9d474c0d test: guard browser cdp mock calls 2026-05-12 00:59:00 +01:00
Peter Steinberger
f6d5d1cc4e test: guard qa lab cli mock calls 2026-05-12 00:57:48 +01:00
Peter Steinberger
065475df83 test: guard signal ingest mock calls 2026-05-12 00:56:41 +01:00
Shakker
5995c1b4a3 test: specify cli image argv 2026-05-12 00:56:22 +01:00
Peter Steinberger
6ac981f044 test: guard zalo lifecycle mock calls 2026-05-12 00:55:27 +01:00
Peter Steinberger
3b15e11052 test: guard zalo startup mock calls 2026-05-12 00:53:59 +01:00
Shakker
0e417981db test: specify deduped image refs 2026-05-12 00:53:18 +01:00
Peter Steinberger
8b5cb16cfb test: guard qa lab web mock calls 2026-05-12 00:52:44 +01:00
Peter Steinberger
f97815a04e test: guard qa lab session mock calls 2026-05-12 00:51:44 +01:00
Peter Steinberger
9b6cc4085f test: guard signal autostart mock calls 2026-05-12 00:50:46 +01:00
Kevin Lin
8954c03231 fix(codex): default plugin destructive actions on (#80792) 2026-05-11 16:50:15 -07:00
Shakker
edd200d517 test: specify message image parser refs 2026-05-12 00:49:32 +01:00
Peter Steinberger
e0c03224e0 test: guard synology chat mock calls 2026-05-12 00:49:13 +01:00
Peter Steinberger
9682e7a034 test: guard slack probe mock calls 2026-05-12 00:48:07 +01:00
Peter Steinberger
2b202ffe7c test: guard slack dispatch mock calls 2026-05-12 00:47:11 +01:00
Shakker
2aec3178e8 test: specify media image parser refs 2026-05-12 00:46:56 +01:00
Peter Steinberger
ce695d7a32 test: guard signal reaction mock calls 2026-05-12 00:45:56 +01:00
Peter Steinberger
35ba1dea85 test: guard discord action mock calls 2026-05-12 00:44:43 +01:00
Shakker
f006e97caa test: specify prompt image path refs 2026-05-12 00:43:56 +01:00
Peter Steinberger
56c26c38be test: guard zalo api mock calls 2026-05-12 00:43:34 +01:00
Peter Steinberger
277ede4b1c test: guard mattermost channel mock calls 2026-05-12 00:42:28 +01:00
Peter Steinberger
ac92277066 test: guard comfy video mock calls 2026-05-12 00:41:06 +01:00
Kevin Lin
7b1c741850 test: stabilize core fast tests (#80803) 2026-05-11 16:40:51 -07:00
Shakker
38f897f0ee test: specify image extension refs 2026-05-12 00:40:26 +01:00
Peter Steinberger
aacfe5b421 test: guard msteams graph mock calls 2026-05-12 00:40:00 +01:00
Peter Steinberger
04b07534b5 test: guard mattermost slash mock calls 2026-05-12 00:38:55 +01:00
Shakker
46ab30a541 test: specify sandbox image load output 2026-05-12 00:38:34 +01:00
Shakker
b516f8f228 test: specify bootstrap truncation counts 2026-05-12 00:36:59 +01:00
Peter Steinberger
a091feae2d test: guard qqbot stt mock calls 2026-05-12 00:36:38 +01:00
Shakker
52e246345c test: specify embedded fence chunks 2026-05-12 00:35:26 +01:00
Peter Steinberger
9086751019 test: guard msteams media mock calls 2026-05-12 00:35:04 +01:00
Peter Steinberger
09f0566008 test: guard twitch setup mock calls 2026-05-12 00:33:52 +01:00
Peter Steinberger
ff37c39bae test: guard kilocode model mock calls 2026-05-12 00:32:20 +01:00
Peter Steinberger
86945dc7c0 test: guard video provider mock calls 2026-05-12 00:31:12 +01:00
Shakker
430e3e1e31 test: specify tool-result char estimates 2026-05-12 00:30:45 +01:00
Peter Steinberger
8577570cf3 test: guard matrix cli mock calls 2026-05-12 00:29:38 +01:00
Shakker
949a196090 test: specify qa mock embeddings 2026-05-12 00:28:24 +01:00
Peter Steinberger
44b09a3c71 test: guard mattermost probe mock calls 2026-05-12 00:28:15 +01:00
Peter Steinberger
8b50587ec7 test: guard slack setup mock calls 2026-05-12 00:27:00 +01:00
Shakker
6cd58ce7b1 test: specify heartbeat bootstrap files 2026-05-12 00:25:59 +01:00
Peter Steinberger
26dd616e2d test: guard xai realtime mock calls 2026-05-12 00:25:50 +01:00
Peter Steinberger
8127103bb3 test: guard memory wiki cli mock calls 2026-05-12 00:24:22 +01:00
Shakker
a8a34c92f3 fix: validate literal tilde exec scripts 2026-05-12 00:23:37 +01:00
Peter Steinberger
f078d90226 test: guard thread ownership mock calls 2026-05-12 00:23:11 +01:00
Peter Steinberger
9a9dc4a47b test: guard webhooks mock calls 2026-05-12 00:21:40 +01:00
Peter Steinberger
c63b72d041 test: guard skill workshop mock calls 2026-05-12 00:20:37 +01:00
Peter Steinberger
225a374d5e test: guard document extract mock calls 2026-05-12 00:19:06 +01:00
Peter Steinberger
00453a9607 test: guard active memory hook mock calls 2026-05-12 00:17:49 +01:00
pashpashpash
3b44dfc367 Make OpenAI auth login use ChatGPT by default (#80790)
* fix(openai): default provider login to ChatGPT auth

* fix(openai): align auth login metadata and fast tests

* fix(openai): prefer setup auth providers for login

* fix(openai): reject unknown explicit auth methods

* fix(line): keep channel entry imports scoped
2026-05-12 08:17:14 +09:00
Peter Steinberger
5c14f159c6 test: guard github copilot mock calls 2026-05-12 00:16:04 +01:00
Shakker
cb9881423d test: specify telegram file-ref chunks 2026-05-12 00:14:45 +01:00
Omar Shahine
d7a9248620 fix(imessage): route inbound tapbacks as reactions
Route inbound iMessage tapbacks as untrusted reaction system events, add reaction notification configuration/docs, and cover reply-cache ownership matching for bot-authored targets.
2026-05-11 16:13:29 -07:00
Peter Steinberger
da97f9f54d test: guard tavily tool mock calls 2026-05-12 00:10:33 +01:00
Shakker
919ba6c70c test: remove redundant telegram command check 2026-05-12 00:10:20 +01:00
Shakker
c0601f955e test: specify telegram model keyboard 2026-05-12 00:08:46 +01:00
Peter Steinberger
f0daf09b02 test: guard google realtime mock calls 2026-05-12 00:07:48 +01:00
Shakker
7cd9e43979 test: specify telegram send action result 2026-05-12 00:06:57 +01:00
Peter Steinberger
fcd0e9d5ad test: guard google speech mock calls 2026-05-12 00:06:16 +01:00
Shakker
cdef959514 test: specify matrix encrypted room request 2026-05-12 00:04:15 +01:00
Peter Steinberger
93b1e7e282 test: guard google provider mock calls 2026-05-12 00:03:56 +01:00
Shakker
e847e0f2dd test: specify telegram command menu registrations 2026-05-12 00:02:33 +01:00
Sarah Fortune
3d5b0cb41b fix(cli/completion): re-apply shell-profile source-line guard (re-#78659) (#80797) 2026-05-11 16:01:00 -07:00
Peter Steinberger
1f167178f2 test: guard messaging provider mock calls 2026-05-12 00:00:46 +01:00
Shakker
25e241e3e2 test: specify signal heading styles 2026-05-12 00:00:18 +01:00
Kevin Lin
f5b0eca12a docs: reorganize tools automation nav (#80116)
* docs: reorganize tools automation nav

* docs: add nav spec glossary terms

* docs: refresh nav spec validation

* docs: keep capabilities nav grouped

* docs: refactor tools overview

* docs: restore tools overview coverage

* add doc refactor skill

* docs: mark refactored docs schema

* docs: remove refactor specs from pr

* docs: rename tools overview header
2026-05-11 15:59:27 -07:00
Shakker
b348cdd1f1 test: specify googlechat capability proof set 2026-05-11 23:58:57 +01:00
Peter Steinberger
459c12eda1 test: guard media provider mock calls 2026-05-11 23:57:23 +01:00
Shakker
12eb320b71 test: specify prometheus exporter startup event 2026-05-11 23:56:48 +01:00
Shakker
5742b39c7b test: specify nested skill discovery cap 2026-05-11 23:55:31 +01:00
Peter Steinberger
7453ba6381 test: guard deepinfra provider mock calls 2026-05-11 23:54:31 +01:00
Shakker
b596c484e4 test: require single oc-path diagnostic 2026-05-11 23:53:16 +01:00
Peter Steinberger
36a4ed5956 test: guard infra process mock calls 2026-05-11 23:52:14 +01:00
Peter Steinberger
995d5ef16f test: guard provider usage mock calls 2026-05-11 23:51:03 +01:00
Peter Steinberger
7c81310b99 test: guard voice call twilio mock calls 2026-05-11 23:49:36 +01:00
Shakker
aef3a39561 test: specify googlechat directory entries 2026-05-11 23:48:52 +01:00
Shakker
424666d5ea test: specify msteams directory entries 2026-05-11 23:47:02 +01:00
Peter Steinberger
b0ee88bc94 test: guard infra net mock calls 2026-05-11 23:46:43 +01:00
Shakker
b4cb08c71a test: require actionable compat text 2026-05-11 23:45:19 +01:00
Peter Steinberger
e3dcb6cf66 test: guard ui gateway mock calls 2026-05-11 23:44:01 +01:00
Shakker
9be43d5a8d test: enumerate no-env model providers 2026-05-11 23:43:46 +01:00
Shakker
f82da6cb42 test: spell stream error sentinel 2026-05-11 23:42:12 +01:00
Peter Steinberger
0b0c43d2e4 test: guard ui sidebar mock calls 2026-05-11 23:41:37 +01:00
Shakker
a1fe0bd91b test: require single plugin tool load 2026-05-11 23:40:51 +01:00
Peter Steinberger
b0946c1a4e test: guard respawn and image mock calls 2026-05-11 23:39:59 +01:00
Shakker
376f93b62b test: match plugin registry inventory 2026-05-11 23:39:34 +01:00
Peter Steinberger
9c9b288ca9 test: guard command setup mock calls 2026-05-11 23:38:10 +01:00
Peter Steinberger
b433e643bb test: guard media understanding mock calls 2026-05-11 23:36:13 +01:00
Shakker
bffa49705e test: preserve NVIDIA provider model 2026-05-11 23:34:34 +01:00
Peter Steinberger
db7a981f4d test: guard chat view mock attachments 2026-05-11 23:33:55 +01:00
Shakker
c1f10e42ef test: compare DeepInfra fallback catalog 2026-05-11 23:33:10 +01:00
Peter Steinberger
5f2bd36180 test: guard realtime talk mock events 2026-05-11 23:32:23 +01:00
Shakker
ddf83d16f7 test: specify Kilo static catalog 2026-05-11 23:31:53 +01:00
Josh Lehman
4bfd7416f0 fix: stabilize code-mode follow-up tool display and replay (#80663)
* fix: project tool-search bridge event display

* fix: keep codex tool progress out of final replies

* fix: preserve tool result pairs on cleanup

* fix: restore tool search display target helper

* fix: keep tool search controls independent

* fix: render bridged tool calls like native tools

* fix: abort timed out tool search bridge calls

* fix: preserve code-mode tool results across display turns

* fix: repair missing code-mode tool results on disk

* fix: expose tool search controls in embedded runs

* docs: add code-mode followups changelog

* fix: update session repair agent-core import

* fix: harden code-mode follow-up repair

* fix: use stable session repair ids

---------

Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-11 15:31:35 -07:00
Peter Steinberger
1786d60cf8 test: guard ui controller mock calls 2026-05-11 23:30:37 +01:00
Eva
f7ab8c26b1 fix(codex): scale context engine projection (#80761)
* fix(codex): scale context engine projection

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* fix: document Codex context projection scaling

* chore: align Codex projection changelog

* chore: realign Codex projection changelog

* fix: isolate Codex projection patch

---------

Co-authored-by: Eva (agent) <eva+agent-78055@100yen.org>
Co-authored-by: Josh Lehman <josh@martian.engineering>
2026-05-11 15:29:59 -07:00
Shakker
6a8ef7b6cf test: spell inline provider header model 2026-05-11 23:29:47 +01:00
Peter Steinberger
a51a9631cc test: guard tooling mock call fallbacks 2026-05-11 23:28:57 +01:00
Shakker
df99502a2a test: check OpenAI thinking option values 2026-05-11 23:28:10 +01:00
Peter Steinberger
fceea8caed test: guard proxy fetch mock calls 2026-05-11 23:26:09 +01:00
Shakker
17afb47c4d test: require session slot diagnostics 2026-05-11 23:25:44 +01:00
Shakker
0eafe995bc test: verify voice call command activation 2026-05-11 23:24:33 +01:00
Shakker
2e7794d803 test: check skipped stream chunks exactly 2026-05-11 23:23:16 +01:00
Peter Steinberger
07a732572b test: guard channel command mock calls 2026-05-11 23:22:13 +01:00
Shakker
cc72279b5a test: record priority model refs 2026-05-11 23:21:55 +01:00
Sarah Fortune
ce2eb4c367 fix: Fix the build: annotate provider-http test-helper exports for portable dts (#80781)
* fix: annotate provider-http test-helper exports for portable dts

* ci: retrigger

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

---------

Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 15:21:44 -07:00
Josh Lehman
24ffd4d2f8 Telegram: keep verbose tool results separate from final answers (#80294)
* Telegram: keep tool progress separate from final answers

* Telegram: separate verbose tool results from final answers

* fix: separate Telegram verbose tool drafts
2026-05-11 15:21:19 -07:00
Peter Steinberger
d3edbaabcb test: guard utility mock call helpers 2026-05-11 23:20:17 +01:00
Peter Steinberger
ccce9aa417 test: guard core mock call reads 2026-05-11 23:18:51 +01:00
Peter Steinberger
920a27aa6f test: guard provider request mock calls 2026-05-11 23:17:09 +01:00
Peter Steinberger
5c59bd6987 test: guard qa and telnyx fetch mock calls 2026-05-11 23:12:57 +01:00
Peter Steinberger
dbf0458d1b test: guard memory lancedb mock calls 2026-05-11 23:11:02 +01:00
Peter Steinberger
b9920447ca test: guard ui chat avatar fetch calls 2026-05-11 23:09:57 +01:00
Peter Steinberger
d7735c607c test: guard tlon upload mock calls 2026-05-11 23:08:43 +01:00
Peter Steinberger
fe1f30bfd6 test: guard zalouser payload mock calls 2026-05-11 23:07:36 +01:00
Peter Steinberger
7d7751edc5 test: guard zalouser send mock calls 2026-05-11 23:06:28 +01:00
Peter Steinberger
c4259b2697 test: guard byteplus video mock calls 2026-05-11 23:05:09 +01:00
Kevin Lin
e0824397b8 docs: add refactor docs skill (#80791) 2026-05-11 15:03:54 -07:00
Peter Steinberger
70818bf252 test: guard mantle discovery mock calls 2026-05-11 23:03:28 +01:00
Peter Steinberger
0ed551eac0 test: guard utility mock call helpers 2026-05-11 23:02:07 +01:00
Peter Steinberger
832a337857 test: guard runway video mock calls 2026-05-11 23:00:50 +01:00
Peter Steinberger
c8e5030d29 test: guard copilot embedding mock calls 2026-05-11 22:58:45 +01:00
Peter Steinberger
b3b692829d test: guard xai mock fetch calls 2026-05-11 22:57:32 +01:00
Peter Steinberger
1923db6dac fix: normalize exact Gemini proxy refs 2026-05-11 22:54:42 +01:00
Shakker
37d018c6d9 test: expand inline provider model rows 2026-05-11 22:51:21 +01:00
Peter Steinberger
21fdc729ac test: guard outbound target calls 2026-05-11 22:49:57 +01:00
Shakker
7b8245a820 test: finish anthropic turn merge row 2026-05-11 22:48:48 +01:00
Shakker
eec0d16458 test: complete backup asset helper 2026-05-11 22:47:10 +01:00
Peter Steinberger
1c03a34813 test: guard outbound media calls 2026-05-11 22:46:23 +01:00
Peter Steinberger
7e97ddcd51 test: guard outbound helper calls 2026-05-11 22:44:35 +01:00
Shakker
db084a8f29 test: spell out agents list rows 2026-05-11 22:44:11 +01:00
Peter Steinberger
60e5804a9d test: guard windows exec spawn call 2026-05-11 22:42:30 +01:00
Shakker
c60a4c9552 test: order sandbox status lookups 2026-05-11 22:41:48 +01:00
Peter Steinberger
c69b58157f test: guard process child adapter calls 2026-05-11 22:41:27 +01:00
Peter Steinberger
ca6a513c55 test: guard process queue calls 2026-05-11 22:40:24 +01:00
Shakker
ad84d5c130 test: expose filtered session row shape 2026-05-11 22:38:40 +01:00
Peter Steinberger
2b90adb45f test: guard infra utility calls 2026-05-11 22:38:32 +01:00
Peter Steinberger
8f730667ce test: guard node host invoke calls 2026-05-11 22:37:00 +01:00
Peter Steinberger
70a0236ccc test: guard process spawn calls 2026-05-11 22:36:06 +01:00
Shakker
31d2d13076 test: fill plugin registry repair records 2026-05-11 22:35:53 +01:00
Peter Steinberger
95752bef68 test: guard group policy warning call 2026-05-11 22:34:48 +01:00
Peter Steinberger
2b2664f17f test: guard logging mock calls 2026-05-11 22:34:04 +01:00
Shakker
ec40e36ada test: verify degraded gateway json 2026-05-11 22:33:16 +01:00
Peter Steinberger
e241aedbcf test: guard secrets channel collector calls 2026-05-11 22:32:29 +01:00
Shakker
f1ccfd87b9 test: define external cli profile envelopes 2026-05-11 22:31:44 +01:00
Peter Steinberger
671f0e653f test: guard task registry calls 2026-05-11 22:31:20 +01:00
Peter Steinberger
fc9b8c94a9 test: guard detached task runtime calls 2026-05-11 22:30:10 +01:00
Shakker
8e793e2bce test: lock cache trace events 2026-05-11 22:29:45 +01:00
Peter Steinberger
41cd36fe6c test: guard media fetch call 2026-05-11 22:29:04 +01:00
Peter Steinberger
0f616dc054 test: guard media understanding calls 2026-05-11 22:28:21 +01:00
Shakker
95fa1bba60 test: detail covered backup assets 2026-05-11 22:27:21 +01:00
Peter Steinberger
ac15f1887f test: guard channel mock calls 2026-05-11 22:27:00 +01:00
Peter Steinberger
597b65e93e test: guard talk consult call helper 2026-05-11 22:24:45 +01:00
Shakker
b5d12bb892 test: shape allowed agents payload 2026-05-11 22:24:01 +01:00
Peter Steinberger
e5fa72c3ce test: guard memory host post json calls 2026-05-11 22:23:55 +01:00
Peter Steinberger
c6eefd9f4d test: guard cron auth profile helper 2026-05-11 22:22:48 +01:00
Peter Steinberger
3f75797de7 test: guard cron skill filter calls 2026-05-11 22:21:53 +01:00
Shakker
0fd1ed9853 test: specify memory append result 2026-05-11 22:21:26 +01:00
Peter Steinberger
f9ba1d6d41 test: guard cron message tool calls 2026-05-11 22:20:10 +01:00
Shakker
c512297f4f test: list refreshed catalog entries 2026-05-11 22:19:16 +01:00
Peter Steinberger
933a597f66 test: guard cron stale enqueue call 2026-05-11 22:18:58 +01:00
Peter Steinberger
a03382181c test: guard cron model override call 2026-05-11 22:17:55 +01:00
Shakker
7a7b2316e1 test: enumerate setup discovery entries 2026-05-11 22:17:23 +01:00
Peter Steinberger
07e3fd5c9c test: guard cron live-session retry call 2026-05-11 22:16:02 +01:00
Shakker
bcc2b8cffa test: place pricing status row 2026-05-11 22:15:34 +01:00
Peter Steinberger
0ce6816ed3 test: guard cron interim retry calls 2026-05-11 22:14:54 +01:00
Shakker
cb12d47513 test: trace task audit finding rows 2026-05-11 22:13:15 +01:00
Peter Steinberger
f8a401d900 test: guard cron fallback requests 2026-05-11 22:13:05 +01:00
Peter Steinberger
53a26dc858 test: guard cron owner auth calls 2026-05-11 22:12:06 +01:00
Shakker
3398369788 test: frame missing channel rows 2026-05-11 22:11:02 +01:00
Peter Steinberger
43ad5ddca0 test: guard cron auth profile call 2026-05-11 22:10:40 +01:00
Peter Steinberger
fdb0b49354 test: guard cron heartbeat requests 2026-05-11 22:09:36 +01:00
Shakker
8dd301c0af test: map task audit json 2026-05-11 22:09:17 +01:00
Peter Steinberger
fe0bb3083e test: guard cron preflight fetch call 2026-05-11 22:08:10 +01:00
Shakker
38a3cf4f01 test: outline approval request payloads 2026-05-11 22:07:16 +01:00
Peter Steinberger
08f176cc6c test: guard talkback consult calls 2026-05-11 22:06:50 +01:00
Peter Steinberger
7eb108abd6 test: centralize talkback timer cleanup 2026-05-11 22:05:35 +01:00
Peter Steinberger
7b21f4d864 test: guard cron due enqueue call 2026-05-11 22:04:23 +01:00
Shakker
44290c7afa test: check external cli reader options 2026-05-11 22:03:57 +01:00
Peter Steinberger
90200d30fd test: guard commitment extractor request 2026-05-11 22:03:20 +01:00
Peter Steinberger
8b112abf61 test: guard cron session mock calls 2026-05-11 22:02:19 +01:00
Shakker
5de295ca84 test: chart os scoped skill status 2026-05-11 22:01:26 +01:00
Peter Steinberger
dc5fedeae0 test: avoid browser tab module reset 2026-05-11 21:59:40 +01:00
Shakker
6e32c06ac5 test: capture media duplicate guidance 2026-05-11 21:58:52 +01:00
Peter Steinberger
82b6885552 test: avoid provider flow module reset 2026-05-11 21:58:10 +01:00
Peter Steinberger
edcb53ec1f test: avoid env module reset 2026-05-11 21:56:41 +01:00
Shakker
ac9732cff4 test: record api error fingerprints 2026-05-11 21:56:29 +01:00
Peter Steinberger
4d68faba62 test: avoid config state module resets 2026-05-11 21:55:27 +01:00
Shakker
8755c1874c test: mirror flow list json 2026-05-11 21:54:36 +01:00
Peter Steinberger
ae304ec688 test: remove stale route reset comment 2026-05-11 21:53:26 +01:00
Sarah Fortune
b05c9c0215 feat(discord): remove harness runtime dropdown from /models picker (#80766)
* feat(discord): remove harness runtime dropdown from /models picker

* ci: retrigger checks
2026-05-11 13:53:21 -07:00
Shakker
cbc620be37 test: cover channels status timeout request 2026-05-11 21:52:43 +01:00
Peter Steinberger
d18e5247fe test: avoid memory fts module resets 2026-05-11 21:51:50 +01:00
Shakker
4dbd5558da test: compare guard redaction messages 2026-05-11 21:51:00 +01:00
Peter Steinberger
95631b1e68 test: avoid media registry module resets 2026-05-11 21:49:38 +01:00
Shakker
ba90ee6b49 test: include transcript update ids 2026-05-11 21:49:26 +01:00
Peter Steinberger
935cf2088d test: dedupe memory lancedb mock harness 2026-05-11 21:47:43 +01:00
Shakker
2959753780 test: match task list json records 2026-05-11 21:47:10 +01:00
Peter Steinberger
1faeb89710 test: use gemini 3.1 in neutral fixtures 2026-05-11 21:45:36 +01:00
Shakker
d0e7df343e test: seal auth list json 2026-05-11 21:44:42 +01:00
Shakker
b9722dcea7 test: verify sandbox json payload 2026-05-11 21:42:40 +01:00
Shakker
5829694fcb test: compare tool mutation keys 2026-05-11 21:41:15 +01:00
Shakker
588ba22db2 test: check router model choices 2026-05-11 21:39:43 +01:00
Peter Steinberger
c4abfa6a9e test: reset telegram message cache directly 2026-05-11 21:39:00 +01:00
Peter Steinberger
b8c3a0b14b test: avoid copilot model module resets 2026-05-11 21:37:05 +01:00
Shakker
fd6059bb28 test: list onboarding hook notes 2026-05-11 21:36:56 +01:00
Peter Steinberger
d865d3a6de test: avoid auth profile module resets 2026-05-11 21:35:41 +01:00
Shakker
010934efe7 test: render oauth tls remediation 2026-05-11 21:34:48 +01:00
Shakker
d0ae1cd07e test: verify repaired session records 2026-05-11 21:32:57 +01:00
Peter Steinberger
00d807c67b test: guard xai live null helper 2026-05-11 21:31:43 +01:00
Shakker
3cb51b258d test: detail transcript redaction output 2026-05-11 21:31:21 +01:00
Peter Steinberger
23b5854fd9 test: guard ui chat null elements 2026-05-11 21:30:46 +01:00
Shakker
68d5a7dc9d test: compare camera image blocks 2026-05-11 21:29:26 +01:00
Peter Steinberger
12227ccf0a test: guard metadata wizard null checks 2026-05-11 21:28:48 +01:00
Shakker
a9fcdf727a test: quote tool policy warnings 2026-05-11 21:27:48 +01:00
Peter Steinberger
07f4b7130f test: guard oc-path null results 2026-05-11 21:27:05 +01:00
Shakker
c6668deb44 test: preserve google cache entry shape 2026-05-11 21:26:34 +01:00
Peter Steinberger
a67507eb04 test: guard chat extension null helpers 2026-05-11 21:25:32 +01:00
Shakker
f7b99c2a7c test: capture session cleanup json 2026-05-11 21:24:49 +01:00
Shakker
8687e29fee test: record model merge outputs 2026-05-11 21:23:28 +01:00
Peter Steinberger
f56fae7b1e test: guard agent runner null helpers 2026-05-11 21:23:01 +01:00
Shakker
50f51a71cb test: catalog stale lock cleanup records 2026-05-11 21:22:02 +01:00
Peter Steinberger
baa2776900 test: guard core agent null helpers 2026-05-11 21:20:59 +01:00
Shakker
e9f760027a test: map turn validation merges 2026-05-11 21:20:21 +01:00
Kevin Lin
d06e85b0aa fix(codex): match connector app approvals by id 2026-05-11 13:19:56 -07:00
Peter Steinberger
6eccb0d3bf test: guard extension helper null checks 2026-05-11 21:18:51 +01:00
Shakker
bbd3ccf8e6 test: describe cli image path reuse 2026-05-11 21:17:27 +01:00
Peter Steinberger
32b8925cfa test: guard core sdk null helpers 2026-05-11 21:16:17 +01:00
Shakker
bff97df6e5 test: show replay tail drops 2026-05-11 21:14:38 +01:00
Peter Steinberger
e7f9f3ba63 test: guard agent tool null helpers 2026-05-11 21:12:24 +01:00
Shakker
30323f37f4 test: outline inline provider records 2026-05-11 21:12:17 +01:00
Peter Steinberger
427372b3f9 test: guard auto reply null helpers 2026-05-11 21:10:16 +01:00
Shakker
2b69b487ac test: name pty hex warnings 2026-05-11 21:08:51 +01:00
Peter Steinberger
e19c7ab95e test: guard cli null helpers 2026-05-11 21:07:53 +01:00
Shakker
e986012043 test: spell out bootstrap file records 2026-05-11 21:06:36 +01:00
Peter Steinberger
ed0aa3784e test: guard infra cron secrets helpers 2026-05-11 21:06:03 +01:00
Shakker
e794b79e23 test: show os scoped skill status 2026-05-11 21:04:30 +01:00
Peter Steinberger
faa74ac1e8 test: guard extension channel helpers 2026-05-11 21:04:13 +01:00
Shakker
eea3f6dc4b test: expose redacted attachment payload 2026-05-11 21:02:15 +01:00
Peter Steinberger
2d0c3750d8 test: guard extension provider helpers 2026-05-11 21:01:56 +01:00
Shakker
9bca3a1325 test: identify media status content 2026-05-11 21:00:32 +01:00
Peter Steinberger
905861c4e0 test: guard command object helpers 2026-05-11 20:59:38 +01:00
Shakker
3eb5070817 test: enumerate agents list details 2026-05-11 20:58:28 +01:00
Peter Steinberger
18c56ef143 test: guard gateway object helpers 2026-05-11 20:57:56 +01:00
Shakker
10492a2559 test: map text transform merges 2026-05-11 20:56:47 +01:00
Peter Steinberger
8604774347 test: guard plugin object helpers 2026-05-11 20:56:22 +01:00
Shakker
1b92d8f8c4 test: spell out thinking option captures 2026-05-11 20:54:45 +01:00
Peter Steinberger
9583c37e8b test: guard cli infra object helpers 2026-05-11 20:53:54 +01:00
Shakker
76468cc145 test: describe channel setup entries 2026-05-11 20:53:14 +01:00
Peter Steinberger
10c2a8a311 test: guard message helper nullish deps 2026-05-11 20:52:29 +01:00
Shakker
911d3e969a test: specify finished process records 2026-05-11 20:51:20 +01:00
Peter Steinberger
5899db7b1c test: consolidate group runtime reset coverage 2026-05-11 20:51:10 +01:00
Peter Steinberger
93dd5e61ba test: guard multiline helper assertions 2026-05-11 20:49:23 +01:00
Shakker
6e1e057e88 test: describe runner payload arrays 2026-05-11 20:49:01 +01:00
Peter Steinberger
63af3bcfdb test: guard remaining truthiness assertions 2026-05-11 20:45:49 +01:00
Shakker
23f8c38ba5 test: define session tool records 2026-05-11 20:45:23 +01:00
Shakker
164031f73f test: specify exec approval shortcut 2026-05-11 20:43:10 +01:00
Shakker
873c436841 test: capture cache trace fingerprints 2026-05-11 20:40:56 +01:00
Peter Steinberger
bad097f34b test: guard agents gateway infra truthiness assertions 2026-05-11 20:40:32 +01:00
Shakker
3049576fce test: record bootstrap signature files 2026-05-11 20:38:55 +01:00
Shakker
e793b65073 test: refine external cli sync helpers 2026-05-11 20:37:07 +01:00
Peter Steinberger
ad907871f9 test: guard core truthiness assertions 2026-05-11 20:35:33 +01:00
Shakker
62c21c4cee test: detail transcript update events 2026-05-11 20:35:06 +01:00
Shakker
0e22935c4a test: verify auth repair messages 2026-05-11 20:32:43 +01:00
Peter Steinberger
0398875044 test: guard ui truthiness assertions 2026-05-11 20:32:04 +01:00
Shakker
c21516372d test: document model probe plans 2026-05-11 20:30:54 +01:00
Peter Steinberger
fc10ac838b fix: normalize nested gemini config refs 2026-05-11 20:29:47 +01:00
Peter Steinberger
3c9fbf7071 test: guard ui tooling assertions 2026-05-11 20:29:47 +01:00
Shakker
b6027cb40e test: exercise command json payloads 2026-05-11 20:28:28 +01:00
Shakker
0961d5c8a8 test: characterize plugin registry repairs 2026-05-11 20:26:41 +01:00
Shakker
2bb4e23ea1 test: describe plugin manifest migrations 2026-05-11 20:24:14 +01:00
Shakker
7def30cbb1 test: cover doctor fallback warnings 2026-05-11 20:22:53 +01:00
Peter Steinberger
4981f8ecbc test: guard agents helper assertions 2026-05-11 20:22:47 +01:00
Shakker
70898621e3 test: inspect command json records 2026-05-11 20:21:08 +01:00
Peter Steinberger
5b4940e41c test: guard auto-reply helper assertions 2026-05-11 20:19:34 +01:00
Shakker
1c9dc55e12 test: check backup asset records 2026-05-11 20:18:44 +01:00
Shakker
02e4e0ccbb test: check agent binding records 2026-05-11 20:17:12 +01:00
Peter Steinberger
5f00135a44 test: guard support helper assertions 2026-05-11 20:16:47 +01:00
Shakker
1461b748d8 test: check task json items 2026-05-11 20:15:32 +01:00
Val Alexander
51b73b39a8 fix(auth): align operator bootstrap scopes
Preserve full shared-token operator sessions while reusing bootstrap/cached device-token scopes for handoff reconnects.

Surface device-token scope mismatches as AUTH_SCOPE_MISMATCH and stop reconnect retry loops without clearing valid stored tokens.

Fixes #79292.
Supersedes #79314, #79296, #79295.
2026-05-11 14:14:33 -05:00
Shakker
0fa4b2fb46 test: check status json audit shape 2026-05-11 20:13:37 +01:00
Peter Steinberger
a644d5dd46 test: guard gateway helper assertions 2026-05-11 20:13:19 +01:00
Shakker
8e75adebe3 test: specify doctor warning text 2026-05-11 20:11:43 +01:00
Peter Steinberger
6b32f6f283 test: guard cli helper assertions 2026-05-11 20:11:18 +01:00
Shakker
aa2596da8b test: verify safe-bin trust hints 2026-05-11 20:10:03 +01:00
Peter Steinberger
0e82b77857 test: guard plugin loader diagnostics 2026-05-11 20:08:19 +01:00
Shakker
94b0695c98 test: capture codex repair summaries 2026-05-11 20:08:09 +01:00
Peter Steinberger
3dd2c1a8b8 test: guard plugin diagnostic assertions 2026-05-11 20:07:14 +01:00
Shakker
eafdbe885f test: record codex route warnings 2026-05-11 20:06:39 +01:00
Peter Steinberger
866c39daea test: guard plugin helper assertions 2026-05-11 20:05:15 +01:00
Shakker
599144b386 test: verify legacy gateway origins 2026-05-11 20:04:53 +01:00
Peter Steinberger
3b4f7adcd9 test: guard tasks and media assertions 2026-05-11 20:03:37 +01:00
Shakker
becc5f5238 test: check legacy migration notes 2026-05-11 20:03:02 +01:00
Peter Steinberger
f9140b30bf test: guard config diagnostics assertions 2026-05-11 20:02:10 +01:00
Shakker
3431607673 test: cover repair note ordering 2026-05-11 20:01:39 +01:00
Peter Steinberger
fb0c525215 test: guard cron helper assertions 2026-05-11 20:00:46 +01:00
Peter Steinberger
1365b71f02 test: guard infra helper assertions 2026-05-11 19:59:48 +01:00
Shakker
630c9fe531 test: verify legacy validation changes 2026-05-11 19:58:48 +01:00
Peter Steinberger
c3dba18730 test: guard channel record helpers 2026-05-11 19:57:25 +01:00
Shakker
085b2d0727 test: verify plugin cleanup changes 2026-05-11 19:57:03 +01:00
Shakker
0573b231ef test: verify allowlist scan warnings 2026-05-11 19:55:33 +01:00
Peter Steinberger
ad1e6c4485 test: guard telegram helper assertions 2026-05-11 19:55:21 +01:00
Shakker
daad0cc834 test: verify config flow hints 2026-05-11 19:54:03 +01:00
Shakker
9924fff1af test: verify channel migration changes 2026-05-11 19:52:49 +01:00
Peter Steinberger
3240aa7399 test: rely on codex approval event guard 2026-05-11 19:52:45 +01:00
Mariano
8c75ed3eaa Mirror Codex native subagents into task registry (#79512)
Merged via squash.

Prepared head SHA: 75bc96ad74
Co-authored-by: mbelinky <mbelinky@users.noreply.github.com>
Co-authored-by: marianobelinky <63976030+marianobelinky@users.noreply.github.com>
Reviewed-by: @pashpashpash
2026-05-11 20:52:41 +02:00
Shakker
ba03d637ea test: verify skills status note 2026-05-11 19:51:39 +01:00
Peter Steinberger
b1a98701cf test: guard mantle fetch assertion 2026-05-11 19:51:29 +01:00
Peter Steinberger
60bda15223 test: check zalouser warning content 2026-05-11 19:50:38 +01:00
Shakker
6873f07e36 test: verify bootstrap size note 2026-05-11 19:50:21 +01:00
Peter Steinberger
a9a196e325 test: guard discord monitor assertions 2026-05-11 19:49:39 +01:00
Shakker
aab10f5e2d test: verify health formatter lines 2026-05-11 19:49:17 +01:00
Peter Steinberger
60cdb99733 test: guard browser dispatcher assertions 2026-05-11 19:48:44 +01:00
Shakker
06f7adf12a test: verify startup note text 2026-05-11 19:47:50 +01:00
Peter Steinberger
199838616c test: guard signal helper assertions 2026-05-11 19:47:34 +01:00
Shakker
f2bb32f09f test: verify default account warnings 2026-05-11 19:46:31 +01:00
Peter Steinberger
880530dd9f test: guard matrix call assertions 2026-05-11 19:46:12 +01:00
Shakker
d16e28c9e1 test: verify gateway status warning 2026-05-11 19:45:13 +01:00
Peter Steinberger
cd9f0b97f8 test: guard matrix helper assertions 2026-05-11 19:44:42 +01:00
Shakker
4c7bffc3a7 fix: remove OSC payloads from terminal text 2026-05-11 19:44:08 +01:00
Peter Steinberger
0793775a66 test: guard channel provider helpers 2026-05-11 19:41:21 +01:00
Shakker
a091a77dbd test: verify cleanup dry run logs 2026-05-11 19:40:42 +01:00
Peter Steinberger
88673b2fad test: guard gateway runtime assertions 2026-05-11 19:40:00 +01:00
Shakker
9d0669cfa3 test: verify gateway auth diagnostics 2026-05-11 19:39:42 +01:00
Shakker
2e5acf12b8 test: verify doctor repair notes 2026-05-11 19:38:09 +01:00
Peter Steinberger
4b6e1373f6 test: guard extension lookup helpers 2026-05-11 19:38:00 +01:00
Peter Steinberger
c7584d5dc7 test: guard codex relay registrations 2026-05-11 19:36:35 +01:00
AI-HUB
738f78519a fix(browser): skip internal CDP targets (#80629) 2026-05-11 19:36:22 +01:00
Shakker
a9991f0d22 test: verify gateway probe summaries 2026-05-11 19:35:33 +01:00
Peter Steinberger
c741d92d06 test: guard discord qa helpers 2026-05-11 19:34:50 +01:00
AI-HUB
578fad471a docs(subagents): document announce timeout (#75509)
Document agents.defaults.subagents.announceTimeoutMs in the sub-agent and configuration references, and align the exported type comment with the runtime default.

Thanks @akrimm702.

Co-authored-by: AI-HUB <144416483+akrimm702@users.noreply.github.com>
2026-05-11 19:33:50 +01:00
Shakker
4b6798d546 test: verify sessions option errors 2026-05-11 19:33:37 +01:00
Peter Steinberger
fa183bbe0b test: guard core helper assertions 2026-05-11 19:32:41 +01:00
Shakker
174ea9d0e4 test: verify ACP default modes 2026-05-11 19:31:41 +01:00
Peter Steinberger
4fb37c9a2d test: guard browser helper assertions 2026-05-11 19:31:28 +01:00
Peter Steinberger
864f30f868 test: guard provider helper assertions 2026-05-11 19:30:04 +01:00
Shakker
5be22e7781 test: verify Claude session rows 2026-05-11 19:29:41 +01:00
Peter Steinberger
fdd902b25e test: guard send handler mock calls 2026-05-11 19:28:33 +01:00
Shakker
8b53bee24b test: verify channel docs link 2026-05-11 19:28:07 +01:00
Peter Steinberger
ba3459bdf1 test: guard msteams test helpers 2026-05-11 19:26:28 +01:00
Shakker
5dde25c7a9 test: verify ACP error guidance 2026-05-11 19:26:10 +01:00
Shakker
260be33c3e test: verify ACP session detail lines 2026-05-11 19:24:48 +01:00
Peter Steinberger
0322821837 test: guard messaging test helpers 2026-05-11 19:24:44 +01:00
Shakker
6290050645 test: verify service exec command 2026-05-11 19:23:10 +01:00
Peter Steinberger
afac1486bf test: guard voice call test lookups 2026-05-11 19:22:58 +01:00
Shakker
22657f598e test: verify gateway fallback detail 2026-05-11 19:21:52 +01:00
Peter Steinberger
2caa0d6b4f test: guard feishu mock helpers 2026-05-11 19:21:39 +01:00
Shakker
0aee7e4db2 test: verify setup output shape 2026-05-11 19:20:19 +01:00
Peter Steinberger
e17dfb0014 test: guard extension mock helpers 2026-05-11 19:19:27 +01:00
Shakker
dea7ab00df test: verify config advisory body 2026-05-11 19:18:51 +01:00
Shakker
7ee8e0b641 test: cover channel capabilities output 2026-05-11 19:17:22 +01:00
Peter Steinberger
bc92264cd9 test: guard mock lookup helpers 2026-05-11 19:16:35 +01:00
Shakker
cc84606946 test: cover sessions table rows 2026-05-11 19:15:49 +01:00
Shakker
fd82a8c3b4 test: verify gateway SecretRef errors 2026-05-11 19:13:24 +01:00
Peter Steinberger
4da11520c8 test: remove redundant defined guards 2026-05-11 19:13:20 +01:00
Shakker
81db4aca42 test: cover channel diagnostic text 2026-05-11 19:11:46 +01:00
Peter Steinberger
8f1c044e7e test: guard plugin record helpers 2026-05-11 19:10:49 +01:00
Shakker
53f95e25fd test: check remote websocket warning 2026-05-11 19:10:32 +01:00
Peter Steinberger
a2c62b594c test: guard record helper assertions 2026-05-11 19:08:59 +01:00
Shakker
d0edacad5b test: check daemon runtime summary 2026-05-11 19:08:18 +01:00
Peter Steinberger
d8f39ce2ee test: guard remaining mock call helpers 2026-05-11 19:07:15 +01:00
Shakker
4f02ce5242 test: check sandbox explain arrays 2026-05-11 19:06:16 +01:00
Peter Steinberger
a2b36587dd test: guard gateway mock call helpers 2026-05-11 19:05:19 +01:00
Shakker
95950d5522 test: remove duplicate owner checks 2026-05-11 19:04:17 +01:00
Peter Steinberger
03b36f096b test: guard agent helper mock reads 2026-05-11 19:03:16 +01:00
Shakker
e89fb601a7 test: check nested delivery logs 2026-05-11 19:03:01 +01:00
Peter Steinberger
f27bd16cc0 test: guard command mock arg helpers 2026-05-11 19:02:03 +01:00
Shakker
baefffda69 test: check ACP resource link text 2026-05-11 19:01:00 +01:00
Peter Steinberger
c3b9f8cf19 test: guard server cron mock args 2026-05-11 19:00:55 +01:00
Shakker
12ac83c61f test: check browser doctor warning 2026-05-11 18:59:35 +01:00
jesse-merhi
79c2ed9065 feat: make exec command highlighting optional 2026-05-12 03:59:30 +10:00
Peter Steinberger
38de1a7518 test: guard gateway status helper records 2026-05-11 18:59:06 +01:00
Shakker
6748192d64 test: check gateway allowed origins 2026-05-11 18:58:10 +01:00
Peter Steinberger
7f89b074ed test: guard http header mock calls 2026-05-11 18:57:49 +01:00
Peter Steinberger
a346e8c4c5 test: guard skills upload call helper 2026-05-11 18:56:54 +01:00
Shakker
445ca84239 test: check TaskFlow command output 2026-05-11 18:56:41 +01:00
Peter Steinberger
e25283f7c7 test: guard command prompt call helpers 2026-05-11 18:55:42 +01:00
Peter Steinberger
82a243d7b6 test: guard codex record assertions 2026-05-11 18:54:47 +01:00
Shakker
cfeb7703b5 test: check ACP policy messages 2026-05-11 18:54:43 +01:00
Peter Steinberger
0bb4ef5fd3 test: guard context engine mock args 2026-05-11 18:53:24 +01:00
Peter Steinberger
ff5bbac349 test: guard model test record assertions 2026-05-11 18:52:02 +01:00
Peter Steinberger
79d9683afa test: guard compact hook records 2026-05-11 18:50:17 +01:00
Peter Steinberger
6bb5c9f957 test: fail fast on overflow compaction calls 2026-05-11 18:49:23 +01:00
Peter Steinberger
bf8bcae8b2 test: fail fast on google prompt cache calls 2026-05-11 18:48:18 +01:00
Peter Steinberger
ee0760172d test: fix overflow compaction mock call typing (#75117) 2026-05-11 18:47:46 +01:00
Peter Steinberger
b9aee95591 docs: add cron get changelog (#75117) (thanks @samzong) 2026-05-11 18:47:46 +01:00
samzong
380a679313 feat(cron): add direct job lookup
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 18:47:46 +01:00
Peter Steinberger
dc83a10733 test: tighten skip discovery hook assertions 2026-05-11 18:47:16 +01:00
Omar Shahine
efc8641393 fix: add channel status filtering (#80706)
Summary:
- Add `openclaw channels status --channel <name>` filtering through CLI, gateway protocol, and fallback status rendering.
- Document the BlueBubbles-to-iMessage cutover path so operators can probe iMessage without starting both monitors.
- Refresh generated Swift protocol model for the new optional channel status parameter.

Verification:
- `pnpm test src/gateway/server-methods/channels.status.test.ts src/commands/channels.status.command-flow.test.ts src/cli/program/routes.test.ts -- --reporter=verbose`
- `CI=true pnpm check:docs`
- `pnpm protocol:check`
- `git diff --check`
- `node scripts/check-changelog-attributions.mjs`
- CI head `45b27e3866`: focused/docs/protocol shards green locally; GitHub broad/scanner jobs queued for runners at merge attempt time; `Real behavior proof` failure is the maintainer-ignorable external-real-proof complaint.
2026-05-11 18:44:54 +01:00
Peter Steinberger
dca801c6c4 docs: update changelog for node 26 build warning (#78584) 2026-05-11 18:44:29 +01:00
Kelaw - Keshav's Agent
b9ec75fb6f Fix Node 26 build deprecation warnings 2026-05-11 18:44:29 +01:00
Peter Steinberger
3775532a29 test: wait for live model switch cleanup by assertion 2026-05-11 18:42:09 +01:00
Peter Steinberger
1533324a5a test: use immediate for browser websocket close fixtures 2026-05-11 18:41:00 +01:00
Peter Steinberger
ad5549a57b test: use immediate for browser cdp close fixtures 2026-05-11 18:39:43 +01:00
Peter Steinberger
2e7d9e2290 test: use immediate for bash abort turn 2026-05-11 18:38:32 +01:00
Peter Steinberger
07795d57fe test: wait for discord voice tool results by assertion 2026-05-11 18:36:02 +01:00
samzong
df30515315 feat(acp): expose session lineage metadata
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 18:32:46 +01:00
Peter Steinberger
61e787724c test: use immediate for telegram webhook yields 2026-05-11 18:32:20 +01:00
Peter Steinberger
85b668e9ee test: collapse restart sentinel timer retries 2026-05-11 18:30:19 +01:00
Peter Steinberger
36a36d6fde test: use immediate for realtime consult event 2026-05-11 18:29:12 +01:00
Peter Steinberger
3f08c7f0f1 test: wait for acp chat sends by assertion 2026-05-11 18:26:37 +01:00
Peter Steinberger
8d7687663b test: wait for google chat monitor by assertion 2026-05-11 18:25:07 +01:00
Shakker
a66d8ffe75 test: cover CLI spawn cleanup 2026-05-11 18:24:15 +01:00
Peter Steinberger
ef8fd8f2e3 test: use immediate for feishu pending races 2026-05-11 18:24:03 +01:00
Peter Steinberger
309f000341 docs: format Codex harness options 2026-05-11 18:23:00 +01:00
Peter Steinberger
694f40fcee fix: constrain Codex app-server sandbox 2026-05-11 18:23:00 +01:00
Peter Steinberger
68609ea3bd test: use immediate for chat refresh race 2026-05-11 18:22:06 +01:00
Peter Steinberger
b5bae1b96e test: use immediate for settings refresh race 2026-05-11 18:20:22 +01:00
Peter Steinberger
b97edc28da test: wait for ollama pull request by assertion 2026-05-11 18:19:26 +01:00
Shakker
bc7c5d960c test: spell out live probe values 2026-05-11 18:18:51 +01:00
Peter Steinberger
8c4c7280c7 test: wait for acp resolver by assertion 2026-05-11 18:17:17 +01:00
Shakker
2d36be829e test: verify UI request payloads 2026-05-11 18:15:41 +01:00
Peter Steinberger
7d2a8677c7 test: poll provider local service shutdown with vitest 2026-05-11 18:14:53 +01:00
samzong
04002e374b fix(auto-reply): precompile directive regexes
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 18:14:47 +01:00
Shakker
2249af2c95 test: verify agent runtime values 2026-05-11 18:13:39 +01:00
Peter Steinberger
5a1712fac6 test: use expect poll for gateway counter wait 2026-05-11 18:13:34 +01:00
Peter Steinberger
9f625fe5e1 test: wait for node invoke forwarding by assertion 2026-05-11 18:12:05 +01:00
Shakker
ccb6e581d3 test: check context and music options 2026-05-11 18:11:15 +01:00
Peter Steinberger
1c5942abbf test: use vi wait helper in task registry 2026-05-11 18:09:38 +01:00
Shakker
a17277d9b4 test: verify auto-reply payloads 2026-05-11 18:07:29 +01:00
Peter Steinberger
068421b68a test: remove gateway chat history polling loop 2026-05-11 18:06:00 +01:00
Shakker
839e9e970c test: inspect exec approval payloads 2026-05-11 18:04:49 +01:00
Shakker
27e705f7cd test: check auto-reply diagnostics 2026-05-11 18:02:36 +01:00
Peter Steinberger
738f94b290 fix: clarify update warning states 2026-05-11 18:02:05 +01:00
Jerran C.
530b892f06 feat(tools): add per-sender tool policies (#66933)
Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-11 18:01:39 +01:00
jesse-merhi
2401ece533 fix: resolve wrapper carriers for approval spans 2026-05-12 03:01:12 +10:00
jesse-merhi
1417047ef8 docs: note approval highlight fallback 2026-05-12 03:01:12 +10:00
jesse-merhi
a70d46717c fix: skip windows gateway command spans 2026-05-12 03:01:12 +10:00
jesse-merhi
004367b4ce test: align approval span mock 2026-05-12 03:01:12 +10:00
jesse-merhi
d9be4a3e71 fix: disable non-posix approval highlights 2026-05-12 03:01:12 +10:00
Shakker
a2a32f7d0a test: spell out configure install records 2026-05-11 18:00:33 +01:00
Shakker
d79a585878 test: spell out setup flow notes 2026-05-11 17:59:20 +01:00
Shakker
e5d8a938a1 test: verify gateway HTTP arguments 2026-05-11 17:57:47 +01:00
Shakker
013ef92034 test: check ACP retry calls 2026-05-11 17:56:28 +01:00
Peter Steinberger
1117964ed6 fix: keep music reference fetch timeout scoped 2026-05-11 17:55:56 +01:00
Peter Steinberger
234ebf434f fix: honor configured media timeouts 2026-05-11 17:55:56 +01:00
Shakker
d9491a8a98 test: check auto-reply missing files 2026-05-11 17:54:19 +01:00
Peter Steinberger
177ff5baba test: wait for agent dispatch by assertion 2026-05-11 17:53:47 +01:00
Shakker
f2ab8ef2f2 test: verify infra outbound payloads 2026-05-11 17:52:15 +01:00
Peter Steinberger
d092bf0b17 test: remove discord model picker polling loop 2026-05-11 17:51:37 +01:00
Shakker
cb0c757c83 test: spell out gateway warning output 2026-05-11 17:50:28 +01:00
Peter Steinberger
7b8125989b test: remove qa lab lazy catalog sleep 2026-05-11 17:50:02 +01:00
Peter Steinberger
d65153988d test: remove tool search pending sleep 2026-05-11 17:48:49 +01:00
Peter Steinberger
098469a2a1 test: remove codex pending-state sleeps 2026-05-11 17:47:41 +01:00
Shakker
5b2abf4fba test: spell out doctor preview warnings 2026-05-11 17:46:38 +01:00
Shakker
8412d89544 test: check daemon env warnings 2026-05-11 17:45:31 +01:00
Shakker
a66531e1c2 test: require channel command messages 2026-05-11 17:44:37 +01:00
Shakker
0977067614 test: spell out doctor repair output 2026-05-11 17:43:06 +01:00
Peter Steinberger
cde42bb49c test: remove managed image cache sleep 2026-05-11 17:42:48 +01:00
Peter Steinberger
85255d9906 test: remove ui zero-delay timers 2026-05-11 17:40:33 +01:00
Shakker
bb8a379c55 test: name gateway lifecycle payloads 2026-05-11 17:40:16 +01:00
Shakker
53b1b145f7 test: spell out channel status payloads 2026-05-11 17:38:42 +01:00
Shakker
f95b38baec test: describe cron wake errors 2026-05-11 17:37:35 +01:00
Shakker
cfb516b666 test: verify cli and daemon call shapes 2026-05-11 17:36:20 +01:00
Peter Steinberger
c0b088c08a test: clean up context warmup timing 2026-05-11 17:35:11 +01:00
Shakker
47d02e9bfa test: verify sdk and tool call values 2026-05-11 17:31:59 +01:00
Peter Steinberger
236a36847e test: remove google meet idle pull sleeps 2026-05-11 17:29:59 +01:00
Shakker
cff8e32aa4 test: verify doctor and identity output 2026-05-11 17:29:32 +01:00
Frank Yang
678b2510b2 fix: abort generic no-progress tool loops
Abort generic repeated no-progress tool loops at the configured critical threshold when identical calls keep returning identical outcomes.

Prepared head SHA: 7fa287cd0f
2026-05-12 00:29:10 +08:00
Peter Steinberger
af0b775274 test(gateway): canonicalize reset hook archive path 2026-05-11 17:28:23 +01:00
Peter Steinberger
980dfeaf02 fix(gateway): start shutdown session end emissions concurrently 2026-05-11 17:28:23 +01:00
Peter Steinberger
4f7606f2cc fix(gateway): narrow reply session end reason 2026-05-11 17:28:23 +01:00
pandadev66
376c7aea7f fix(gateway): await session_end during shutdown drain and track channel + compaction lifecycle paths (#57790)
Tighten the shutdown finalizer so it actually waits for plugin handlers
under its bounded budget and so it covers every session lifecycle path,
not just the centralized emitters in `session-reset-service.ts`.

- `drainActiveSessionsForShutdown` previously called
  `emitGatewaySessionEndPluginHook`, which fires `runSessionEnd` as
  fire-and-forget (`void hookRunner.runSessionEnd(...)`). The bounded
  2 s timeout then raced only the synchronous for-loop, so the close
  handler could proceed to subsystem teardown while a database-writing
  `session_end` plugin was still in flight -- the exact ghost-session
  failure this PR is supposed to fix. Inline the emit path: build the
  `buildSessionEndHookPayload` + `resolveStableSessionEndTranscript`
  payload directly in the drain and `await hookRunner.runSessionEnd(...)`
  under the bounded race. A never-resolving handler now surfaces as
  `timedOut=true` and the close handler records `session-end-drain` as
  a warning, but is never blocked.
- The channel reply path in `src/auto-reply/reply/session.ts` and the
  compaction lifecycle helper in `src/auto-reply/reply/session-updates.ts`
  emit `session_start` / `session_end` directly through the global hook
  runner without going through `emitGatewaySessionStartPluginHook`, so
  the shutdown tracker never saw normal channel sessions or rolled-over
  compacted sessions. Wire the tracker `note` / `forget` calls into both
  paths so every public lifecycle emitter participates in the same
  tracker, and so a compacted session is both forgotten (previous id)
  and re-noted (new id) on rollover.

Tests:

- `src/gateway/drain-active-sessions-for-shutdown.test.ts` gains two
  cases: one proves the drain genuinely waits for an in-flight handler
  to settle before returning, the other proves a never-resolving handler
  is cut off at the configured budget with `timedOut=true`.

Refs #57790.
2026-05-11 17:28:23 +01:00
pandadev66
dfa1a11676 fix(gateway): fire typed session_end on shutdown/restart for active sessions (#57790)
`session_end` was only fired when a session was replaced, reset, deleted, or
compacted -- the gateway shutdown/restart paths closed the process without
enumerating active sessions, so downstream `session_end` plugins
(e.g. claude-mem) accumulated ghost rows in `active` state across restarts.
Issue reporter saw 11 orphaned sessions cause 63 timeouts/day from agent
pool exhaustion.

Add an in-memory active-session tracker
(`src/gateway/active-sessions-shutdown-tracker.ts`) populated by
`emitGatewaySessionStartPluginHook` and forgotten unconditionally by
`emitGatewaySessionEndPluginHook` (even when no plugin listens), so any
session that has already been finalized through the normal lifecycle is
never re-fired by the shutdown drain. The close handler then calls a new
`drainActiveSessionsForShutdown({ reason })` in `session-reset-service.ts`
between the `gateway:shutdown`/`gateway:pre-restart` lifecycle hooks and
the subsystem teardown steps; the drain races a bounded 2 s total timeout
so a slow plugin cannot block SIGTERM/SIGINT, surfacing the timeout as a
`session-end-drain` warning on the shutdown result.

Extend `PluginHookSessionEndReason` with `"shutdown"` and `"restart"` so
plugins can distinguish a graceful close from a planned restart; the close
handler picks `restart` when `restartExpectedMs` is set and `shutdown`
otherwise. Update `emitGatewaySessionStartPluginHook` to also accept
`storePath`, `sessionFile`, and `agentId` so the shutdown drain can build
the same `session_end` payload shape the normal lifecycle path emits, and
update the existing call sites in `session-reset-service.ts` and
`server-methods/sessions.ts` to pass those fields through.

Tests:

- `src/gateway/active-sessions-shutdown-tracker.test.ts` (new) -- tracker
  insert/forget/clear semantics, idempotent re-noting, empty-id guard,
  snapshot isolation.
- `src/gateway/drain-active-sessions-for-shutdown.test.ts` (new) -- drain
  fires `session_end` with the right reason for every tracked session,
  skips sessions already finalized via reset/delete/compaction, and still
  forgets sessions even when no `session_end` plugin is registered.
- `src/gateway/server-close.test.ts` -- four new cases covering the
  shutdown/restart drain wiring, the bounded timeout warning, and the
  drain-skipped-when-no-helper case.

Docs:

- `docs/plugins/hooks.md` documents the new `shutdown`/`restart` values
  on `PluginHookSessionEndReason`.
- `docs/automation/hooks.md` documents the post-`gateway:shutdown`
  `session_end` drain step and its bounded execution guarantee.

Fixes #57790.
2026-05-11 17:28:23 +01:00
Shakker
8a8cb6fb30 test: verify command output text 2026-05-11 17:27:29 +01:00
Peter Steinberger
d0347f961c test: wait for qqbot queue drain 2026-05-11 17:26:41 +01:00
Peter Steinberger
c10bbddc2b test(tui): type session key assertion 2026-05-11 17:26:12 +01:00
leonaIee
503cb8d59f fix(auto-reply): keep silent turn errors visible 2026-05-11 17:26:12 +01:00
Peter Steinberger
2a6dfbd034 test: remove discord voice timer flushes 2026-05-11 17:24:33 +01:00
Peter Steinberger
15fa1e546f fix(cron): centralize wake session target resolution 2026-05-11 17:24:30 +01:00
Kaspre
f142bb0d6b test(extensions): type mocked calls explicitly 2026-05-11 17:24:30 +01:00
Kaspre
528ab7ed4d fix(wake): reject subagent session targets 2026-05-11 17:24:30 +01:00
Kaspre
5971f74bf1 fix(cron): strengthen targeted wake routing proof 2026-05-11 17:24:30 +01:00
Kaspre
db4f1fd778 fix(cron): preserve untargeted wake fanout 2026-05-11 17:24:30 +01:00
Kaspre
764bb7fbf7 test(gateway/cron): assert symmetric agentId derivation across enqueue and wake
When `cron.wake` is called with only an agent-prefixed `sessionKey` (no
explicit `agentId`), the gateway cron adapter must derive the same agentId
on both `enqueueSystemEvent` and `requestHeartbeat` so events land in (and
heartbeats fire on) the same agent target. Pre-PR, only `requestHeartbeat`
derived agentId from the key; `enqueueSystemEvent` ran through
`resolveCronSessionKey` with the configured-default agent and was rerouted
to that agent's main session under multi-agent deployments where `main`
exists but is not the default.

The new test exercises the cron-adapter directly via `state.cron.state.deps`
with a multi-agent config (`primary` default + `ops` non-default) and a
`agent:ops:cron:nightly:run:abc-123` foreign-agent session key, asserting
that both call sites resolve the agent target to "ops" rather than falling
back to "primary".

Refs #78687.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 17:24:30 +01:00
Kaspre
8399ff888f docs(system event): document --session-key timing exception
Codex review on PR #78687 [P3] flagged that the docs say next-heartbeat
"waits for the next scheduled tick" while the patched timer collapses
next-heartbeat+sessionKey to an immediate targeted wake. Add a callout
describing the exception and pointing callers who want delayed delivery
back at the no-session-key path.

Refs #78687.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 17:24:30 +01:00
Kaspre
fd8d58af05 fix(test): drop unused non-null assertions on mock.calls[0]
Caught by oxlint typescript-eslint(no-unnecessary-type-assertion) in CI.
mock.calls is typed as any[][], so the trailing `!` adds nothing.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 17:24:30 +01:00
Kaspre
072fa9b174 fix(wake): handle relative + agent-prefixed session keys consistently in cron adapter
Address review findings from successive codex rounds:

1. next-heartbeat + sessionKey now fires a targeted immediate wake.
   The regularly-scheduled heartbeat fires for the agent's main session,
   not the supplied sessionKey, so an event queued for a non-main session
   would sit stranded indefinitely; an "event"-intent wake is also
   deferred as not-due by the heartbeat runner and not retried, so
   neither path delivers without an explicit immediate wake.

2. resolveCronWakeTarget now always runs through resolveCronAgent, both
   for agent-prefixed session keys (so non-default agents are honored)
   and relative keys (so the configured default agent is used instead
   of the hardcoded "main" returned by resolveAgentIdFromSessionKey).
   Mirrors the matching fix in the enqueueSystemEvent adapter so wake
   and enqueue resolve to the same target.

3. Generated Swift `WakeParams` models now expose the new optional
   `sessionkey` field (codingKey "sessionKey") in both the macOS and
   shared OpenClawKit copies. Locally regenerated from agent.ts via
   protocol:gen + protocol:gen:swift would have produced this; the
   environment couldn't run the generators (fs-safe transitive
   typecheck errors), so the diff was applied by hand to match what
   pnpm protocol:check would output.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 17:24:30 +01:00
Kaspre
4ddd942f5f feat(wake): expose typed sessionKey on wake protocol + system event CLI
Adds an optional sessionKey to the WakeParamsSchema and threads it through
the gateway wake handler, CronService.wake(), and the underlying timer.wake()
ops so callers can target a specific session for async-task completion
relays instead of always hitting the agent's main session.

Also adds --session-key to `openclaw system event`.

The schema rejects empty/non-string sessionKey at the gateway boundary;
mismatched session keys (a key that does not belong to the resolving agent)
fall back to the agent's main session inside resolveCronSessionKey, which
is the existing safety path.

Refs #52305 (companion to PR #50818, which closes the related cron-run
remap slice at internal enqueue sites). Doesn't depend on #50818.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-11 17:24:30 +01:00
Shakker
13bc7037b1 test: verify infra generated values 2026-05-11 17:23:49 +01:00
Peter Steinberger
f57afbbd16 test: remove agent async timer flushes 2026-05-11 17:21:53 +01:00
Shakker
ac478b2c6a test: verify diagnostics and session callbacks 2026-05-11 17:21:03 +01:00
Peter Steinberger
1f43e79a58 test: remove plugin contract timer flushes 2026-05-11 17:19:44 +01:00
Shakker
d4f3d4edad test: verify schema and timing messages 2026-05-11 17:18:19 +01:00
Shakker
8f79e34cbe test: verify install and runtime messages 2026-05-11 17:16:25 +01:00
Peter Steinberger
b3a9eba793 test: wait for msteams monitor startup 2026-05-11 17:14:23 +01:00
Peter Steinberger
902e4807c4 test: wait for qa suite stagger starts 2026-05-11 17:12:42 +01:00
Peter Steinberger
d104793520 test: wait for microsoft voice capture 2026-05-11 17:11:03 +01:00
Shakker
a63267eb6a test: verify generated core values 2026-05-11 17:07:48 +01:00
Peter Steinberger
6e7943f5bb refactor: share channel route target collection 2026-05-11 17:07:18 +01:00
Peter Steinberger
baba186717 test: wait for session history revocation 2026-05-11 17:07:09 +01:00
Peter Steinberger
d381879dd7 test: route extension ansi helpers through sdk 2026-05-11 17:06:47 +01:00
Peter Steinberger
19b78380f5 test: assert CLI lastCallUsage persists to session store 2026-05-11 17:06:47 +01:00
Neerav Makwana
af2897e29b fix: persist CLI lastCallUsage for session context totals (#78194)
- Session store: derive totalTokens for CLI providers from agentMeta.lastCallUsage
  when present (avoids cumulative usage; matches persistSessionUsageUpdate).
- Claude CLI runner: populate lastCallUsage from the final attempt usage blob.
- Add regression test for claude-cli lastCallUsage snapshot.

Fixes #78194.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-11 17:06:47 +01:00
Peter Steinberger
1fcb6e6427 test: remove inbound debounce timer flush 2026-05-11 17:05:28 +01:00
Shakker
4fcc3e526b test: verify extension runtime messages 2026-05-11 17:04:33 +01:00
Peter Steinberger
0218afd8e3 test: wait for run-node spawn 2026-05-11 17:04:04 +01:00
Peter Steinberger
80d1df6e68 test: remove slack duplicate timer flush 2026-05-11 17:02:45 +01:00
Peter Steinberger
166f2bcee4 test: wait for openai realtime socket 2026-05-11 17:01:27 +01:00
Peter Steinberger
f3f120cde8 test: wait for openai tts capture events 2026-05-11 16:59:54 +01:00
Peter Steinberger
435e1a74fa test: keep extension tests on sdk terminal helper 2026-05-11 16:59:35 +01:00
Chinar Amrutkar
f2c15f94ae fix(channels): narrow bundled channel loader diagnostics
Narrow bundled channel wrong-loader diagnostics, preserve ordinary missing-register debug details, and add focused loader coverage.

Verification:
- pnpm test src/plugins/loader.test.ts src/plugins/loader.cli-metadata.test.ts -- --reporter=verbose
- env -u OPENCLAW_TESTBOX -u OPENCLAW_TESTBOX_REMOTE_RUN pnpm check:changed

CI notes:
- Real behavior proof passed with maintainer proof: override label.
- check-additional-boundaries-d is red from existing extension test imports outside this PR: extensions/telegram/src/bot.create-telegram-bot.test.ts and extensions/whatsapp/src/login.coverage.test.ts.

Co-authored-by: Chinar Amrutkar <chinar.amrutkar@gmail.com>
2026-05-11 16:58:06 +01:00
Peter Steinberger
820b21ad46 test: remove synology preauth timer flush 2026-05-11 16:57:45 +01:00
Peter Steinberger
c9c9c3f7f1 fix: surface plugin beta fallback outcomes 2026-05-11 16:57:27 +01:00
Shakker
9a1de1c4ca test: verify channel warning values 2026-05-11 16:57:18 +01:00
Peter Steinberger
761b2ae870 test: remove feishu comment timer flushes 2026-05-11 16:55:54 +01:00
Peter Steinberger
a3db718d86 test: remove feishu queue timer flush 2026-05-11 16:54:26 +01:00
Peter Steinberger
63ba3cd63d fix(doctor): match route channel coverage to runtime 2026-05-11 16:53:05 +01:00
stainlu
c9fadc597a docs(changelog): scope message-tool warning reference 2026-05-11 16:53:05 +01:00
stainlu
d9862141c1 fix(doctor): keep message-tool warning deterministic 2026-05-11 16:53:05 +01:00
stainlu
f79b8468ac fix(doctor): respect default-account route coverage 2026-05-11 16:53:05 +01:00
stainlu
4ce4a951a1 fix(doctor): normalize channel route coverage 2026-05-11 16:53:05 +01:00
stainlu
0923e9e9d9 fix(doctor): honor account route coverage 2026-05-11 16:53:05 +01:00
stainlu
7382bdfaf8 fix(doctor): respect route account coverage 2026-05-11 16:53:05 +01:00
stainlu
aecebd3347 fix(doctor): warn for scoped channel fallbacks 2026-05-11 16:53:05 +01:00
stainlu
60acfd9dfe fix(doctor): include fallback channel warnings 2026-05-11 16:53:05 +01:00
stainlu
1831162ac1 fix(doctor): warn routed agents missing message tool 2026-05-11 16:53:05 +01:00
Peter Steinberger
5dc7a05f7f test: remove acp approval retry timer flush 2026-05-11 16:52:02 +01:00
Shakker
98c825c4e3 test: verify qa runtime values 2026-05-11 16:51:31 +01:00
Peter Steinberger
d4b2560d3c test: remove mcp shutdown timer flush 2026-05-11 16:50:20 +01:00
Peter Steinberger
accf0ff335 test: remove keyed queue timer flush 2026-05-11 16:48:31 +01:00
Shakker
28a23ca980 test: verify generated command values 2026-05-11 16:47:42 +01:00
Peter Steinberger
49fa943eca test: remove hook queue timer flush 2026-05-11 16:45:58 +01:00
Shakker
2deeb9f668 test: verify teams generated values 2026-05-11 16:45:49 +01:00
corevibe555
a1fc955aef fix(memory): load sqlite-vec platform variant fallback
Resolve the sqlite-vec platform package exported native extension when the meta package is absent, preserving explicit extensionPath priority and keeping the existing config hint on load failures.

Adds coverage for the real exported vec0 subpath so package.json export-map regressions fail in tests.

Fixes #77838.

Co-authored-by: corevibe555 <leaderbossprog2025@gmail.com>
2026-05-11 16:45:45 +01:00
Peter Steinberger
3bad58e3eb test: remove whatsapp route timer flush 2026-05-11 16:44:31 +01:00
Peter Steinberger
72998128ce test: remove qa agent process sleep 2026-05-11 16:42:38 +01:00
Val Alexander
4eb37254b3 fix(ui): localize chat panel strings
Localize the remaining Control UI chat welcome, composer, run-control, session/model/thinking/agent selector, and zh-CN Skills labels through the existing Control UI i18n pipeline.

Fixes #79937.

Verification:
- pnpm ui:i18n:check
- pnpm exec oxfmt --check --threads=1 ui/src/ui/chat/chat-welcome.ts ui/src/ui/chat/run-controls.ts ui/src/ui/chat/session-controls.ts ui/src/ui/views/chat.ts ui/src/ui/chat/run-controls.test.ts ui/src/ui/views/chat.test.ts ui/src/i18n/locales/en.ts ui/src/i18n/locales/zh-CN.ts
- pnpm test ui/src/ui/chat/run-controls.test.ts ui/src/ui/views/chat.test.ts ui/src/i18n/test/translate.test.ts
- git diff --check origin/main..HEAD
2026-05-11 10:42:34 -05:00
Shakker
3bd1ff4140 test: verify memory plugin artifacts 2026-05-11 16:42:29 +01:00
Peter Steinberger
f707f3a5bb test: fix main check failures 2026-05-11 16:41:46 +01:00
Peter Steinberger
8e1f1b56ae test: remove voice call manager sleeps 2026-05-11 16:41:17 +01:00
Shakker
561c19cb58 test: verify plugin warning messages 2026-05-11 16:40:07 +01:00
Peter Steinberger
b0db82be15 test: remove voice call timing sleeps 2026-05-11 16:38:08 +01:00
Val Alexander
6b3cd9043e fix(control-ui): keep channel statuses responsive
Summary:
- Keep Channels responsive by opening on cached/runtime snapshots, bounding live probes, and preventing stale slow probe results from replacing newer snapshots.
- Reduce Control UI churn by scoping Nodes polling to the active Nodes tab, debouncing sessions.changed reconciliation, and bounding secondary chat/session refreshes.
- Scope config schema analysis before section-limited renders so excluded root sections are not fully analyzed.

Verification:
- pnpm test ui/src/ui/app-channels.test.ts ui/src/ui/controllers/channels.test.ts ui/src/ui/app-settings.refresh-active-tab.node.test.ts ui/src/ui/app-gateway.sessions.node.test.ts ui/src/ui/app-lifecycle-connect.node.test.ts ui/src/ui/controllers/sessions.test.ts ui/src/ui/views/config.browser.test.ts src/gateway/server-methods/channels.status.test.ts src/gateway/control-ui.http.test.ts ui/src/ui/app-polling.node.test.ts ui/src/ui/app-gateway-chat-load.node.test.ts ui/src/ui/app-gateway.node.test.ts ui/src/ui/app-chat.test.ts ui/src/ui/app-render.helpers.node.test.ts ui/src/ui/app-lifecycle.node.test.ts
- pnpm exec oxfmt --check --threads=1 <changed files>
- git diff --check origin/main...HEAD
- node scripts/run-oxlint.mjs --tsconfig config/tsconfig/oxlint.core.json <changed TypeScript files>
- pnpm changed:lanes --json

Note: local pnpm check:changed reached core lint and failed on src/gateway/server-methods/nodes.invoke-wake.test.ts, which is unchanged in this PR and already present on current origin/main; changed-file lint passed under the same repo wrapper.
2026-05-11 10:37:35 -05:00
Shakker
678c2c070d test: verify browser policy responses 2026-05-11 16:36:47 +01:00
Peter Steinberger
b29b2558a7 test: remove launcher polling waits 2026-05-11 16:35:29 +01:00
Shakker
80175cfb74 test: verify browser route values 2026-05-11 16:33:31 +01:00
Shakker
c5e481eeb1 test: verify cdp connection options 2026-05-11 16:31:57 +01:00
Shakker
8aa0bea4b6 test: check anthropic beta headers 2026-05-11 16:30:51 +01:00
Peter Steinberger
7e57b69e6e test: finish broad matcher cleanup 2026-05-11 16:30:29 +01:00
Shakker
46a0d3ba85 test: check node wake dynamic values 2026-05-11 16:28:50 +01:00
Shakker
08acf80891 test: check daemon install messages 2026-05-11 16:26:36 +01:00
Shakker
b11bdabfa2 test: check doctor plugin warnings 2026-05-11 16:25:36 +01:00
Shakker
6923cf348a test: check doctor allowlist warnings 2026-05-11 16:24:16 +01:00
Shakker
99ae349ad2 test: check gateway discovery logs 2026-05-11 16:23:09 +01:00
Shakker
6a1f53316f test: check tailscale preserve logs 2026-05-11 16:22:18 +01:00
Peter Steinberger
e8785972d0 test: tighten agent auth assertions 2026-05-11 16:21:43 +01:00
Shakker
07805cc75b test: check session memory filenames 2026-05-11 16:21:22 +01:00
Shakker
4630076381 test: check cron timer handles 2026-05-11 16:19:50 +01:00
Shakker
3ce0b9769e test: check cleanup backup prompts 2026-05-11 16:18:56 +01:00
Shakker
948e87939f test: check sandbox command messages 2026-05-11 16:18:12 +01:00
Peter Steinberger
9340105bb5 fix(agents): preserve media tools for alsoAllow policies 2026-05-11 16:17:39 +01:00
Shakker
70935a110c test: check gateway stage error logs 2026-05-11 16:17:18 +01:00
Neerav Makwana
5171c2654a fix(models/auth): preserve primary when login omits --set-default
Provider applyConfig patches merged during models auth login could replace
agents.defaults.model.primary even without --set-default. Snapshot the prior
defaults.model and restore it after the patch unless the user opts in.

Fixes #78162.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-11 16:16:49 +01:00
Peter Steinberger
eb34d09232 test: tighten agent assertions 2026-05-11 16:16:36 +01:00
Shakker
1067abc665 test: check device identity pem blocks 2026-05-11 16:16:20 +01:00
Shakker
d23fb1e708 test: check heartbeat ack send options 2026-05-11 16:15:32 +01:00
Shakker
f80db58689 test: check heartbeat telegram send options 2026-05-11 16:14:09 +01:00
Ayaan Zaidi
9c16388177 ci(mantis): serialize telegram account proofs 2026-05-11 20:42:00 +05:30
Shakker
77e3f2b6e2 test: check migration backup filenames 2026-05-11 16:11:36 +01:00
Shakker
723ebb2a2c test: check sync hook warning text 2026-05-11 16:10:45 +01:00
Shakker
a150e35928 test: check plugin service failure logs 2026-05-11 16:10:06 +01:00
Shakker
691440f061 test: check inbound claim hook warnings 2026-05-11 16:09:26 +01:00
Shakker
584c9bdeb2 test: check reply dispatch hook warnings 2026-05-11 16:08:38 +01:00
Peter Steinberger
938b1e0225 test: cover MiniMax Anthropic route guard 2026-05-11 16:08:30 +01:00
Peter Steinberger
4bb7acd88b test: tighten config assertions 2026-05-11 16:06:43 +01:00
Shakker
c0c8f7c2d4 test: check security fix outputs 2026-05-11 16:06:21 +01:00
Shakker
fb4d18bcba test: check skill scanner permission errors 2026-05-11 16:04:57 +01:00
Shakker
788ef05384 test: check release tag errors 2026-05-11 16:04:04 +01:00
Shakker
ef6b157389 test: check i18n warning messages 2026-05-11 16:02:42 +01:00
Neerav Makwana
7bf4458bbe fix: guard empty MiniMax Anthropic messages (#74731)
Fixes #74589. Thanks @neeravmakwana and @DerekEXS.
2026-05-11 16:02:03 +01:00
Shakker
bc33a2049d test: check chat idempotency keys 2026-05-11 16:01:51 +01:00
Shakker
338fbd8bfd test: check control ui nav calls 2026-05-11 16:00:51 +01:00
Shakker
618818d20b test: check usage filter warnings 2026-05-11 15:59:49 +01:00
Peter Steinberger
8aa286476d test: tighten command assertions 2026-05-11 15:59:03 +01:00
Shakker
3e332426fc test: check browser navigation page handles 2026-05-11 15:58:55 +01:00
Shakker
2a42e4743f test: check browser doctor notes 2026-05-11 15:57:53 +01:00
Jayesh Betala
0c9f34eac1 fix(telegram): honor forced document videos
Fixes #80389. Thanks @jbetala7.
2026-05-11 20:27:36 +05:30
Peter Steinberger
ea663dbb56 test: allow old Linux package update baselines 2026-05-11 15:57:12 +01:00
Shakker
b58ee9eee2 test: check matrix verification block logs 2026-05-11 15:56:31 +01:00
Peter Steinberger
2d2f4bb2bd test: align cron heartbeat override expectation 2026-05-11 15:55:21 +01:00
Peter Steinberger
402fa0e935 fix: keep cron heartbeat wakes on session route 2026-05-11 15:55:21 +01:00
Shakker
7b28a52676 test: fix whatsapp ansi helper import 2026-05-11 15:55:06 +01:00
jeffjhunter
850d685d4b Fix Codex app-server OAuth harness auth 2026-05-11 15:54:43 +01:00
Shakker
affaeaf8d3 test: check telegram bot error output 2026-05-11 15:54:08 +01:00
Shakker
af9c09a21f test: check telegram chat action logs 2026-05-11 15:51:54 +01:00
Peter Steinberger
16b33fc91e test: tighten auto reply assertions 2026-05-11 15:51:21 +01:00
Shakker
9bfd1947d5 test: check twitch client log messages 2026-05-11 15:51:05 +01:00
Shakker
ffb814c420 test: check whatsapp login messages 2026-05-11 15:49:59 +01:00
Shakker
aa072aedef test: check acp gateway startup args 2026-05-11 15:45:50 +01:00
Shakker
2a53725161 test: check bonjour warning messages 2026-05-11 15:44:25 +01:00
Shakker
180fa826ba test: check acp resume lifecycle fields 2026-05-11 15:42:42 +01:00
FullerStackDev
b8e9492086 fix(bonjour): back off probing watchdog repairs 2026-05-11 15:42:39 +01:00
Shakker
af4e90f41b test: verify acp spawn wake routing 2026-05-11 15:41:38 +01:00
Peter Steinberger
0693603e5f test: tighten remaining plugin sdk assertions 2026-05-11 15:41:25 +01:00
Statxc
6943b5b4a6 fix: tighten system event dedupe identity
Refs #69478.

Co-authored-by: statxc <181730535+statxc@users.noreply.github.com>
2026-05-11 15:41:08 +01:00
Shakker
de0e5f662a test: check oauth ref ids 2026-05-11 15:40:07 +01:00
Peter Steinberger
ab7e4e79cf docs: mark symbolic header shim temporary 2026-05-11 15:39:38 +01:00
Shakker
c714755af6 test: verify tool hash digest shape 2026-05-11 15:38:56 +01:00
Ayaan Zaidi
adc3ba45ca ci(mantis): render proof media responsively 2026-05-11 20:08:02 +05:30
Shakker
4b6c43af48 test: check media path resolver options 2026-05-11 15:37:51 +01:00
Shakker
cd5018b40e test: check export session arguments 2026-05-11 15:36:41 +01:00
Shakker
99bac079ed test: check models command workspace args 2026-05-11 15:35:50 +01:00
Shakker
8f66462125 test: verify restart sentinel payloads 2026-05-11 15:34:48 +01:00
Peter Steinberger
46e150ea68 test: tighten plugin sdk assertions 2026-05-11 15:33:31 +01:00
Shakker
69f4639aac test: check stop target payloads 2026-05-11 15:33:09 +01:00
Shakker
9139ce0652 test: inspect reply dispatch hook inputs 2026-05-11 15:32:00 +01:00
Shakker
e521f56116 test: check directive alias parsing 2026-05-11 15:30:04 +01:00
Ayaan Zaidi
1ff833d66d ci(mantis): fit telegram proof gifs in comments 2026-05-11 19:59:54 +05:30
YBoy
ff8bc72c81 fix: consolidate gateway doctor service notes (#78688)
Fixes #80287.

Co-authored-by: YB0y <brianandez6@gmail.com>
2026-05-11 15:29:14 +01:00
Shakker
f9c3d683cd test: cover queued followup retargeting 2026-05-11 15:28:54 +01:00
Peter Steinberger
f994094cb4 fix(cron): sanitize target-last heartbeat wakes 2026-05-11 15:28:39 +01:00
Shakker
ec5a97467c test: cover reply routing decisions 2026-05-11 15:28:05 +01:00
Peter Steinberger
8ad588d9e6 test: tighten isolated cron assertions 2026-05-11 15:27:33 +01:00
Shakker
3255d2e09d test: check session fork headers 2026-05-11 15:27:15 +01:00
Shakker
754450cbb9 test: verify transcript replay records 2026-05-11 15:26:14 +01:00
Shakker
c4b551f85e test: check capability cli error text 2026-05-11 15:25:22 +01:00
Shakker
a4b95296ed test: exercise command policy resolvers 2026-05-11 15:22:20 +01:00
Peter Steinberger
0ddf10ff89 test: tighten cron assertions 2026-05-11 15:22:15 +01:00
Shakker
bc6b34a67a test: check mcp config messages 2026-05-11 15:19:34 +01:00
Peter Steinberger
601b70557d test: tighten config validation assertions 2026-05-11 15:17:26 +01:00
Shakker
17c75df670 test: check config guard error output 2026-05-11 15:16:59 +01:00
Peter Steinberger
9074f08fc3 test: tighten channel assertion checks 2026-05-11 15:15:12 +01:00
Shakker
5ad73cb995 test: verify default account warning copy 2026-05-11 15:14:43 +01:00
Shakker
6c19f389a8 test: spell out gateway send responses 2026-05-11 15:13:07 +01:00
Shakker
50a9f9a3ce test: cover exec safe bin warning text 2026-05-11 15:11:20 +01:00
Gabriel
83ffc1f47a fix(gateway): dedupe inflight outbound requests (#68341)
Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-11 15:10:21 +01:00
Shakker
0343a2e689 test: pin realtime relay requests 2026-05-11 15:09:19 +01:00
Peter Steinberger
281a88d6df test: tighten cli gateway assertions 2026-05-11 15:08:14 +01:00
Shakker
fd7448299f test: pin browser state errors 2026-05-11 15:07:16 +01:00
Peter Steinberger
3dd2266723 test: tighten cli smoke assertions 2026-05-11 15:04:49 +01:00
Shakker
8ee4290e06 test: pin Zalo lifecycle logs 2026-05-11 15:04:34 +01:00
Peter Steinberger
02eff52f16 test(plugin-sdk): align compact progress draft expectation 2026-05-11 15:04:30 +01:00
Peter Steinberger
f3f1509ee9 fix(plugin-sdk): restore compact progress draft cap 2026-05-11 15:04:30 +01:00
Peter Steinberger
b2153e01d8 docs: add memory budget changelog entry (#74088) 2026-05-11 15:04:30 +01:00
YB0y
3b8cfc3657 fix(memory-core): cap MEMORY.md size during dreaming promotions to prevent unbounded growth (#73691)
Dreaming's deep-phase promotion path appends to ~/.openclaw/workspace-<agent>/MEMORY.md
without a durable size budget. After weeks of use, the file grows past the bootstrap
injection cap (~12KB/file), at which point bootstrap silently truncates promoted memory
and (per the issue body) session writes can hit lock timeouts that wedge the gateway.

Adds a bounded compaction step in applyShortTermPromotions: before each write, drop the
OLDEST auto-promoted sections (date-ordered) until existing + new section fits within
memoryFileMaxChars (default 10,000 chars, safely below the 12KB bootstrap cap).
User-authored content is preserved unconditionally; only dreaming-owned sections are
eligible for compaction.

Verified:
- pnpm install --frozen-lockfile
- pnpm test extensions/memory-core/src/memory-budget.test.ts extensions/memory-core/src/short-term-promotion.test.ts
- pnpm exec oxfmt --check --threads=1 extensions/memory-core/src/memory-budget.ts extensions/memory-core/src/memory-budget.test.ts extensions/memory-core/src/short-term-promotion.ts extensions/memory-core/src/short-term-promotion.test.ts CHANGELOG.md
- pnpm check:changed
- pnpm tsgo:core
- pnpm tsgo:extensions
- pnpm tsgo:test:src
- git diff --check
- live driver: real applyShortTermPromotions across 5 sweeps with oversized seeded MEMORY.md — file stayed bounded, oldest sections compacted, user content preserved

Closes #73691
2026-05-11 15:04:30 +01:00
Shakker
1317779a05 test: pin gh config discovery results 2026-05-11 15:02:11 +01:00
Peter Steinberger
6b2b7d12e5 test: tighten media understanding assertions 2026-05-11 15:01:19 +01:00
Shakker
54edf9513b test: pin cron channel delivery calls 2026-05-11 15:00:20 +01:00
Peter Steinberger
2858afd4cf test: tighten config session assertions 2026-05-11 14:59:09 +01:00
Peter Steinberger
4615f08817 fix: harden gh config discovery 2026-05-11 14:57:42 +01:00
tmimmanuel
72b5cddbe1 fix(doctor): surface GH_CONFIG_DIR hint when gh auth lives at a different HOME
When OpenClaw spawns an agent shell with a different HOME than the user
that ran `gh auth login` (per-agent codex homes, systemd User= services,
sudo'd shells), `gh` looks at $XDG_CONFIG_HOME/gh or $HOME/.config/gh and
reports "not logged into any GitHub hosts" even though the operator HOME
has a valid hosts.yml.

Add `detectGhConfigDirMismatch` in src/agents/skills/gh-config-discovery.ts:
a pure helper that takes process env plus a fileExists probe and returns
either "auth-discoverable", "no-known-auth", "explicit-gh-config-dir-set",
or a "mismatch" with the alternate config dir, the host file path, and a
suggested GH_CONFIG_DIR value to set on the gateway service environment.
The helper checks `/root`, `$SUDO_USER`'s home, and `$USER`'s home as
candidate operator homes on Linux/macOS, and uses platform-specific path
joins so the same logic works on Windows test runners.

Wire the helper into the doctor skills health flow: when the github skill
is reported and the gh binary is present, call the discovery helper and,
on a mismatch, print a "GitHub CLI" note with the operator-actionable
fix instructions before any unavailable-skill repair prompt.

Update skills/github/SKILL.md with a troubleshooting subsection that
documents GH_CONFIG_DIR for service/agent environments where HOME differs
from the user that ran `gh auth login`.

Fixes #78063.
2026-05-11 14:57:42 +01:00
Shakker
0abf14777d test: pin cron model switch retry 2026-05-11 14:57:04 +01:00
Peter Steinberger
0c2296015c test: tighten cli assertion checks 2026-05-11 14:56:43 +01:00
Peter Steinberger
511d706cf5 test: tighten crestodian assertions 2026-05-11 14:54:32 +01:00
Peter Steinberger
bfcd816953 test: tighten provider live assertions 2026-05-11 14:52:12 +01:00
Peter Steinberger
ed6d72efcf test: tighten browser mcp assertions 2026-05-11 14:50:16 +01:00
Peter Steinberger
5dbeacabc9 test: tighten browser route assertions 2026-05-11 14:47:22 +01:00
Peter Steinberger
248207dace test: tighten browser server assertions 2026-05-11 14:45:43 +01:00
Peter Steinberger
09fcd19814 test: tighten codex event assertions 2026-05-11 14:42:25 +01:00
Peter Steinberger
c20d45e346 test: tighten codex binding assertions 2026-05-11 14:40:27 +01:00
Feelw00
c1b59a95bf fix(cron): mark manual cron runs active (#78243)
Summary:
- Mark forced/manual cron runs active in the task registry until completion and clear them in finally.
- Add regression coverage for manual run success and failure cleanup.
- Update changelog for #78243 and apply a small lint-only test fix needed after rebasing on latest main.

Fixes #78233

Verification:
- pnpm test src/plugin-sdk/channel-streaming.test.ts src/cron/active-jobs-manual-run.test.ts
- pnpm run lint:extensions:bundled
- pnpm test extensions/codex/src/app-server/side-question.test.ts
- CI: https://github.com/openclaw/openclaw/actions/runs/25673031776

Co-authored-by: Feelw00 <dhrtn1006@naver.com>
2026-05-11 14:40:21 +01:00
Peter Steinberger
ebf0d6bc8e test: tighten qa lab live assertions 2026-05-11 14:38:49 +01:00
Peter Steinberger
1320e0ec80 test: tighten qa lab web assertions 2026-05-11 14:36:53 +01:00
Peter Steinberger
1f1a1412ff test: tighten qa lab config assertions 2026-05-11 14:34:40 +01:00
Shakker
6f3fd2410c test: pin browser fallback calls 2026-05-11 14:32:39 +01:00
Peter Steinberger
c8c1f46da1 test: tighten qa lab runtime assertions 2026-05-11 14:30:10 +01:00
Shakker
563bbd3df4 test: pin Telegram dispatch drafts 2026-05-11 14:28:38 +01:00
Peter Steinberger
ee5b06f9fe docs: clarify contributor changelog ownership 2026-05-11 14:26:56 +01:00
Peter Steinberger
d2f578cbb4 fix: retire timed-out codex app-server clients 2026-05-11 14:26:56 +01:00
Peter Steinberger
fecf18d277 test: tighten qa matrix assertions 2026-05-11 14:26:48 +01:00
Shakker
610b695a12 test: pin Telegram draft stream checks 2026-05-11 14:26:31 +01:00
Peter Steinberger
a3c7fea512 fix(agents): avoid Pi resource discovery stalls
Co-authored-by: dataCenter430 <titan032000@gmail.com>
2026-05-11 14:25:55 +01:00
Peter Steinberger
ac7e1c36eb fix(whatsapp): retry opening-phase 428 closes
Co-authored-by: dataCenter430 <titan032000@gmail.com>
2026-05-11 14:25:55 +01:00
Shakker
1f8d29e532 test: pin command registry checks 2026-05-11 14:25:18 +01:00
Shakker
19c66ad3fe test: pin Codex run attempt assertions 2026-05-11 14:24:01 +01:00
VACInc
6a741102d1 test(codex): keep native tool observability fixture generic 2026-05-11 14:23:46 +01:00
VACInc
88d0c77add docs: note codex tool observability fix 2026-05-11 14:23:46 +01:00
VACInc
a28bf10ce2 fix(codex): observe native tool completions 2026-05-11 14:23:46 +01:00
Peter Steinberger
5b6f4d6bb6 test: tighten acpx memory assertions 2026-05-11 14:23:32 +01:00
Peter Steinberger
ac8a193cbe test: tighten memory wiki assertions 2026-05-11 14:21:08 +01:00
Shakker
ead6179718 test: pin Codex side question calls 2026-05-11 14:20:02 +01:00
Peter Steinberger
97bf9bfd22 docs: credit qqbot binding fix contributor (#73567) 2026-05-11 14:19:34 +01:00
statxc
5eda2a2bc6 fix(qqbot): align #69546 fix with merged main 2026-05-11 14:19:34 +01:00
statxc
278ffbdb53 fix(qqbot): type active config provider 2026-05-11 14:19:34 +01:00
statxc
d69b663021 fix(qqbot): re-evaluate routing bindings per inbound message
QQBot's gateway captured `ctx.cfg` once at startup and reused that
reference for every inbound, so peer-specific bindings added via the
CLI were ignored until the gateway restarted (the routing resolver
caches evaluated bindings keyed by the cfg object reference).

Add a small `ActiveCfgProvider` that reads `getRuntimeConfig()` from
the plugin SDK on every event and falls back to the startup snapshot
when the runtime registry is not populated, mirroring Telegram's
per-event lookup pattern. Wire it into `handleMessage` so both the
inbound pipeline and outbound dispatch run against the live config.

Fixes #69546.
2026-05-11 14:19:34 +01:00
Peter Steinberger
8d2dd8cf2e test: tighten openai extension assertions 2026-05-11 14:19:09 +01:00
Peter Steinberger
03d9bc14b5 test: fix progress draft truncation expectations 2026-05-11 14:18:23 +01:00
Shakker
c214a5f262 test: pin self-hosted provider setup 2026-05-11 14:17:08 +01:00
Peter Steinberger
242e2474a6 test: tighten telegram extension assertions 2026-05-11 14:16:48 +01:00
Shakker
6462472358 test: pin session schema success 2026-05-11 14:14:28 +01:00
Peter Steinberger
6781957a99 test: tighten channel extension assertions 2026-05-11 14:13:46 +01:00
Shakker
31f128e86f test: pin tailscale bind diagnostics 2026-05-11 14:13:27 +01:00
Shakker
1dddb502a8 test: pin config schema fields 2026-05-11 14:12:14 +01:00
Peter Steinberger
493f363857 test: tighten slack monitor assertions 2026-05-11 14:11:39 +01:00
Shakker
98f07a5387 test: pin cron delivery targets 2026-05-11 14:09:54 +01:00
Peter Steinberger
8975ac83f4 test: tighten slack extension assertions 2026-05-11 14:09:30 +01:00
Shakker
19a040ee88 test: pin cron session entries 2026-05-11 14:08:06 +01:00
Peter Steinberger
8218595cd1 docs: add changelog for follow-up queue guard (#68839) 2026-05-11 14:07:58 +01:00
Feelw00
137d566422 fix(auto-reply): guard FOLLOWUP_QUEUES delete against late drain finally
Regression: the drain IIFE finally (`drain.ts:263-271`) performed an
unconditional `FOLLOWUP_QUEUES.delete(key)` + `clearFollowupDrainCallback(key)`
using only the key, without checking whether the captured `queue` still matched
the map entry. Under the `/stop` + immediate followup sequence, a late-returning
D1 finally could delete the map entry for a fresh Q2 and orphan it until the
next enqueue.

Fix: only remove the map entry and drain callback when `FOLLOWUP_QUEUES.get(key)
=== queue`. Mirrors the identity pattern noted in
`subagent-announce-queue.ts:62-64`.

Adds `src/auto-reply/reply/queue/drain.identity-guard.test.ts` which uses real
`enqueueFollowupRun` / `scheduleFollowupDrain` / `clearSessionQueues` (no
module mocks) and a Deferred gate to park D1 inside `runFollowup`. The test
uses `restartIfIdle=false` on the Q2 enqueue so D1's finally is the only
mutator that can touch the map entry, producing deterministic pre/post-fix
differentiation:
  pre-fix  : get(key) === undefined (Q2 orphaned), depth === 0
  post-fix : get(key) === Q2,                     depth === 1

AI-assisted (fully tested). 1082 auto-reply/reply tests pass, pnpm check +
pnpm build clean.
2026-05-11 14:07:58 +01:00
Shakker
535348a1c7 test: pin cron main wake calls 2026-05-11 14:06:50 +01:00
Shakker
36d90ce431 test: pin cron read status 2026-05-11 14:05:33 +01:00
Peter Steinberger
68cec724b1 test: tighten signal extension assertions 2026-05-11 14:04:55 +01:00
Val Alexander
42fc84f4b4 fix(control-ui): add static mount fallback
Summary:
- Add a plain HTML Control UI fallback when the module app never mounts.
- Document blank-page recovery guidance and keep the fallback retry-friendly.
- Cover the timeout path with iframe-isolated regression tests.

Verification:
- pnpm exec oxfmt --check --threads=1 ui/index.html ui/src/ui/mount-fallback.test.ts
- pnpm test ui/src/ui/app.talk.test.ts ui/src/ui/mount-fallback.test.ts
- pnpm ui:build
- pnpm check:changed
- GitHub CI for 8ef18e8bca completed without failures.
2026-05-11 08:03:49 -05:00
Peter Steinberger
58087ef3d6 test: tighten extension auth assertions 2026-05-11 14:02:35 +01:00
Peter Steinberger
0a92d7a8ff fix: widen progress draft preview lines 2026-05-11 14:02:19 +01:00
Feelw00
08cffbb067 fix(gateway): clear node wake state without registration (#68848)
Summary:
- Clear speculative gateway node wake state when APNs registration is missing.
- Add regression coverage for unregistered node IDs.
- Add changelog credit for @Feelw00.

Verification:
- git diff --check
- pnpm test src/gateway/server-methods/nodes.wake-leak.test.ts src/gateway/server-methods/nodes.invoke-wake.test.ts
- GitHub exact-head checks green on 29db03ff4e
2026-05-11 14:02:03 +01:00
Peter Steinberger
2c89dad895 test: tighten remaining UI assertions 2026-05-11 13:59:43 +01:00
Peter Steinberger
36aea9792f docs: update changelog for #80333 2026-05-11 13:58:14 +01:00
samzong
1ecd46f49b fix(channels): cache selected channel registry lookups 2026-05-11 13:58:14 +01:00
Shakker
7c75001492 test: pin cron diagnostics entries 2026-05-11 13:58:01 +01:00
Peter Steinberger
9c5a150336 test: tighten UI view assertions 2026-05-11 13:57:15 +01:00
Shakker
a012bfb296 test: pin cron timer handles 2026-05-11 13:55:45 +01:00
Peter Steinberger
ef9c03c4bb test: tighten UI gateway assertions 2026-05-11 13:54:54 +01:00
Shakker
82cc6f1d25 test: pin cron schedule logs 2026-05-11 13:54:38 +01:00
Shakker
0fcddd3974 test: pin cron reaper store 2026-05-11 13:53:01 +01:00
Shakker
e3cde42b49 test: pin attachment offload warning 2026-05-11 13:52:04 +01:00
Peter Steinberger
552f088af9 test: tighten gateway live assertions 2026-05-11 13:51:37 +01:00
Shakker
f801009008 test: pin runtime recovery logs 2026-05-11 13:50:39 +01:00
Peter Steinberger
318794f808 test: tighten gateway helper assertions 2026-05-11 13:49:35 +01:00
Shakker
c165b9c650 test: pin agent identity writes 2026-05-11 13:49:23 +01:00
Shakker
bcdec7bfb9 test: pin plugin approval ids 2026-05-11 13:47:51 +01:00
Peter Steinberger
cca6c4cfcf test: tighten gateway send assertions 2026-05-11 13:45:24 +01:00
Shakker
17b4ab369e test: pin tools catalog plugin fields 2026-05-11 13:45:00 +01:00
Peter Steinberger
296a0feddc test: tighten gateway rate limit assertions 2026-05-11 13:43:34 +01:00
Peter Steinberger
26b32601f0 test: tighten tools catalog assertions 2026-05-11 13:41:40 +01:00
Shakker
29f85ca246 test: pin gateway client logs 2026-05-11 13:41:18 +01:00
Val Alexander
96b672c54d Stabilize Control UI connection diagnostics (#80510)
Summary:
- Catch browser-side WebSocket constructor security failures and surface wss://, Tailscale, and loopback dashboard guidance.
- Classify the browser WebSocket security code through Control UI login and overview insecure-context hints.
- Keep the changelog attribution under the active Fixes section.


Verification:
- pnpm test ui/src/ui/gateway.node.test.ts ui/src/ui/views/login-gate.test.ts ui/src/ui/views/overview.node.test.ts src/logging/diagnostic.test.ts
- pnpm exec oxfmt --check --threads=1 CHANGELOG.md src/logging/diagnostic-stability.ts src/logging/diagnostic.test.ts ui/src/ui/gateway.ts ui/src/ui/gateway.node.test.ts ui/src/ui/views/login-gate.test.ts ui/src/ui/views/overview-hints.ts ui/src/ui/views/overview.node.test.ts
- git diff --check origin/main...HEAD
- pnpm check:changed
- GitHub Real behavior proof and CI preflight passed on 1ea05289b1
2026-05-11 07:40:47 -05:00
Peter Steinberger
39348e9a93 test: tighten skill gateway assertions 2026-05-11 13:39:41 +01:00
Shakker
1517c36dbd test: pin reload deferral warnings 2026-05-11 13:38:53 +01:00
Shakker
b41d766394 test: pin skill update config writes 2026-05-11 13:37:28 +01:00
Peter Steinberger
6fb630aec1 test: avoid mutating diagnostics snapshot keys 2026-05-11 13:36:51 +01:00
Peter Steinberger
7c6c2fa994 test: tighten gateway server response assertions 2026-05-11 13:36:51 +01:00
Shakker
6963fd1492 test: pin session reset hook strings 2026-05-11 13:36:00 +01:00
Ayaan Zaidi
6887b12be7 docs(changelog): add Telegram thinking status entry (#80341) (thanks @VACInc) 2026-05-11 18:04:53 +05:30
Ayaan Zaidi
377d7a0b4c fix(telegram): simplify thinking defaults 2026-05-11 18:04:53 +05:30
VACInc
9a47f0fd3d fix: preserve native status thinking precedence 2026-05-11 18:04:53 +05:30
VACInc
d468741c5b test: fix native status alias index mock 2026-05-11 18:04:53 +05:30
VACInc
8192147b90 fix: respect native status thinking overrides 2026-05-11 18:04:53 +05:30
VACInc
6562bac624 fix: show Telegram thinking defaults 2026-05-11 18:04:53 +05:30
Shakker
ee77ce467a test: cover diagnostics snapshots 2026-05-11 13:33:48 +01:00
Peter Steinberger
653483d9c8 test: tighten gateway server method assertions 2026-05-11 13:32:24 +01:00
Shakker
4b51e86914 test: pin chat abort payloads 2026-05-11 13:31:28 +01:00
Shakker
06f39a97f1 test: pin session archive filenames 2026-05-11 13:29:53 +01:00
Peter Steinberger
da7cc2b11c fix(feishu): make manual setup the default 2026-05-11 13:29:13 +01:00
Peter Steinberger
2838eb4d8e test: tighten node pairing authz assertions 2026-05-11 13:28:24 +01:00
Peter Steinberger
4c070299c8 test: tighten telegram session recreation assertions 2026-05-11 13:27:09 +01:00
Shakker
eabb129bcf test: pin subagent hook session keys 2026-05-11 13:26:17 +01:00
Peter Steinberger
951444cb83 test: tighten gateway preauth assertions 2026-05-11 13:25:47 +01:00
Shakker
c2346d1042 test: pin conversation label calls 2026-05-11 13:24:55 +01:00
Peter Steinberger
344f42a52a test: tighten gateway helper call assertions 2026-05-11 13:24:11 +01:00
Shakker
f60a12ccca test: pin fast reply bootstrap checks 2026-05-11 13:23:34 +01:00
Peter Steinberger
fb11851c7f docs: refresh config baseline 2026-05-11 13:21:47 +01:00
Peter Steinberger
0362b75824 feat(discord): add voice channel allowlist 2026-05-11 13:21:47 +01:00
Peter Steinberger
696a98871d test: tighten gateway call assertions 2026-05-11 13:21:32 +01:00
Shakker
0d8d350d16 test: pin gateway doctor notes 2026-05-11 13:20:48 +01:00
Ayaan Zaidi
663206aac4 ci(mantis): derive telegram proof refs from pr 2026-05-11 17:50:23 +05:30
Peter Steinberger
bf5202b056 test: tighten hook mapping assertions 2026-05-11 13:19:44 +01:00
Shakker
b48baece87 test: assert onboard option errors 2026-05-11 13:19:12 +01:00
Peter Steinberger
9c810b552b docs: add gateway streaming envelope changelog (#80299) 2026-05-11 13:19:00 +01:00
samzong
3880b72294 fix(gateway): share streaming event envelopes
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 13:19:00 +01:00
Peter Steinberger
e50f323c1f test(exec): isolate OpenClaw home in security floor tests 2026-05-11 13:18:50 +01:00
Peter Steinberger
1cbe6e271b fix(exec): address security floor review 2026-05-11 13:18:50 +01:00
Bryan Pearson
235ad7ec95 fix(exec): keep configured security authoritative 2026-05-11 13:18:50 +01:00
Peter Steinberger
6fcceed61f test: tighten chat attachment assertions 2026-05-11 13:18:13 +01:00
Shakker
2d5701237b test: assert agents add outputs 2026-05-11 13:17:57 +01:00
Peter Steinberger
323ba824ed test: tighten control ui http assertions 2026-05-11 13:16:58 +01:00
Peter Steinberger
29f36e0072 fix: avoid llama.cpp router autoload during discovery (#74057) 2026-05-11 13:16:06 +01:00
brokemac79
f4be39c4f4 fix(providers): read nested llama cpp props context 2026-05-11 13:16:06 +01:00
brokemac79
7c7d19ec84 fix(providers): use llama.cpp runtime context cap 2026-05-11 13:16:06 +01:00
brokemac79
ccdaf1875a fix(doctor): tolerate malformed crontab output (#78112)
Fixes #77773.

Co-authored-by: brokemac79 <martin_cleary@yahoo.co.uk>
2026-05-11 13:15:57 +01:00
Peter Steinberger
a57691cdcb test: tighten gateway websocket assertions 2026-05-11 13:15:45 +01:00
Shakker
75b745d559 test: assert scheduled task command parsing 2026-05-11 13:14:29 +01:00
Peter Steinberger
db9549c46f test: tighten gateway role assertions 2026-05-11 13:13:30 +01:00
Shakker
9c37951435 test: assert service audit issues 2026-05-11 13:13:14 +01:00
Peter Steinberger
c4ed66c58b test: tighten gateway misc assertions 2026-05-11 13:12:01 +01:00
Shakker
0c50714a03 test: assert approval bootstrap retry warning 2026-05-11 13:11:45 +01:00
Shakker
945fcc10fd test: assert runtime guard diagnostics 2026-05-11 13:10:53 +01:00
Peter Steinberger
d932d89778 test: tighten session store rpc assertions 2026-05-11 13:10:18 +01:00
Shakker
fbaac02823 test: assert windows task restart spawn 2026-05-11 13:09:59 +01:00
Val Alexander
342ae551ae fix(logging): reduce active-only liveness noise
Summary:
- Reduce active-only diagnostic liveness noise by emitting transient event-loop max delay samples as info-level telemetry.
- Keep warnings for queued or waiting work and for sustained high P99 loop delay.
- Cover the active-only path in the diagnostic stability tests and changelog.

Verification:
- pnpm format:check src/logging/diagnostic-stability.ts src/logging/diagnostic.test.ts CHANGELOG.md
- pnpm test src/logging/diagnostic.test.ts
- pnpm check:changed
- GitHub PR checks passed on head 25e674fe41.
2026-05-11 07:09:12 -05:00
Peter Steinberger
35827b7dbb test: tighten gateway discovery assertions 2026-05-11 13:09:06 +01:00
Shakker
f7d68cf435 test: assert channel allowlist warnings 2026-05-11 13:08:43 +01:00
Peter Steinberger
4bfdb6ef30 test: tighten gateway health assertions 2026-05-11 13:07:15 +01:00
Peter Steinberger
2dcc05a9eb docs: add Fly container detection changelog (#80209) 2026-05-11 13:06:49 +01:00
Lior Balmas
b94919ab1b test(gateway): isolate Fly env container checks 2026-05-11 13:06:49 +01:00
Lior Balmas
0f8fc6bb61 fix(runtime): detect Fly Machines as containers 2026-05-11 13:06:49 +01:00
Shakker
9bb7f220c9 test: assert daemon config guard json 2026-05-11 13:06:23 +01:00
Peter Steinberger
1f49d34c5f fix(gateway): preserve batched client tool calls 2026-05-11 13:06:05 +01:00
Lellansin
0e6aca34db fix(gateway): align OpenAI chat completions tool protocol
fix(gateway): remove unnecessary type assertion in buildAgentPrompt

fix(gateway): reject unsupported forced tool_choice modes

tool_choice=required and named function tool_choice are now rejected
with invalid_request_error until hard enforcement is implemented
at the agent runtime layer. Only auto and none remain supported.

docs: update Chat Completions tool_choice contract to match rejection behavior

Only auto and none are currently accepted; required and named
function tool_choice are rejected until hard enforcement exists.
2026-05-11 13:06:05 +01:00
Peter Steinberger
efbc550dc9 test: tighten gateway helper assertions 2026-05-11 13:05:47 +01:00
Peter Steinberger
26ac5a3596 test: tighten assistant identity assertions 2026-05-11 13:04:24 +01:00
Ayaan Zaidi
d4c7519989 ci(mantis): allow fork telegram proof 2026-05-11 17:33:29 +05:30
Peter Steinberger
e6b0b37e3f test: tighten websocket log assertions 2026-05-11 13:02:51 +01:00
Shakker
1d5785ba85 test: assert gateway restart handoffs 2026-05-11 13:02:47 +01:00
Peter Steinberger
e0679d0d0c docs: add changelog for sessions resolve scope (#79474) (thanks @samzong) 2026-05-11 13:02:42 +01:00
samzong
c1b29bf5db fix(gateway): scope session resolve store loads 2026-05-11 13:02:42 +01:00
samzong
3e87e55604 fix(ui): preserve empty plugin allowlists
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 13:02:34 +01:00
samzong
adafd4f5be docs(changelog): note plugin allowlist revert fix
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 13:02:34 +01:00
samzong
8e92b069d2 fix(ui): remove reverted plugin allow entries
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 13:02:34 +01:00
Peter Steinberger
776c39b00c test: tighten gateway readiness assertions 2026-05-11 13:01:23 +01:00
Shakker
8f1e6ab13c test: assert config write warnings 2026-05-11 13:00:44 +01:00
Peter Steinberger
e8dc492cb0 test: tighten gateway runtime assertions 2026-05-11 12:59:51 +01:00
Peter Steinberger
8d6bef0de1 test: tighten session create assertions 2026-05-11 12:58:08 +01:00
Shakker
a62b8c77a4 test: assert followup collect prompts 2026-05-11 12:57:48 +01:00
Peter Steinberger
96c2502bfb test: tighten gateway startup assertions 2026-05-11 12:56:28 +01:00
Shakker
51ad59ea0c test: assert acp ledger replay order 2026-05-11 12:55:19 +01:00
Peter Steinberger
a199ddf995 test: tighten gateway response assertions 2026-05-11 12:54:28 +01:00
Shakker
85d5718236 test: assert cli startup routing 2026-05-11 12:52:39 +01:00
Peter Steinberger
3c1d8bbc09 test: tighten shared auth rotation assertions 2026-05-11 12:51:41 +01:00
Peter Steinberger
ee9522ef8d fix: keep browser status page probe within timeout 2026-05-11 12:51:07 +01:00
ai-hpc
b4a420185c fix(browser): add pageReady to Chrome MCP existing-session status
Closes #80268

For Chrome MCP existing-session profiles, browser status previously
exposed only transport-handshake fields (cdpHttp, cdpReady) sourced
from isTransportAvailable(...). It did not surface whether a
page-level tool round-trip (list_pages, etc.) actually succeeds, so
operators and downstream tooling had no honest signal to distinguish
"transport handshake passed" from "page tools are usable".

This adds a pageReady field to BrowserStatus, derived from
profileCtx.isReachable(...) for chrome-mcp profiles (with a status-
bound 5s timeout) and mirroring cdpReady for managed CDP profiles
where the WS handshake already covers page-level reachability.

The status route opts the page probe into ephemeral mode so a passive
status call does not seed a persistent cached Chrome MCP session as a
side effect. listChromeMcpTabs reuses an existing cached attach
session if one already exists, otherwise opens a temporary session
that is closed immediately after the round-trip. The cached-session
path used by /tabs and other interactive routes is unchanged.

isReachable now threads the new ephemeral option (alongside timeoutMs)
into listChromeMcpTabs; existing callers in tabs.ts pass only
timeoutMs and continue to use the cached path.

The page probe is skipped when transport itself is down so status
latency does not regress on offline profiles.

Test changes:
- basic.existing-session.test.ts: the prior assertion that running:
  true and cdpReady: true with isReachable: false is now flipped to
  assert pageReady: false in that state, matching the new contract.
- New tests cover: probe-throws (treated as page-down), both-succeed
  (pageReady: true), transport-down (probe skipped, pageReady: false),
  and an ephemeral-mode regression that asserts the status probe
  passes { ephemeral: true } so it cannot seed a cached session.
2026-05-11 12:51:07 +01:00
Shakker
1eb42c68d9 test: assert completion cache writes 2026-05-11 12:50:46 +01:00
Peter Steinberger
7a6dbffa05 test: tighten gateway auth path assertions 2026-05-11 12:49:55 +01:00
Peter Steinberger
a85c7936e9 test: tighten node pending work assertions 2026-05-11 12:48:31 +01:00
Shakker
c7016bf988 test: assert update cli errors 2026-05-11 12:47:36 +01:00
Peter Steinberger
5f0449d3f3 test: tighten client bootstrap assertions 2026-05-11 12:47:25 +01:00
Peter Steinberger
913c621adb ci: add plugin inspector prerelease advisory 2026-05-11 12:46:33 +01:00
Shakker
cffe71e2ba test: assert legacy sender warnings 2026-05-11 12:46:02 +01:00
Peter Steinberger
d26bc48ae7 test: tighten models http assertions 2026-05-11 12:45:55 +01:00
Peter Steinberger
5da239473c fix(sessions): stream transcript reverse scans 2026-05-11 12:44:59 +01:00
jack-stormentswe
9654239af9 fix(sessions): stream JSONL transcript scans instead of buffering whole files (#54296)
The remaining whole-file transcript scans flagged by ClawSweeper triage on
splitting on newlines. On long-running sessions where transcripts grow into
the multi-MB / 100s-of-MB range that scales peak RSS with file size and is
the practical OOM risk in the report.

Add a shared streaming helper module `src/config/sessions/transcript-stream.ts`
exposing:

- `streamSessionTranscriptLines(filePath, { signal? })`: forward async-iterator
  over trimmed non-empty lines using `fs.createReadStream` + `readline` with
  `crlfDelay: Infinity`. Bounded to one line of memory at a time and honours
  an abort signal between lines.
- `readSessionTranscriptTailLines(filePath, { maxBytes? })`: tail-only read of
  the last `maxBytes` of a file (default 4 MiB, clamped to [1 KiB, 64 MiB]),
  returning trimmed non-empty lines in reverse order. Drops the leading line
  of the slice when the window does not start at byte zero so callers never
  see a partial-line suffix.

Migrate every flagged whole-file scan to these helpers while preserving the
malformed-line tolerance and idempotency-key return semantics callers depend
on (see `Remaining risk / open question` on the issue):

- `src/config/sessions/transcript.ts`: `readLatestAssistantTextFromSessionTranscript`,
  `readTailAssistantTextFromSessionTranscript`, and the delivery-mirror dedupe
  helper `findLatestEquivalentAssistantMessageId` now use the tail helper;
  `transcriptHasIdempotencyKey` uses the forward stream helper.
- `src/gateway/server-methods/chat.ts`: the inline `transcriptHasIdempotencyKey`
  used by chat-method append idempotency now uses the forward stream helper
  and tolerates malformed lines mid-scan (matching the sibling helper in
  `config/sessions/transcript.ts`).
- `src/gateway/session-compaction-checkpoints.ts`: `readTranscriptEntriesForForkAsync`
  builds the fork entry array from the forward stream helper instead of one
  big `fileHandle.readFile("utf-8")` call.

Fixes #54296.
2026-05-11 12:44:59 +01:00
Shakker
69c2bc58fa test: assert cron model diagnostics 2026-05-11 12:44:21 +01:00
Kaspre
775a24e57c fix(doctor): warn when per-agent model omits fallbacks key and defaults chain is non-empty (#79826)
* fix(doctor): warn when per-agent model omits fallbacks key and defaults chain is non-empty

`resolveAgentModelFallbacksOverride` in `src/agents/agent-scope.ts` returns
`[]` (no fallbacks) when a per-agent model is configured without an explicit
`fallbacks` key. At runtime this silently clobbers
`agents.defaults.model.fallbacks`, leaving the agent with no fallbacks.

Two config patterns hit this:

1. String form: `"model": "openai/gpt-5.5"` — user likely means "use this model,
   inherit fallbacks from defaults".
2. Object without `fallbacks` key: `"model": { "primary": "openai/gpt-5.5" }` —
   user likely means "just set the primary, keep defaults fallbacks".

The only explicit "no fallbacks" signal is `fallbacks: []`. This change adds
`collectImplicitFallbackClobberWarnings` / `noteImplicitFallbackClobberWarnings`
to the doctor config-analysis flow, which warns on either ambiguous shape only
when `agents.defaults.model.fallbacks` is non-empty (so there is something to
clobber).

No semantic change to how fallbacks resolve; this is a doctor-only diagnostic.

Closes #79369. Extends the scope of closed PR #79389 (string-form only) to
also cover the object-without-fallbacks case.

* fix(doctor): mirror runtime model primary normalization

* fix(doctor): strengthen fallback warning proof

* fix(doctor): tolerate malformed agent lists

* fix(doctor): type guarded agent runtime policy

* fix(ui): sync quick settings i18n baseline

---------

Co-authored-by: Peter Steinberger <steipete@gmail.com>
2026-05-11 12:43:51 +01:00
Peter Steinberger
9c736af39d test: tighten session cost usage assertions 2026-05-11 12:43:05 +01:00
Shakker
2d73d59905 test: assert cron store loads 2026-05-11 12:41:55 +01:00
pashpashpash
2846d9ea56 test: type acp cli option mock assertions 2026-05-11 12:41:21 +01:00
Peter Steinberger
6ee0c9a696 fix(codex): honor codex fallback blocking 2026-05-11 12:41:21 +01:00
Peter Steinberger
3f05165c47 fix(codex): preserve codex auth order 2026-05-11 12:41:21 +01:00
pashpashpash
30ed0329cb fix(codex): avoid mutating rate limit candidates 2026-05-11 12:41:21 +01:00
Peter Steinberger
10c43aefd8 fix(codex): ignore blocked account fallback state 2026-05-11 12:41:21 +01:00
Peter Steinberger
554d80c060 fix(codex): scope auth state updates 2026-05-11 12:41:21 +01:00
pashpashpash
edd7e3c70c test: fix current extension test assertions 2026-05-11 12:41:21 +01:00
Peter Steinberger
b2b381ac4d fix(codex): prefer live account credential state 2026-05-11 12:41:21 +01:00
pashpashpash
e9f8387a63 docs: align slash command btw contract 2026-05-11 12:41:21 +01:00
Peter Steinberger
dbe568556e fix(codex): avoid app-server request cross-talk 2026-05-11 12:41:21 +01:00
Peter Steinberger
95cee42b5b fix(codex): prefer direct codex auth order 2026-05-11 12:41:21 +01:00
Peter Steinberger
8185eb40e8 fix(codex): complete side thread request parity 2026-05-11 12:41:21 +01:00
pashpashpash
3e5544cc76 test(zalouser): type mock Zalo constructor result 2026-05-11 12:41:21 +01:00
pashpashpash
ddc9581d00 fix(codex): preserve side thread tools 2026-05-11 12:41:21 +01:00
pashpashpash
e15f99e34e fix(codex): show api key profile handles 2026-05-11 12:41:21 +01:00
pashpashpash
ac618c6d9d fix(codex): preserve account ladder indentation 2026-05-11 12:41:21 +01:00
pashpashpash
7f5a10e0e4 fix(codex): clarify account auth ladder 2026-05-11 12:41:21 +01:00
pashpashpash
004854e76e fix(codex): preserve blank account separators 2026-05-11 12:41:21 +01:00
pashpashpash
1877c600ea fix(codex): infer api key account fallback 2026-05-11 12:41:21 +01:00
pashpashpash
e310824828 fix(codex): explain account auth fallback 2026-05-11 12:41:21 +01:00
pashpashpash
3ae2799e28 fix(codex): preserve auth candidates for auto profiles 2026-05-11 12:41:21 +01:00
pashpashpash
cc95d4dd28 fix(codex): rotate auth profiles inside harness 2026-05-11 12:41:21 +01:00
pashpashpash
f447e5b9db fix(btw): keep Codex side questions tool-free 2026-05-11 12:41:21 +01:00
pashpashpash
517566e39a fix(auth): accept friendly OpenAI order for Codex profiles 2026-05-11 12:41:21 +01:00
pashpashpash
a947e8fae0 fix(codex): align btw side thread semantics 2026-05-11 12:41:21 +01:00
pashpashpash
42e259a696 fix(codex): route btw through native side threads 2026-05-11 12:41:21 +01:00
Peter Steinberger
4aa13b5338 test: tighten outbound target assertions 2026-05-11 12:40:55 +01:00
Shakker
1c452ddabf test: assert aux reload failures 2026-05-11 12:40:15 +01:00
Shakker
996a38466f test: assert session usage errors 2026-05-11 12:38:28 +01:00
Peter Steinberger
f57bcb0788 test: tighten outbound route assertions 2026-05-11 12:37:21 +01:00
Shakker
5569973d90 test: assert restart sentinel warnings 2026-05-11 12:36:53 +01:00
Shakker
34186196df test: assert gateway startup logs 2026-05-11 12:35:03 +01:00
Peter Steinberger
691b760df3 test: tighten outbound action runner assertions 2026-05-11 12:34:58 +01:00
Peter Steinberger
1a7efcad4b docs: add memory symlink traversal changelog (#80331) (thanks @samzong) 2026-05-11 12:34:01 +01:00
samzong
5ad3fa0a17 fix(memory): preserve ENOTDIR missing reads
Signed-off-by: samzong <samzong.lu@gmail.com>
2026-05-11 12:34:01 +01:00
samzong
c6748a8eeb fix(memory): block extra path symlink traversal
## Considered and deferred

- packages/memory-host-sdk/src/host/read-file.ts:77 [BOT-SCOPE]: Fully race-proof parent traversal would need a lower-level pinned/openat-style primitive; this diff fixes static symlink traversal and rejects symlink components before read.
2026-05-11 12:34:01 +01:00
Shakker
d21c47d711 test: assert plugin route runtime scopes 2026-05-11 12:33:04 +01:00
Peter Steinberger
2f1a9faae8 test: tighten outbound storage assertions 2026-05-11 12:31:18 +01:00
Peter Steinberger
3756e5dc10 test: tighten infra edge-case assertions 2026-05-11 12:29:37 +01:00
Shakker
7d966238b3 test: assert whatsapp inbox payloads 2026-05-11 12:27:44 +01:00
Peter Steinberger
7aa8f69808 test: tighten approval runtime assertions 2026-05-11 12:27:02 +01:00
Peter Steinberger
e520d9b8f6 test: tighten proxy dispatcher assertions 2026-05-11 12:25:27 +01:00
Shakker
06292d83a5 test: assert get-reply fixture config 2026-05-11 12:24:05 +01:00
Peter Steinberger
b9c5290a45 test: tighten infra warning and restart assertions 2026-05-11 12:21:46 +01:00
Shakker
a29b2b4026 test: assert session compaction payloads 2026-05-11 12:21:39 +01:00
Peter Steinberger
9c9b719cc9 test: tighten ssrf dispatcher assertions 2026-05-11 12:18:55 +01:00
Peter Steinberger
8e7ee67f67 test: tighten ssrf pinning assertions 2026-05-11 12:17:53 +01:00
Shakker
40457455e1 test: assert tts contract attempts 2026-05-11 12:17:30 +01:00
Peter Steinberger
26a0de82df test: tighten runtime fetch formdata assertions 2026-05-11 12:16:32 +01:00
Peter Steinberger
c2a13e292f test: tighten heartbeat runner assertions 2026-05-11 12:15:17 +01:00
Peter Steinberger
0f03af8643 test: tighten infra fetch summary assertions 2026-05-11 12:13:28 +01:00
Kaspre
7eefb26bc8 fix(heartbeat): remap cron-run exec events to session keys (#80214)
Summary:
- Remap cron-run async exec, ACP, node-event, and watchdog completion events to the queue heartbeat drains.
- Route per-sender cron-run events to the agent main queue and global-scope events to `global` while preserving the originating `agentId`.
- Tighten exec-completion classification and treat cron-run descendants as ephemeral for retention pruning.

Verification:
- CI: https://github.com/openclaw/openclaw/actions/runs/25625964382 passed.
- Real behavior proof: https://github.com/openclaw/openclaw/actions/runs/25666664248/job/75340798016 passed.
- PR targeted validation: `node scripts/run-vitest.mjs run --config test/vitest/vitest.unit.config.ts src/routing/session-key.test.ts src/infra/heartbeat-events-filter.test.ts src/agents/bash-tools.exec-runtime.test.ts src/agents/acp-spawn-parent-stream.test.ts src/cron/session-reaper.test.ts`.
- PR targeted typecheck: `pnpm tsgo:core`.

Refs #52305.
Related: #18237, #14191.

Co-authored-by: Kaspre <kaspre@gmail.com>
2026-05-11 12:13:17 +01:00
Shakker
ccc6109853 test: assert plugin update warnings 2026-05-11 12:13:14 +01:00
Peter Steinberger
2cd08508ea test: tighten infra helper assertions 2026-05-11 12:11:36 +01:00
Peter Steinberger
c1e4b4d2a9 test: tighten device auth token assertions 2026-05-11 12:10:27 +01:00
Peter Steinberger
c53d7aee0f test: tighten agent event context assertions 2026-05-11 12:08:25 +01:00
Shakker
a6f80874b3 test: assert acp cli option payloads 2026-05-11 12:07:57 +01:00
Peter Steinberger
1e9ddc33a3 test: tighten device identity storage assertions 2026-05-11 12:07:06 +01:00
Peter Steinberger
605fb9731d test: tighten channel runtime context assertions 2026-05-11 12:06:05 +01:00
Peter Steinberger
01d9d1be83 test: tighten apns auth assertions 2026-05-11 12:03:43 +01:00
Peter Steinberger
58ca32a79a test: tighten safe npm install env assertions 2026-05-11 12:02:39 +01:00
Shakker
499d789f97 test: assert config compat warnings 2026-05-11 12:02:01 +01:00
Peter Steinberger
950be50c0d test: tighten session maintenance warning assertions 2026-05-11 12:00:57 +01:00
Peter Steinberger
ffba41fe6b fix(codex): ignore echoed abort marker prompts 2026-05-11 11:59:56 +01:00
Peter Steinberger
be0e85a72d fix(codex): accept abort markers without request responses 2026-05-11 11:59:56 +01:00
Peter Steinberger
b273b81e5b fix(codex): narrow app-server abort marker fallback 2026-05-11 11:59:56 +01:00
Peter Steinberger
4ff28a7735 fix(codex): release interrupted app-server turns 2026-05-11 11:59:56 +01:00
Shakker
6207ba7010 test: assert session maintenance warnings 2026-05-11 11:59:11 +01:00
Peter Steinberger
42f277dc60 test: tighten gateway tls runtime assertions 2026-05-11 11:58:36 +01:00
Peter Steinberger
1b6143b7f9 fix: hide sandbox marker in command previews 2026-05-11 11:58:29 +01:00
Shakker
fd21722cdf test: assert port conflict hints 2026-05-11 11:57:19 +01:00
Shakker
51be8f4647 test: assert temp dir repair warnings 2026-05-11 11:56:15 +01:00
Peter Steinberger
cb0f983544 test: tighten windows task restart assertions 2026-05-11 11:55:43 +01:00
Peter Steinberger
1a61e28117 test: tighten inbound reply dispatch assertions 2026-05-11 11:54:11 +01:00
Shakker
f2d9d76996 test: assert channel ingress access fields 2026-05-11 11:52:06 +01:00
Peter Steinberger
4e67506f71 test: tighten qa runner runtime assertions 2026-05-11 11:51:19 +01:00
Shakker
5e318ce3cd test: assert channel config DM policies 2026-05-11 11:50:40 +01:00
Shakker
3f30ec4602 test: assert acp dispatch payloads 2026-05-11 11:48:11 +01:00
Peter Steinberger
1ff126c682 test: tighten plugin tool payload assertions 2026-05-11 11:46:51 +01:00
Shakker
ca73c8da43 test: assert tool payload parse blocks 2026-05-11 11:44:55 +01:00
Shakker
5b66d7f865 test: assert anthropic vertex stream options 2026-05-11 11:43:11 +01:00
Shakker
af322da872 test: assert anthropic vertex catalog 2026-05-11 11:42:25 +01:00
Peter Steinberger
3f5f038cc9 test: tighten active tab refresh assertions 2026-05-11 11:42:19 +01:00
Shakker
6c4ffec1be test: assert browser plugin registration 2026-05-11 11:41:18 +01:00
Peter Steinberger
526d5390c6 test: tighten exec approval parser assertions 2026-05-11 11:41:01 +01:00
Peter Steinberger
c71bc216cf test: tighten sessions controller assertions 2026-05-11 11:39:55 +01:00
Shakker
63649bbbff test: assert matrix monitor payloads 2026-05-11 11:39:46 +01:00
Peter Steinberger
71192383e7 test: tighten webrtc realtime talk assertions 2026-05-11 11:38:27 +01:00
Shakker
21e0f60890 test: assert matrix startup directory calls 2026-05-11 11:38:04 +01:00
Peter Steinberger
3021d36f84 test: tighten acpx runtime lease assertions 2026-05-11 11:36:55 +01:00
Shakker
0f83118dfd test: assert matrix registration calls 2026-05-11 11:36:31 +01:00
Peter Steinberger
accba2c4e2 test: tighten anthropic vertex stream assertions 2026-05-11 11:35:32 +01:00
Shakker
bc338a4019 test: assert matrix config storage calls 2026-05-11 11:35:27 +01:00
Peter Steinberger
8ac299ee49 test: tighten browser cdp screenshot assertions 2026-05-11 11:34:16 +01:00
Harris Ali
39cbe94f07 fix(msteams): normalize pre-suffixed thread session keys (#78850)
Normalize pre-thread-qualified Teams route session keys before deriving channel-thread lanes so cached route reuse cannot create malformed mixed thread sessions.

Co-authored-by: Harris Ali <harrisali@getfieldforce.com>
2026-05-11 05:34:14 -05:00
Shakker
5a4201fd86 test: assert matrix client error shapes 2026-05-11 11:33:23 +01:00
Peter Steinberger
5b293150c3 test: tighten browser doctor assertions 2026-05-11 11:32:59 +01:00
Andy
6d26609f7b fix(windows): prevent restart race from duplicate schtasks /Run (#52487)
Prevent duplicate scheduled-task /Run attempts during Windows gateway restart by checking the task state before retrying.

Co-authored-by: Andy K <andyk-ms@users.noreply.github.com>
2026-05-11 05:32:48 -05:00
Peter Steinberger
37fa027772 test: tighten codex protocol validator assertions 2026-05-11 11:31:04 +01:00
Shakker
8de5a3e2b8 test: assert matrix profile action calls 2026-05-11 11:30:41 +01:00
Shakker
8a13d09b3a test: assert matrix recovery key result 2026-05-11 11:29:41 +01:00
Peter Steinberger
c60950856d test: tighten codex conversation binding assertions 2026-05-11 11:29:16 +01:00
Shakker
432e19527e test: assert matrix raw event serialization 2026-05-11 11:28:35 +01:00
Shakker
b00e84e6be test: assert matrix poll parsing 2026-05-11 11:27:50 +01:00
Peter Steinberger
3ed9b23834 test: tighten memory import insight assertions 2026-05-11 11:27:02 +01:00
Shakker
83748bc8bb test: assert matrix client options 2026-05-11 11:26:41 +01:00
Shakker
4c63dd9f95 test: assert matrix room config results 2026-05-11 11:26:02 +01:00
Peter Steinberger
c59cb73584 test: tighten memory palace assertions 2026-05-11 11:25:14 +01:00
Shakker
5a77d791dd test: assert matrix event summaries 2026-05-11 11:24:25 +01:00
Shakker
deaed7a2bd test: assert matrix device health summary 2026-05-11 11:23:50 +01:00
Peter Steinberger
75daa12562 test: tighten openai device code assertions 2026-05-11 11:23:25 +01:00
Shakker
81281609b8 test: assert matrix direct room mappings 2026-05-11 11:22:23 +01:00
Shakker
d17a347f8c test: assert matrix tool action details 2026-05-11 11:20:51 +01:00
Peter Steinberger
3a5155bfff test: tighten qa live gateway assertions 2026-05-11 11:19:54 +01:00
Shakker
ab12985d71 test: assert matrix action schema fields 2026-05-11 11:19:03 +01:00
Shakker
225cbb7b21 test: assert matrix sync store payloads 2026-05-11 11:18:10 +01:00
Peter Steinberger
75f6bd212c test: tighten whatsapp live runtime assertions 2026-05-11 11:17:52 +01:00
Peter Steinberger
22e2ee3103 docs: clarify fixed issue closeout 2026-05-11 11:17:23 +01:00
Shakker
d29865f4b6 test: assert matrix resolver runtime forwarding 2026-05-11 11:16:41 +01:00
Peter Steinberger
c7fd9fcbb7 test: tighten mantis telegram builder assertions 2026-05-11 11:16:22 +01:00
Shakker
68fdb8007d test: assert matrix message adapter calls 2026-05-11 11:14:49 +01:00
Peter Steinberger
36e457aa72 test: tighten extension test call typing 2026-05-11 11:14:16 +01:00
Shakker
3e31b0946f test: assert matrix runtime exports 2026-05-11 11:14:02 +01:00
Peter Steinberger
cb088c8160 fix(ui): preserve draft on chat stop 2026-05-11 11:13:23 +01:00
Shakker
3e2cd6676a test: assert matrix device action results 2026-05-11 11:13:16 +01:00
Peter Steinberger
cd52ea1108 test: tighten slack draft stream assertions 2026-05-11 11:11:51 +01:00
Shakker
324289eebf test: assert msteams attachment warning 2026-05-11 11:11:42 +01:00
Shakker
3a040d3562 test: assert msteams consent upload request 2026-05-11 11:11:00 +01:00
Shakker
432ffec88d test: assert msteams inbound media diagnostics 2026-05-11 11:10:25 +01:00
Peter Steinberger
e376aa4ee1 docs: clarify model override fallback routes 2026-05-11 11:09:47 +01:00
Shakker
202f65c40b test: assert msteams message adapter calls 2026-05-11 11:09:30 +01:00
Peter Steinberger
37f1f5d4ab test: tighten slack progress block assertions 2026-05-11 11:09:03 +01:00
Peter Steinberger
f9016145c8 test: tighten slack security audit assertions 2026-05-11 11:07:46 +01:00
Shakker
fcb631e1d3 test: assert msteams owner role graph request 2026-05-11 11:07:23 +01:00
Peter Steinberger
4d4512c144 test: tighten telegram media download assertions 2026-05-11 11:06:33 +01:00
Shakker
ae3be984a5 test: assert msteams adaptive card dispatch payload 2026-05-11 11:06:17 +01:00
Jeff J Hunter
3247b091d6 Add browser and tool profile quick settings (#80609)
Summary:
- The PR adds Browser enabled and Tool profile controls to Control UI Quick Settings, stacks the tool profile row for narrow cards, and adds focused UI tests plus a screenshot asset.
- Reproducibility: not applicable. This PR adds a Control UI quick-settings capability rather than fixing a reported reproducible bug. Source inspection and the supplied screenshot/log proof cover the changed behavior.

Automerge notes:
- No ClawSweeper repair was needed after automerge opt-in.

Validation:
- ClawSweeper review passed for head 06adff19fd.
- Required merge gates passed before the squash merge.

Prepared head SHA: 06adff19fd
Review: https://github.com/openclaw/openclaw/pull/80609#issuecomment-4419255136

Co-authored-by: Jeff J Hunter <support@aipersonamethod.com>
2026-05-11 10:06:00 +00:00
Shakker
e2d51cacfe test: assert msteams delivery failure event 2026-05-11 11:04:50 +01:00
Peter Steinberger
3b1ad58241 test: tighten telegram gateway assertions 2026-05-11 11:03:44 +01:00
Shakker
b73c1dc58f test: assert google meet bridge session fields 2026-05-11 11:03:29 +01:00
Peter Steinberger
1327f6742f ci: keep ClawSweeper comment dispatch best effort 2026-05-11 11:02:00 +01:00
Shakker
e31af364ab test: assert browser existing-session profile shape 2026-05-11 11:01:09 +01:00
Shakker
9bccba3544 test: assert browser dispatcher error responses 2026-05-11 10:59:51 +01:00
Shakker
62ace89c23 test: tighten browser permission assertions 2026-05-11 10:58:37 +01:00
Shakker
9b72e7cfa6 test: tighten browser control state assertion 2026-05-11 10:57:40 +01:00
Peter Steinberger
94035bc200 test: tighten telegram monitor assertions 2026-05-11 10:57:02 +01:00
Shakker
ec2bef8154 test: tighten memory citation assertions 2026-05-11 10:56:32 +01:00
Shakker
ae98568b00 test: tighten qqbot stt request assertions 2026-05-11 10:55:07 +01:00
Peter Steinberger
89b894d630 fix: allow voice approval followups 2026-05-11 10:54:42 +01:00
Peter Steinberger
b3e2f3b261 fix: repair broken plugin package entries 2026-05-11 10:53:55 +01:00
Shakker
92ff210941 test: tighten qqbot reminder assertions 2026-05-11 10:53:41 +01:00
Peter Steinberger
c0602499ef docs: refresh crabbox skill for run helpers 2026-05-11 10:53:38 +01:00
Peter Steinberger
7a6f73a8aa fix(whatsapp): apply hot-reloaded DM policy 2026-05-11 10:53:10 +01:00
Shakker
ff3bf53938 test: tighten qqbot setup config assertions 2026-05-11 10:52:39 +01:00
Peter Steinberger
95948ce504 test: tighten telegram session route assertions 2026-05-11 10:51:51 +01:00
Shakker
5a9e8a29e5 test: tighten qqbot outbound assertions 2026-05-11 10:50:55 +01:00
Shakker
a4e6d00770 test: tighten qqbot quote assertion 2026-05-11 10:49:59 +01:00
Peter Steinberger
3eedeab04d test: tighten codex oauth refresh assertions 2026-05-11 10:49:32 +01:00
Shakker
5e43abe378 test: tighten qqbot attachment assertions 2026-05-11 10:49:05 +01:00
Shakker
c4cd22af0b test: tighten qqbot group config assertion 2026-05-11 10:48:08 +01:00
Shakker
946393a926 test: tighten qqbot policy assertions 2026-05-11 10:47:08 +01:00
Peter Steinberger
3e8ea999ba test: tighten directive parser assertions 2026-05-11 10:46:07 +01:00
Shakker
10575ea84a test: tighten telegram binding rejection assertions 2026-05-11 10:44:35 +01:00
Peter Steinberger
bbd3e7da75 test: tighten agent runner utility assertions 2026-05-11 10:44:10 +01:00
Shakker
59e1a00f5c test: tighten telegram threading context assertions 2026-05-11 10:42:48 +01:00
Peter Steinberger
3939750648 test: tighten tts command assertions 2026-05-11 10:41:46 +01:00
Peter Steinberger
9de498bfb0 test: fix current test type assertions 2026-05-11 10:41:37 +01:00
Shakker
3aa43c1dbd test: tighten msteams token store assertion 2026-05-11 10:41:23 +01:00
Shakker
90c97346f0 test: tighten googlechat target assertions 2026-05-11 10:40:01 +01:00
Peter Steinberger
c880d917cd test: tighten session lifecycle assertions 2026-05-11 10:39:24 +01:00
Shakker
b69f4cfdee test: tighten googlechat access assertions 2026-05-11 10:38:38 +01:00
Peter Steinberger
e21e83db97 fix(config): normalize Gemini provider catalog writes 2026-05-11 10:37:52 +01:00
Shakker
e88956d235 test: tighten googlechat auth assertions 2026-05-11 10:37:32 +01:00
Shakker
3112fbcb4d test: tighten diffs store cleanup assertion 2026-05-11 10:36:35 +01:00
Shakker
11aacaaf1d test: tighten google shared payload assertions 2026-05-11 10:33:58 +01:00
Shakker
7c18a5f575 test: tighten feishu account assertion 2026-05-11 10:32:45 +01:00
Ayaan Zaidi
becb6e8bbb fix(mantis): route telegram proof through trusted harness 2026-05-11 15:02:36 +05:30
Shakker
7e1afc0fea test: tighten zalouser channel assertion 2026-05-11 10:31:33 +01:00
Peter Steinberger
02f3b531a6 test: tighten channel catalog assertions 2026-05-11 10:31:14 +01:00
Shakker
0a39738257 test: tighten memory event assertions 2026-05-11 10:30:15 +01:00
Shakker
e588eadb5b test: tighten memory tool debug assertions 2026-05-11 10:29:26 +01:00
Shakker
efa6da6e02 test: tighten memory dreaming command assertions 2026-05-11 10:28:20 +01:00
Peter Steinberger
d1140d0f6f test: fix discord threading lint 2026-05-11 10:28:12 +01:00
Shakker
eae975d42d test: tighten google manifest alias assertions 2026-05-11 10:27:17 +01:00
Shakker
3fe1c1504d test: tighten memory dreaming markdown assertion 2026-05-11 10:25:54 +01:00
Shakker
9365da211a test: tighten browser cli timeout assertion 2026-05-11 10:24:58 +01:00
Shakker
81c48622ca test: tighten browser cli lazy assertions 2026-05-11 10:24:17 +01:00
Peter Steinberger
76b6ad1484 test: tighten daemon probe assertions 2026-05-11 10:24:02 +01:00
Shakker
79da106d25 test: tighten google provider hook assertions 2026-05-11 10:23:05 +01:00
Shakker
e4ea45495c test: tighten google web search assertion 2026-05-11 10:20:42 +01:00
Peter Steinberger
4cfba8b45d chore: fix transport lint regressions 2026-05-11 10:19:46 +01:00
Shakker
b29bcbcf75 test: tighten mattermost setup assertion 2026-05-11 10:19:38 +01:00
Shakker
497fed0e50 test: tighten discord webhook error assertions 2026-05-11 10:17:59 +01:00
Shakker
33910876a7 test: tighten imessage gating assertion 2026-05-11 10:16:33 +01:00
Peter Steinberger
1307cf4d5c test: tighten port probe assertions 2026-05-11 10:15:48 +01:00
Shakker
1ba3a2c882 test: tighten imessage inbound assertion 2026-05-11 10:15:38 +01:00
Shakker
1c484d4303 test: tighten openshell backend assertion 2026-05-11 10:14:38 +01:00
Peter Steinberger
313ce2c18c docs: add pnpm follow-up changelog (#80588) 2026-05-11 10:13:49 +01:00
Altay
7084c7d43f test(pnpm): check workflow pnpm major 2026-05-11 10:13:49 +01:00
Altay
a3cbc67a37 test(pnpm): derive workflow pin from package manager 2026-05-11 10:13:49 +01:00
Altay
7d35f28b6c chore(pnpm): align follow-up pnpm 11 surfaces 2026-05-11 10:13:49 +01:00
Peter Steinberger
dcb37a39b3 test: tighten setup command assertions 2026-05-11 10:12:44 +01:00
Shakker
c95bbca8f1 test: tighten zai onboard assertions 2026-05-11 10:12:37 +01:00
Shakker
4452df5b17 test: tighten slack probe timeout assertion 2026-05-11 10:11:29 +01:00
Peter Steinberger
b9185703bc chore: add model transport debugging 2026-05-11 10:11:03 +01:00
Shakker
640d1994c0 test: tighten brave search error assertions 2026-05-11 10:10:42 +01:00
Peter Steinberger
e2e63b82ac test: tighten security cli assertions 2026-05-11 10:10:33 +01:00
Shakker
b60de25021 test: tighten minimax provider assertions 2026-05-11 10:09:10 +01:00
Peter Steinberger
804edb10f3 test: tighten cron model preflight assertions 2026-05-11 10:08:30 +01:00
Shakker
fcfff66e98 test: tighten discord component fallback assertions 2026-05-11 10:07:45 +01:00
Shakker
000e39310d test: tighten discord preflight binding assertions 2026-05-11 10:06:35 +01:00
Shakker
6efb4e13db test: tighten discord acp preflight assertions 2026-05-11 10:05:18 +01:00
Peter Steinberger
6e6decf5d2 test: tighten cron sandbox config assertions 2026-05-11 10:04:37 +01:00
Shakker
9885680469 test: tighten discord acp bind assertions 2026-05-11 10:04:30 +01:00
Peter Steinberger
37fac48f97 test: tighten cron session key assertions 2026-05-11 10:02:29 +01:00
Shakker
8a9f99d3e5 test: tighten discord native command assertions 2026-05-11 10:02:02 +01:00
Shakker
4766ad6b06 test: tighten discord gateway metadata assertions 2026-05-11 10:00:56 +01:00
Peter Steinberger
8cdaf771db test: tighten embeddings http assertions 2026-05-11 10:00:23 +01:00
Shakker
3911058708 test: tighten discord threading utility assertions 2026-05-11 09:59:58 +01:00
oliviareid-svg
337f1b2a42 fix(microsoft-foundry): replace unsafe non-null assertion in subscription lookup (#62742)
subs.find() can return undefined if the selected subscription ID does not match any enabled subscription. Replace the unsafe non-null assertion with an explicit guard and descriptive error.

Co-authored-by: oliviareid-svg <oliviareid@users.noreply.github.com>
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-05-11 03:59:34 -05:00
Shakker
1bf6bd33b5 test: tighten discord component context assertions 2026-05-11 09:58:51 +01:00
Shakker
493995467e test: tighten discord binding api assertions 2026-05-11 09:58:07 +01:00
Shakker
c5d816b873 test: tighten discord thread starter assertions 2026-05-11 09:56:58 +01:00
Peter Steinberger
2e1e914572 test: tighten approval bootstrap assertions 2026-05-11 09:56:35 +01:00
Shakker
48d320b931 test: tighten discord route assertions 2026-05-11 09:54:48 +01:00
Shakker
37bce8ad4d test: tighten discord channel access assertions 2026-05-11 09:53:54 +01:00
Shakker
13458025bc test: tighten discord dm auth assertions 2026-05-11 09:53:18 +01:00
Shakker
893632fc67 test: tighten slack reaction assertions 2026-05-11 09:52:35 +01:00
Peter Steinberger
76903f4dbf test: tighten gateway close assertions 2026-05-11 09:51:47 +01:00
Shakker
733545c90d test: tighten discord voice assertions 2026-05-11 09:51:04 +01:00
Peter Steinberger
e432c32701 test: tighten gateway method list assertions 2026-05-11 09:49:42 +01:00
Ayaan Zaidi
96d4dd68da fix(mantis): validate telegram driver before lease 2026-05-11 14:19:36 +05:30
Shakker
4ddccbd28d test: tighten comfy provider assertions 2026-05-11 09:48:48 +01:00
Shakker
0f4a37c828 test: tighten tlon security assertions 2026-05-11 09:47:46 +01:00
Peter Steinberger
7e8f74ded4 test: tighten chat abort auth assertions 2026-05-11 09:46:00 +01:00
Shakker
0f574902d8 test: tighten discord action assertions 2026-05-11 09:45:50 +01:00
Peter Steinberger
0ed0f93620 test: tighten skill upload store assertions 2026-05-11 09:42:26 +01:00
Shakker
50efe3f55e test: tighten qa matrix tee assertions 2026-05-11 09:42:08 +01:00
Shakker
928bd2de01 test: tighten mattermost slash monitor assertions 2026-05-11 09:41:24 +01:00
Shakker
9da1ac1bb1 test: tighten mattermost websocket assertions 2026-05-11 09:40:24 +01:00
Peter Steinberger
84190e3de3 test: tighten tasks handler assertions 2026-05-11 09:39:59 +01:00
Shakker
192d161f7f test: tighten mattermost draft assertions 2026-05-11 09:39:12 +01:00
Shakker
8b8f653b50 test: tighten mattermost client assertions 2026-05-11 09:38:25 +01:00
Peter Steinberger
037ebe76f3 test: tighten tools effective assertions 2026-05-11 09:37:49 +01:00
Shakker
efbffd808f test: tighten mattermost gating assertions 2026-05-11 09:37:30 +01:00
Peter Steinberger
32906ea64c test: use stable array ordering helpers 2026-05-11 09:37:13 +01:00
Peter Steinberger
f2031ee8c1 test: remove redundant slack test cast 2026-05-11 09:37:13 +01:00
Peter Steinberger
de630ce4f0 docs: update changelog for retry-after fix (#68543) 2026-05-11 09:37:13 +01:00
Feelw00
b7fc2451e7 fix(infra): positive jitter 는 Math.ceil 로 non-integer retryAfterMs 하방도 보장 (cross-review) 2026-05-11 09:37:13 +01:00
Feelw00
a77bd213ce fix(infra): Retry-After 경계(===)에서 contract 우선, symmetric 은 >만 (codex override) 2026-05-11 09:37:13 +01:00
Feelw00
317e474b84 fix(infra): retryAfterMs === maxDelayMs 경계에서도 symmetric fallback (greptile review) 2026-05-11 09:37:13 +01:00
Feelw00
62dff64700 fix(infra): retryAfterMs > maxDelayMs 때 symmetric jitter 유지 (codex review) 2026-05-11 09:37:13 +01:00
Feelw00
d49480527e fix(infra): retryAsync retry-after 를 jitter 가 침범하지 않도록 positive-only mode 적용 2026-05-11 09:37:13 +01:00
Shakker
d4dbcea0cf test: tighten mattermost slash assertions 2026-05-11 09:36:52 +01:00
Shakker
394011ab16 test: tighten irc send assertions 2026-05-11 09:36:13 +01:00
Shakker
d67ad56658 test: tighten qa matrix cli assertions 2026-05-11 09:34:53 +01:00
Peter Steinberger
fdb4b8940c test: tighten gateway reload assertions 2026-05-11 09:34:38 +01:00
Peter Steinberger
21fb799168 fix(agents): label sandbox tool workdirs 2026-05-11 09:33:34 +01:00
Peter Steinberger
eb38d2d277 fix(deps): update fs-safe Windows stat fallback 2026-05-11 09:33:15 +01:00
Peter Steinberger
e8ab20c0e4 test: tighten session search assertions 2026-05-11 09:31:44 +01:00
Shakker
d9314f7f45 test: tighten mattermost authz assertions 2026-05-11 09:31:30 +01:00
Shakker
3b89a8b961 test: tighten mattermost auth assertions 2026-05-11 09:30:36 +01:00
Peter Steinberger
12624457d0 test: tighten message hook mapper assertions 2026-05-11 09:29:37 +01:00
Shakker
86a84015a9 test: tighten channel send assertions 2026-05-11 09:29:18 +01:00
Peter Steinberger
50700ccca1 test: tighten backup create assertions 2026-05-11 09:27:39 +01:00
Shakker
337d58404f test: tighten dreaming repair assertions 2026-05-11 09:27:29 +01:00
Shakker
2b5c18012c test: tighten memory cli assertions 2026-05-11 09:26:40 +01:00
Peter Steinberger
0dbdbc1372 test: tighten device bootstrap assertions 2026-05-11 09:25:59 +01:00
Shakker
413197238b test: tighten msteams feedback assertions 2026-05-11 09:24:46 +01:00
Peter Steinberger
00cf49d607 test: fix assertion type checks 2026-05-11 09:23:54 +01:00
Peter Steinberger
fb02e25798 test: tighten package update step assertions 2026-05-11 09:23:26 +01:00
Ayaan Zaidi
1564e70b3b fix(browser): reuse chrome mcp screenshot format 2026-05-11 13:52:38 +05:30
Baris Albayrak
86794d638e docs(changelog): link #77222 for chrome-mcp screenshot fix 2026-05-11 13:52:38 +05:30
Baris Albayrak
694e05be0e docs(changelog): credit @barbarhan for #74685 2026-05-11 13:52:38 +05:30
Baris Albayrak
6e4c17ca35 fix(browser): read chrome MCP screenshot extension 2026-05-11 13:52:38 +05:30
Shakker
cdc8247dd8 test: tighten browser and memory path assertions 2026-05-11 09:22:22 +01:00
Peter Steinberger
6a58d84b2d test: tighten restart handoff assertions 2026-05-11 09:21:21 +01:00
Shakker
95d711977b test: tighten acpx auth bridge assertions 2026-05-11 09:21:17 +01:00
Shakker
38295d3c04 test: tighten slack and openshell assertions 2026-05-11 09:20:24 +01:00
Shakker
27ec47d433 test: tighten device pair assertions 2026-05-11 09:18:03 +01:00
Peter Steinberger
43653f5d23 test: tighten shell env assertions 2026-05-11 09:17:24 +01:00
Shakker
1772716fc1 test: tighten qa aimock server assertions 2026-05-11 09:16:28 +01:00
Shakker
fb451028d5 test: tighten fal image assertions 2026-05-11 09:14:43 +01:00
Peter Steinberger
dd5ce8712f test: tighten tsdown config assertions 2026-05-11 09:13:42 +01:00
Shakker
d544414eef test: tighten copilot model assertions 2026-05-11 09:13:17 +01:00
Shakker
44b13ef25e test: tighten copilot stream assertions 2026-05-11 09:12:02 +01:00
Peter Steinberger
da9e77f6e9 test: tighten diagnostic support export assertions 2026-05-11 09:11:15 +01:00
Shakker
7e6c407c03 test: tighten minimax provider assertions 2026-05-11 09:09:52 +01:00
Peter Steinberger
b282745b4c test: tighten app render helper assertions 2026-05-11 09:08:49 +01:00
Shakker
32f3af8bbc test: tighten feishu assertion coverage 2026-05-11 09:08:33 +01:00
Peter Steinberger
e9174fc984 test: tighten tool card assertions 2026-05-11 09:06:29 +01:00
Shakker
6066e878f6 test: tighten slack setup manifest assertion 2026-05-11 09:05:16 +01:00
Peter Steinberger
2d64ee0aec test: tighten google live talk assertions 2026-05-11 09:05:10 +01:00
Shakker
69b6f1f676 test: tighten speech provider assertions 2026-05-11 09:04:29 +01:00
Shakker
baa72f4c45 test: tighten hermes secret assertions 2026-05-11 09:03:18 +01:00
Peter Steinberger
85e9dd0720 test: tighten command palette item assertions 2026-05-11 09:02:44 +01:00
Shakker
4bef5422cd test: tighten openrouter provider assertions 2026-05-11 09:02:24 +01:00
Peter Steinberger
71d814ee35 test: tighten browser chrome diagnostics 2026-05-11 09:00:57 +01:00
Peter Steinberger
f12f123f43 fix: keep workspace file status on Windows 2026-05-11 08:58:52 +01:00
Shakker
c249163537 test: tighten zalouser setup assertions 2026-05-11 08:58:41 +01:00
Peter Steinberger
f4aa97f660 test: tighten browser cli inspect assertions 2026-05-11 08:57:56 +01:00
Shakker
f7938c82db test: tighten comfy video assertions 2026-05-11 08:57:09 +01:00
Peter Steinberger
043d27b0ea test: tighten codex media request assertions 2026-05-11 08:56:04 +01:00
Shakker
63236764b5 test: tighten comfy music assertions 2026-05-11 08:55:54 +01:00
Shakker
02ddac4f76 test: tighten qa inbound assertions 2026-05-11 08:54:44 +01:00
Peter Steinberger
3870850d91 test: tighten codex auth bridge assertions 2026-05-11 08:54:12 +01:00
Shakker
e3b5e28cff test: tighten mattermost slash state assertions 2026-05-11 08:52:53 +01:00
Shakker
ee0563cb52 test: tighten qa bus client assertions 2026-05-11 08:50:44 +01:00
Shakker
54807c3af8 test: tighten synology tls assertions 2026-05-11 08:49:52 +01:00
Peter Steinberger
89641f37ae test: tighten codex plugin inventory assertions 2026-05-11 08:49:39 +01:00
Shakker
004bb2013e test: tighten device pair notify assertions 2026-05-11 08:48:57 +01:00
Ayaan Zaidi
799bd8a23b ci(mantis): fetch ffmpeg proof tools directly 2026-05-11 13:18:34 +05:30
Peter Steinberger
cb3d5c0c61 test: tighten codex plugin thread config assertions 2026-05-11 08:48:28 +01:00
Shakker
9062313486 test: tighten msteams conversation store assertions 2026-05-11 08:48:01 +01:00
Peter Steinberger
672ef67fa7 test: tighten discord component assertions 2026-05-11 08:47:10 +01:00
Shakker
42e1d68a74 test: tighten msteams credential assertions 2026-05-11 08:46:54 +01:00
Shakker
f1190f2ad5 test: tighten ollama provider policy assertions 2026-05-11 08:46:09 +01:00
Peter Steinberger
bd26b13d1e test: tighten discord subagent hook assertions 2026-05-11 08:45:58 +01:00
Shakker
ce1fe33ca0 test: tighten ollama stream content assertions 2026-05-11 08:45:26 +01:00
Peter Steinberger
baba16518e test: tighten matrix reaction assertions 2026-05-11 08:44:39 +01:00
Shakker
6187b425d5 test: tighten discord voice command assertions 2026-05-11 08:44:21 +01:00
Shakker
d8a9860df7 test: tighten google meet oauth assertions 2026-05-11 08:43:29 +01:00
Peter Steinberger
852d267767 test: tighten matrix credential assertions 2026-05-11 08:43:26 +01:00
Shakker
829375f634 test: tighten msteams pending upload fs assertions 2026-05-11 08:42:47 +01:00
Peter Steinberger
086bb3514f test: tighten matrix route assertions 2026-05-11 08:41:50 +01:00
Shakker
923c993e5a test: tighten tlon sse subscription assertions 2026-05-11 08:41:43 +01:00
Ayaan Zaidi
1caf3ae674 ci(mantis): install static proof media tools 2026-05-11 13:11:16 +05:30
Shakker
1941142391 test: tighten qqbot websocket option assertions 2026-05-11 08:40:26 +01:00
Shakker
6a8fd8b7f3 test: tighten google api config assertions 2026-05-11 08:39:45 +01:00
Peter Steinberger
cb593f3b08 test: tighten mattermost route assertions 2026-05-11 08:39:40 +01:00
Shakker
3fe229182f test: tighten discord voice access assertions 2026-05-11 08:38:43 +01:00
Peter Steinberger
baaf42cd22 test: tighten memory atomic reindex assertions 2026-05-11 08:38:22 +01:00
Shakker
a4f606e2cf test: tighten mistral realtime config assertion 2026-05-11 08:37:28 +01:00
Peter Steinberger
fe9e3bde6a test: tighten memory wiki query assertions 2026-05-11 08:36:44 +01:00
Shakker
a371976787 test: tighten msteams allowlist assertion 2026-05-11 08:35:41 +01:00
Peter Steinberger
44dfb10e6a test: tighten msteams graph assertions 2026-05-11 08:35:20 +01:00
Peter Steinberger
3e9efe3b11 test: tighten auth profile assertions 2026-05-11 08:34:06 +01:00
Shakker
dda4ac92db test: tighten msteams pending upload assertions 2026-05-11 08:33:33 +01:00
Shakker
62962a7257 test: tighten oc-path jsonl resolver assertions 2026-05-11 08:32:32 +01:00
Ayaan Zaidi
64cfb2be70 ci(mantis): avoid host apt in telegram proof 2026-05-11 13:02:04 +05:30
Shakker
29b41f49c4 test: tighten oc-path jsonc resolver assertions 2026-05-11 08:31:34 +01:00
Shakker
5d15f47887 test: tighten fireworks stream assertions 2026-05-11 08:30:37 +01:00
Peter Steinberger
4fc1ff7dfd test: tighten ollama web search assertions 2026-05-11 08:29:38 +01:00
Shakker
3014351dfb test: tighten elevenlabs realtime config assertion 2026-05-11 08:29:33 +01:00
Shakker
efc9106408 test: tighten file-transfer tar budget assertions 2026-05-11 08:27:45 +01:00
Peter Steinberger
2251e9f489 fix: normalize onboarded gemini catalog ids 2026-05-11 08:26:54 +01:00
Shakker
6a72bb9782 test: tighten msteams poll store assertions 2026-05-11 08:26:38 +01:00
Shakker
4ad9286e19 test: tighten zca client assertion 2026-05-11 08:25:29 +01:00
Ayaan Zaidi
449eb09a15 docs(changelog): note telegram edit cache 2026-05-11 12:54:41 +05:30
Ayaan Zaidi
4c2b63975c test(telegram): prove edited message context 2026-05-11 12:54:41 +05:30
Ayaan Zaidi
f79117e479 fix(telegram): cache edited messages 2026-05-11 12:54:41 +05:30
Shakker
ce5df3380b test: tighten perplexity transport assertions 2026-05-11 08:24:32 +01:00
Shakker
dfbd9b6023 test: tighten zalo group policy assertions 2026-05-11 08:23:32 +01:00
Leo Ge
66b4306a2a fix(fal): route GPT Image 2/NB2 edits through Fal edit endpoints
Fix Fal image-edit routing for GPT Image 2 and Nano Banana 2, including multi-image edit payloads and provider-specific reference limits.

- Routes GPT Image 2/Nano Banana 2 edits through Fal `/edit` endpoints with `image_urls`.
- Keeps Flux/custom image-to-image edits on singular `image_url` and preserves exact custom `/edit` paths.
- Documents and tests provider caps: Flux/custom 1, GPT Image 2 10, Nano Banana 2 14.

Verified with focused Fal provider tests, oxlint, oxfmt, `git diff --check`, docs listing, green PR CI, and live Fal calls for GPT Image 2, Nano Banana 2, Flux, plus the GPT Image 2 10-ref cap edge.

Co-authored-by: Leo Ge <116452300+leoge007@users.noreply.github.com>
2026-05-11 08:22:34 +01:00
Pavan Kumar Gondhi
17ceca86d6 Redact persisted secret-shaped payloads [AI] (#79006)
* fix: redact persisted secret-shaped payloads

* docs: add changelog entry for PR merge
2026-05-11 12:52:32 +05:30
Shakker
be8bf3585e test: tighten searxng empty result assertion 2026-05-11 08:22:05 +01:00
Shakker
c7f7cd6e5e test: tighten qa cron wait assertion 2026-05-11 08:21:08 +01:00
Shakker
93cac4c7dc test: tighten slack target assertions 2026-05-11 08:20:22 +01:00
Peter Steinberger
4866f7960c test: tighten openai plugin manifest assertions 2026-05-11 08:19:33 +01:00
Shakker
748788177b test: tighten exa provider assertions 2026-05-11 08:18:30 +01:00
Ayaan Zaidi
6729044966 ci(mantis): prepare telegram proof tooling 2026-05-11 12:47:46 +05:30
Ayaan Zaidi
4facdded3e fix(telegram): use repo-owned user driver 2026-05-11 12:47:46 +05:30
Shakker
ad08232753 test: tighten volcengine tts assertions 2026-05-11 08:16:12 +01:00
Shakker
4c05c39d39 test: tighten venice compat assertions 2026-05-11 08:14:45 +01:00
Shakker
a0c087594e test: tighten google embedding request assertions 2026-05-11 08:13:32 +01:00
Shakker
5ca5fc5746 test: tighten diff language hint assertions 2026-05-11 08:12:34 +01:00
Peter Steinberger
ae720e5892 test: tighten openai transport assertions 2026-05-11 08:12:06 +01:00
Shakker
86a67b4b15 test: tighten feishu streaming card assertions 2026-05-11 08:11:24 +01:00
Shakker
138aa763ce test: tighten msteams probe assertions 2026-05-11 08:10:17 +01:00
Shakker
a74bf2bfcc test: tighten discord channel resolver assertions 2026-05-11 08:09:12 +01:00
Shakker
628885ebfc test: tighten xiaomi speech provider assertions 2026-05-11 08:08:06 +01:00
Peter Steinberger
e092d50e77 test: tighten qa credentials admin assertions 2026-05-11 08:07:01 +01:00
Shakker
f528a70a8f test: tighten nextcloud preflight assertions 2026-05-11 08:06:51 +01:00
Shakker
f4ad760c6a test: tighten tavily tool result assertions 2026-05-11 08:05:51 +01:00
Shakker
11fdf60d05 test: tighten llm task schema assertions 2026-05-11 08:04:32 +01:00
Peter Steinberger
122c0104cd test: tighten slack message adapter assertions 2026-05-11 08:04:00 +01:00
Shakker
247c1f58e7 test: tighten mistral provider assertions 2026-05-11 08:03:25 +01:00
Shakker
a2f1b01ad8 test: tighten feishu probe error assertions 2026-05-11 08:02:13 +01:00
Peter Steinberger
e9947d9316 test: tighten telegram account config assertions 2026-05-11 08:01:59 +01:00
Shakker
abbb598986 test: tighten nextcloud replay status assertions 2026-05-11 08:01:20 +01:00
Shakker
e003849454 test: tighten slack user resolution assertion 2026-05-11 07:59:20 +01:00
Peter Steinberger
533099a3e5 test: tighten telegram thread binding assertions 2026-05-11 07:59:09 +01:00
Shakker
5e01b16976 test: tighten teams feedback reflection assertion 2026-05-11 07:57:10 +01:00
Peter Steinberger
f28a987442 refactor: centralize reply prompt envelope 2026-05-11 07:56:45 +01:00
Peter Steinberger
c6041616e1 build(canvas): refresh A2UI bundle hash 2026-05-11 07:56:36 +01:00
Peter Steinberger
a1811b33ce test: tighten telegram lane delivery assertions 2026-05-11 07:56:22 +01:00
Peter Steinberger
c743c61c69 fix(gateway): clarify token source conflict warning 2026-05-11 07:56:12 +01:00
Shakker
eb81dd899c test: tighten twitch client send assertion 2026-05-11 07:56:00 +01:00
Shakker
fd2ebf4458 test: tighten discord dns assertion 2026-05-11 07:54:37 +01:00
Peter Steinberger
5dba5db7af test: tighten acp lifecycle assertions 2026-05-11 07:54:26 +01:00
Shakker
3c1fd7030e test: tighten line send receipt assertions 2026-05-11 07:53:29 +01:00
Peter Steinberger
6715ee6a2b test: tighten reset hook assertions 2026-05-11 07:52:41 +01:00
Shakker
e149a23a3b test: tighten clickclack account assertions 2026-05-11 07:51:25 +01:00
Peter Steinberger
94c7882713 test: tighten usage command assertions 2026-05-11 07:50:46 +01:00
Peter Steinberger
f4ba9553c0 fix(models): preserve fallback chain for override models 2026-05-11 07:50:19 +01:00
Shakker
8d695fc5be test: tighten anthropic stream assertion 2026-05-11 07:49:58 +01:00
Peter Steinberger
d9fe18c574 test: tighten backup command assertions 2026-05-11 07:48:50 +01:00
3377 changed files with 126163 additions and 32536 deletions

View File

@@ -0,0 +1,159 @@
---
name: clawdtributor
description: "Use for OpenClaw clawtributors PR/issue triage: Discrawl discovery, live-open rechecks, deep review, topic grouping, and compact @handle/LOC/type/blast/verification summaries."
---
# Clawdtributor
Use for the `#clawtributors` queue: Discord-discovered OpenClaw PRs/issues that need live GitHub status plus maintainer-quality review.
## Compose with other skills
- `$discrawl`: local Discord archive sync/search.
- `$openclaw-pr-maintainer`: live GitHub PR/issue review, duplicate search, close/land rules.
- `$gitcrawl`: related issue/PR and current-main/stale-proof search.
- `$openclaw-testing` / `$crabbox`: proof choice when a candidate needs real validation.
## Archive flow
Local archive first; verify freshness for current questions.
```bash
discrawl status --json
discrawl sync
```
Resolve channel if needed:
```bash
sqlite3 "$HOME/.discrawl/discrawl.db" \
"select id,name from channels where name like '%clawtributor%' order by name;"
```
Current known channel id from prior work: `1458141495701012561`. Re-resolve if it stops matching.
Extract recent refs:
```bash
sqlite3 "$HOME/.discrawl/discrawl.db" "
select m.created_at, coalesce(nullif(mm.username,''), m.author_id), m.content
from messages m
left join members mm on mm.guild_id=m.guild_id and mm.user_id=m.author_id
where m.channel_id='1458141495701012561'
and m.created_at >= '<ISO cutoff>'
order by m.created_at desc;" |
perl -nE 'while(m{github\.com/openclaw/openclaw/(pull|issues)/(\d+)}g){say "$1\t$2\t$_"}'
```
Map a PR/issue back to the Discord handle:
```bash
sqlite3 -separator $'\t' "$HOME/.discrawl/discrawl.db" "
select m.created_at,
coalesce(nullif(mm.username,''), nullif(mm.global_name,''), m.author_id)
from messages m
left join members mm on mm.guild_id=m.guild_id and mm.user_id=m.author_id
where m.channel_id='1458141495701012561'
and m.content like '%github.com/openclaw/openclaw/<pull-or-issues>/<number>%'
order by m.created_at desc
limit 1;"
```
Show only `@handle` in the final list. Do not write the word Discord unless the user asks for source details.
## Live GitHub recheck
Always recheck live state before listing, closing, or saying "open".
```bash
GITHUB_TOKEN= GITHUB_TOKEN_NODIFF= GH_TOKEN= \
gh api repos/openclaw/openclaw/pulls/<number> \
--jq '. | {number,title,state,merged,mergeable,draft,author:.user.login,url:.html_url,updatedAt:.updated_at,additions,deletions,changedFiles:.changed_files}'
```
For issues:
```bash
GITHUB_TOKEN= GITHUB_TOKEN_NODIFF= GH_TOKEN= \
gh api repos/openclaw/openclaw/issues/<number> \
--jq '. | {number,title,state,author:.user.login,url:.html_url,updatedAt:.updated_at,pull_request}'
```
If `gh` says bad credentials, clear env vars with empty assignments as above. Use `--jq '. | {...}'` for object projections.
## Review depth
For each open item, inspect enough to classify risk:
- PR body, linked issue, comments, files, additions/deletions, checks.
- Current `origin/main` code path and adjacent tests.
- Related threads with `gitcrawl neighbors/search`.
- Whether main already fixed it, the PR is obsolete, or the idea is invalid.
- Blast radius: touched runtime surfaces, config/schema, plugin/core boundary, user-visible behavior, release/package surface.
- Verification: say if local unit/docs proof is enough, live/provider proof is needed, or it is not directly verifiable.
Do not close from title alone. If closing as done on main or nonsensical, prove it against current main and comment first when mutation is requested. Bulk close/reopen above 5 requires explicit scope.
## Candidate selection
When asked for `5 new`, exclude refs already surfaced in the session and refill from the archive until there are 5 live-open candidates. If fewer than 5 remain open, list all open ones and say how many short.
When asked to `update`, `refresh`, `recheck`, `check again`, or similar, return an updated live-open candidate list. Do not fill the main list with items that merely merged/closed since the last pass; put those numbers in a short bottom line.
Prefer:
- Fresh, open, external contributor work.
- Small, high-confidence bugfixes.
- Clear repro, tests, or obvious code-path proof.
Demote:
- Broad product/features without owner decision.
- Large rewrites with unclear contract.
- PRs already in progress, merged, closed, duplicate, or fixed on main.
## Topic grouping
Group only when useful or requested:
- Agents/tooling
- Providers/auth/models
- Channels/messaging
- UI/web
- Gateway/protocol/runtime
- Config/memory/cache
- Docker/install/release
- Docs/tests/chore
- Closed/obsolete
Infer topic from labels, touched files, title/body, and actual code path.
## Output format
No Markdown tables. Compact bullets. Use color/risk markers:
- 🟢 low/narrow
- 🟡 medium or needs targeted proof
- 🔴 broad/high runtime risk
- 🟣 security/policy/owner-boundary slow review
- ✅ merged
- ⚪ closed unmerged
Required line shape:
```markdown
- **PR #81244** `@whatsskill.` `+118/-1` `bug` 🟢 verifiable: yes. This prevents chat action buttons from overlapping short assistant replies. Blast: web chat rendering, low.
- **Issue #81245** `@alice` `LOC n/a` `bug` 🟡 verifiable: partial. This reports duplicate Telegram replies when reconnecting after gateway restart. Blast: Telegram channel runtime, medium.
```
Rules:
- Bold the `PR #n` or `Issue #n` marker.
- Use `@handle`, not author bio text.
- PR LOC is `+additions/-deletions`; issue LOC is `LOC n/a`.
- Type: `bug`, `feature`, `perf`, `security`, `docs`, `test`, `chore`, or `refactor`.
- Write a full sentence for what it does.
- Always include blast radius in one phrase.
- Always include `verifiable: yes|partial|no` plus the shortest proof hint when helpful.
- If status is not open, still show it only when the user asked for all surfaced refs; use ✅ or ⚪ and state merged/closed.
- For refresh-style asks, bottom line: `Merged/closed since last pass: #81016 merged, #81026 closed.` Omit if none.

View File

@@ -1,6 +1,6 @@
---
name: crabbox
description: Use Crabbox for OpenClaw remote Linux validation. Default to Blacksmith Testbox; includes direct Blacksmith and owned AWS/Hetzner fallback notes when Crabbox fails.
description: Use Crabbox for OpenClaw remote validation across Linux, macOS, Windows, and WSL2. Default to Blacksmith Testbox for broad Linux proof; includes direct Blacksmith and owned AWS/Hetzner fallback notes when Crabbox fails.
---
# Crabbox
@@ -31,13 +31,16 @@ pnpm crabbox:run -- --help | sed -n '1,120p'
- Check `.crabbox.yaml` for repo defaults, but override provider explicitly.
Even if config still says AWS, maintainer validation should normally pass
`--provider blacksmith-testbox`.
- For live/provider bugs, check keys on the local Mac before downgrading to
mocks: source local `~/.profile` and test only presence/length. If Crabbox
does not already have the key, copy only the exact needed key into the remote
process environment for that one command. Do not print it, do not sync it as a
repo file, and do not leave it in remote shell history or logs. If no
secret-safe injection path is available, say true live provider auth is
blocked instead of silently using a fake key.
- If a warm direct-provider lease smells stale, retry with `--full-resync`
(alias `--fresh-sync`) before replacing the lease. This resets the remote
workdir, skips the fingerprint fast path, reseeds Git when possible, and
uploads the checkout from scratch.
- For live/provider bugs, use the configured secret workflow before downgrading
to mocks. Copy only the exact needed key into the remote process environment
for that one command. Do not print it, do not sync it as a repo file, and do
not leave it in remote shell history or logs. If no secret-safe injection path
is available, say true live provider auth is blocked instead of silently using
a fake key.
- Prefer local targeted tests for tight edit loops. Broad gates belong remote.
- Do not treat inherited shell env as operator intent. In particular,
`OPENCLAW_LOCAL_CHECK_MODE=throttled` from the local shell is not permission
@@ -64,7 +67,8 @@ Crabbox supports static SSH targets:
- `target=macos` and `target=windows --windows-mode wsl2` use the POSIX SSH,
bash, Git, rsync, and tar contract.
- Native Windows uses OpenSSH, PowerShell, Git, and tar; sync is manifest tar
archive transfer into `static.workRoot`.
archive transfer into `static.workRoot`. Direct native Windows runs support
`--script*`, `--env-from-profile`, `--preflight`, and PowerShell `--shell`.
- `crabbox actions hydrate/register` are Linux-only today; use plain
`crabbox run` loops for static macOS and Windows hosts.
- Live proof needs a reachable, operator-managed SSH host. Without one, verify
@@ -127,6 +131,7 @@ Read the JSON summary. Useful fields:
- `provider`: should be `blacksmith-testbox`
- `leaseId`: `tbx_...`
- `syncDelegated`: should be `true`
- `commandPhases`: populated when the command prints `CRABBOX_PHASE:<name>`
- `commandMs` / `totalMs`
- `exitCode`
@@ -138,6 +143,85 @@ unclear:
blacksmith testbox list
```
## Observability Flags
Use these on debugging runs before inventing ad hoc logging:
- `--preflight`: prints run context, workspace mode, SSH target, remote user/cwd,
and target-specific tool probes. Defaults cover `git`, `tar`, `node`, `npm`,
`corepack`, `pnpm`, `yarn`, `bun`, `docker`, plus POSIX
`sudo`/`apt`/`bubblewrap` and native Windows
`powershell`/`execution_policy`/`longpaths`/`temp`/`pwsh`. Add
`--preflight-tools node,bun,docker`, `CRABBOX_PREFLIGHT_TOOLS`, or repo
`run.preflightTools` to replace the list. `default` expands built-ins; `none`
prints only the workspace summary. Preflight is diagnostic only; install
toolchains through Actions hydration, images, devcontainer/Nix/mise/asdf, or
the run script. On `blacksmith-testbox`, this prints a delegated-unsupported
note because the workflow owns setup.
- `CRABBOX_ENV_ALLOW=NAME,...`: forwards only listed local env vars for direct
providers and prints `set len=N secret=true` style summaries. On
`blacksmith-testbox`, env forwarding is unsupported; put secrets in the
Testbox workflow instead.
- `--env-from-profile <file>` plus `--allow-env NAME`: loads simple
`export NAME=value` / `NAME=value` lines from a local profile without
executing it, then forwards only allowlisted names. `--allow-env` is
repeatable and comma-separated. Profile values override ambient allowlisted
env values for that run. Direct POSIX, WSL2, and native Windows runs are
supported; delegated providers are not. Crabbox probes the uploaded profile
remotely and prints redacted presence/length metadata before the command.
- `--env-helper <name>`: with `--env-from-profile` on POSIX SSH targets,
persists `.crabbox/env/<name>` and `.crabbox/env/<name>.env` so follow-up
commands on the same lease can run through `./.crabbox/env/<name> <command>`.
Use only on leases you control; the profile stays until cleanup, lease reset,
or `--full-resync`.
- `--script <file>` / `--script-stdin`: upload a local script into
`.crabbox/scripts/` and execute it on the remote box. Shebang scripts execute
directly on POSIX; scripts without a shebang run through `bash`. Native
Windows uploads run through Windows PowerShell, and Crabbox appends `.ps1`
when needed. Arguments after `--` become script args.
- `--fresh-pr owner/repo#123|URL|number`: skip dirty local sync and create a
fresh remote checkout of the GitHub PR. Bare numbers use the current repo's
GitHub origin. Add `--apply-local-patch` only when the current local
`git diff --binary HEAD` should be applied on top of that PR checkout.
- `--full-resync` / `--fresh-sync`: reset a stale direct-provider workdir
before syncing. Use after sync fingerprints look wrong, SSH times out before
sync, or rsync watchdog output suggests it. It is redundant with
`--fresh-pr`, incompatible with `--no-sync`, and unsupported by delegated
providers.
- `--capture-stdout <path>` / `--capture-stderr <path>`: write remote streams to
local files and keep binary/noisy output out of retained logs. Parent
directories must already exist. These are direct-provider only.
- `--capture-on-fail`: on non-zero direct-provider exits, downloads
`.crabbox/captures/*.tar.gz` with `test-results`, `playwright-report`,
`coverage`, JUnit XML, and nearby logs. Treat as secret-bearing until reviewed.
- `--keep-on-failure`: leave a failed one-shot lease alive for live debugging
until idle/TTL expiry. Useful on direct providers and delegated one-shots.
- `--timing-json`: final machine-readable timing. Add
`echo CRABBOX_PHASE:install`, `CRABBOX_PHASE:test`, etc. in long shell
commands; direct providers and Blacksmith Testbox both report them as
`commandPhases`.
Live-provider debug template for direct AWS/Hetzner leases:
```sh
mkdir -p .crabbox/logs
pnpm crabbox:run -- --provider aws \
--preflight \
--allow-env OPENAI_API_KEY,OPENAI_BASE_URL \
--timing-json \
--capture-stdout .crabbox/logs/live-provider.stdout.log \
--capture-stderr .crabbox/logs/live-provider.stderr.log \
--capture-on-fail \
--shell -- \
"echo CRABBOX_PHASE:install; pnpm install --frozen-lockfile; echo CRABBOX_PHASE:test; pnpm test:live"
```
Do not pass `--capture-*`, `--download`, `--checksum`, `--force-sync-large`, or
`--sync-only` to delegated providers. Also do not pass `--script*`,
`--fresh-pr`, `--full-resync`, or `--env-helper` there. Crabbox rejects these
because the provider owns sync or command transport. `--keep-on-failure` is OK
for delegated one-shots when you need to inspect a failed lease.
## Efficient Bug E2E Verification
Use the smallest Crabbox lane that proves the reported user path, not just the
@@ -149,8 +233,8 @@ Pick the lane by symptom:
- Docker/setup/install bug: build a package tarball and run the matching
`scripts/e2e/*-docker.sh` or package script. This proves npm packaging,
install paths, runtime deps, config writes, and container behavior.
- Provider/model/auth bug: prefer true live E2E. First source local Mac
`~/.profile`, then inject the single needed key into Crabbox if needed. Scrub
- Provider/model/auth bug: prefer true live E2E. Use the configured secret
workflow, then inject the single needed key into Crabbox if needed. Scrub
unrelated provider env vars in the child command so interactive defaults do
not drift to another provider. If only a dummy key is used, label the proof
narrowly, e.g. "UI/install path only; live provider auth not exercised."
@@ -179,6 +263,13 @@ Efficient flow:
Keep it efficient:
- Reuse existing E2E scripts and helper assertions before writing ad hoc shell.
- Use `--script <file>` or `--script-stdin` for multi-line E2E commands instead
of quote-heavy `--shell` strings on direct SSH providers.
- Use `--fresh-pr <pr>` when validating an upstream PR in isolation from the
local dirty tree. Add `--apply-local-patch` only when testing a local fixup on
top of that PR.
- Use `--full-resync` before replacing a warmed direct-provider lease when the
remote workdir or sync fingerprint appears stale.
- Use one-shot Crabbox for a single proof; use a reusable Testbox only when
several commands must share built images, installed packages, or live state.
- Prefer `OPENCLAW_CURRENT_PACKAGE_TGZ` with Docker/package lanes when testing a
@@ -189,6 +280,31 @@ Keep it efficient:
- Include `--timing-json` on broad or flaky runs when command duration or sync
behavior matters.
Before/after PR proof on delegated Testbox:
- For PRs that should prove "broken before, fixed after", compare base and PR
on the same Testbox when practical. Fetch both refs, create detached temp
worktrees under `/tmp`, install in each, then run the same harness twice.
- Do not checkout base/PR refs in the synced repo root. Delegated Testbox sync
may leave the root dirty with local files; `git checkout` can abort or mix
proof state.
- Temp harness files under `/tmp` do not resolve repo packages by default. Put
the harness inside the worktree, or in ESM use
`createRequire(path.join(process.cwd(), "package.json"))` before requiring
workspace deps such as `@lydell/node-pty`.
- For full-screen TUI/CLI bugs, a PTY harness is stronger than helper-only
assertions. Use a real PTY, wait for visible lifecycle markers, send input,
then send control keys and assert process exit/stuck behavior.
- When validating a rebased local branch before push, remember delegated sync
usually validates synced file content on a detached dirty checkout, not a
remote commit object. Record the local head SHA, changed files, Testbox id,
and final success markers; after pushing, ensure the pushed SHA has the same
file content.
- If GitHub CI is still queued but the exact changed content passed Testbox
`pnpm check:changed`, `pnpm check:test-types`, and the real E2E proof, it is
reasonable to merge once required checks allow it. Note any still-running
unrelated shards in the proof comment instead of waiting forever.
Interactive CLI/onboarding:
- For full-screen or prompt-heavy CLI flows, run the target command inside tmux
@@ -249,10 +365,17 @@ Useful WebVNC commands:
```sh
../crabbox/bin/crabbox webvnc --provider hetzner --id <cbx_id-or-slug> --open
../crabbox/bin/crabbox webvnc --provider hetzner --id <cbx_id-or-slug> --daemon --open
../crabbox/bin/crabbox webvnc --provider hetzner --id <cbx_id-or-slug> --status
../crabbox/bin/crabbox webvnc --provider hetzner --id <cbx_id-or-slug> --stop
../crabbox/bin/crabbox screenshot --provider hetzner --id <cbx_id-or-slug> --output desktop.png
../crabbox/bin/crabbox webvnc daemon start --provider hetzner --id <cbx_id-or-slug> --open
../crabbox/bin/crabbox webvnc daemon status --provider hetzner --id <cbx_id-or-slug>
../crabbox/bin/crabbox webvnc daemon stop --provider hetzner --id <cbx_id-or-slug>
../crabbox/bin/crabbox webvnc status --provider hetzner --id <cbx_id-or-slug>
../crabbox/bin/crabbox webvnc reset --provider hetzner --id <cbx_id-or-slug> --open
../crabbox/bin/crabbox desktop doctor --provider hetzner --id <cbx_id-or-slug>
../crabbox/bin/crabbox desktop click --provider hetzner --id <cbx_id-or-slug> --x 640 --y 420
../crabbox/bin/crabbox desktop paste --provider hetzner --id <cbx_id-or-slug> --text "user@example.com"
../crabbox/bin/crabbox desktop key --provider hetzner --id <cbx_id-or-slug> ctrl+l
../crabbox/bin/crabbox artifacts collect --id <cbx_id-or-slug> --all --output artifacts/<slug>
../crabbox/bin/crabbox artifacts publish --dir artifacts/<slug> --pr <number>
```
`desktop launch --webvnc --open` is usually the nicest one-shot: it starts the
@@ -285,7 +408,11 @@ Common Crabbox-only failures:
- Slug/claim confusion: use the raw `tbx_...` id, or run one-shot without
`--id`.
- Sync/timing bug: add `--debug --timing-json`; capture the final JSON and the
printed Actions URL.
printed Actions URL. Large sync warnings now include top source directories
by file count and a hint to update `.crabboxignore` / `sync.exclude`; inspect
those before reaching for `--force-sync-large`. Quiet rsync watchdogs and SSH
timeouts now print `next_action=` hints; follow them, usually `--full-resync`
first and a fresh lease second.
- Cleanup uncertainty: run `blacksmith testbox list` and stop only boxes you
created.
- Testbox queued/capacity pressure: do not convert a broad changed gate or full
@@ -427,7 +554,10 @@ crabbox run --id <lease> --shell -- 'DISPLAY=:99 xdotool search --onlyvisible --
crabbox status --id <id-or-slug> --wait
crabbox inspect --id <id-or-slug> --json
crabbox sync-plan
crabbox history --limit 20
crabbox history --lease <id-or-slug>
crabbox attach <run_id>
crabbox events <run_id> --json
crabbox logs <run_id>
crabbox results <run_id>
crabbox cache stats --id <id-or-slug>

View File

@@ -0,0 +1,114 @@
---
name: openclaw-debugging
description: Debug OpenClaw model, provider, tool-surface, code-mode, streaming, and live/Crabbox behavior by choosing the right logs, probes, and proof path before changing code.
---
# OpenClaw Debugging
Use this skill when OpenClaw behavior differs between local tests, live models,
providers, code mode, Tool Search, Crabbox, or CI, and the next move should be a
debug signal rather than a guess.
## Read First
- `docs/logging.md` for log files, `openclaw logs`, and targeted debug flags.
- `docs/reference/test.md` for local test commands.
- `docs/reference/code-mode.md` for code-mode exec/wait and tool catalog rules.
- Use `$openclaw-testing` for choosing test lanes.
- Use `$crabbox` for broad, Docker, package, Linux, live-key, or CI-parity proof.
## Default Loop
1. State the suspected boundary: config, tool construction, provider payload,
fetch, stream/SSE, transcript replay, worker/runtime, package/dist, or CI.
2. Add or enable the narrowest signal that proves that boundary.
3. Reproduce with the same provider/model/config. Do not randomly switch models
unless the model itself is the variable being tested.
4. Compare configured state with actual run activation.
5. Patch the root cause.
6. Rerun the exact failing probe, then broaden only if the contract requires it.
## Model Transport Logs
Use targeted env flags instead of global debug when the model request shape or
stream timing matters:
```bash
OPENCLAW_DEBUG_MODEL_TRANSPORT=1 openclaw gateway
OPENCLAW_DEBUG_MODEL_PAYLOAD=tools OPENCLAW_DEBUG_SSE=events openclaw gateway
OPENCLAW_DEBUG_MODEL_PAYLOAD=full-redacted OPENCLAW_DEBUG_SSE=peek openclaw gateway
```
Useful flags:
- `OPENCLAW_DEBUG_MODEL_TRANSPORT=1`: request start, fetch response, SDK
headers, first SSE event, stream done, and transport errors at `info`.
- `OPENCLAW_DEBUG_MODEL_PAYLOAD=summary`: bounded payload summary.
- `OPENCLAW_DEBUG_MODEL_PAYLOAD=tools`: all model-facing tool names.
- `OPENCLAW_DEBUG_MODEL_PAYLOAD=full-redacted`: capped, redacted JSON payload.
Use only while debugging; prompts/message text may still appear.
- `OPENCLAW_DEBUG_SSE=events`: first-event and stream-completion timing.
- `OPENCLAW_DEBUG_SSE=peek`: first five redacted SSE events.
- `OPENCLAW_DEBUG_CODE_MODE=1`: code-mode tool-surface diagnostics.
Watch logs with:
```bash
openclaw logs --follow
```
## Common Boundaries
- **Config vs activation:** config can be enabled while the run disables tools,
is raw, has an empty allowlist, or lacks model tool support. Check the actual
visible tools before enforcing provider payload invariants.
- **Tool surface:** inspect final model-visible tool names, not only the tool
registry or config. Code mode means exactly `exec` and `wait` only after it
actually activates.
- **Provider payload:** log fields, model id, service tier, reasoning, input
size, metadata keys, prompt-cache key presence, and tool names before SDK
call.
- **Fetch vs SSE:** fetch response proves HTTP headers arrived; first SSE event
proves provider body progress. A gap here is a stream/body/provider issue, not
tool execution.
- **Worker/dist:** run `pnpm build` when touching workers, dynamic imports,
package exports, lazy runtime boundaries, or published paths.
- **Live keys:** use the configured secret workflow for missing provider keys
before saying live proof is blocked. Env checks are presence-only; never print
secrets.
## Code Pointers
- Model payload + Responses stream:
`src/agents/openai-transport-stream.ts`
- Guarded fetch/timing:
`src/agents/provider-transport-fetch.ts`
- OpenAI/Codex provider wrappers:
`src/agents/pi-embedded-runner/openai-stream-wrappers.ts`
- Tool construction, Tool Search, code-mode activation:
`src/agents/pi-embedded-runner/run/attempt.ts`
- Code-mode runtime and worker:
`src/agents/code-mode.ts`
`src/agents/code-mode.worker.ts`
- Tool Search catalog:
`src/agents/tool-search.ts`
## Proof Choice
- Single helper/payload bug: local targeted Vitest.
- Docs/logging-only: `pnpm check:docs` and `git diff --check`.
- Worker/dist/lazy import/package surface: targeted tests plus `pnpm build`.
- Live provider/model behavior: same provider/model with debug flags and a real
key if available.
- Docker/package/Linux/CI-parity: `$crabbox`.
- CI failure: exact SHA, relevant job only, logs only after failure/completion.
## Output Habit
Report:
- boundary tested
- exact command/env shape, redacted
- observed signal, such as tool names or first SSE event timing
- fix location
- narrow proof and any remaining risk

View File

@@ -0,0 +1,4 @@
interface:
display_name: "OpenClaw Debugging"
short_description: "Debug model, tool, stream, and live behavior"
default_prompt: "Use $openclaw-debugging to identify the right OpenClaw debug boundary, turn on targeted logs, and choose the narrowest local or Crabbox proof."

View File

@@ -42,16 +42,20 @@ Choose the page type before writing:
Use this default topic page structure:
1. Title: name the major entity or surface.
2. Overview: explain what it is, what it owns, and what it does not own.
2. Opening overview: start with a few unheaded sentences that explain what it
is, what it owns, and what it does not own. Do not add a `## Overview`
heading unless the page is itself an overview index.
3. Requirements: include only when setup needs specific accounts, versions,
permissions, plugins, operating systems, or credentials.
4. Quickstart: show the recommended setup path and smallest reliable verification.
5. Configuration: show the minimum configuration needed to use the surface,
common variants users must choose between, and where each option is set:
CLI, config file, environment variable, plugin manifest, dashboard, or API.
6. Subtopics: organize the entity's major concepts, workflows, and decisions by
reader intent.
7. Troubleshooting: diagnose common observable failures.
6. Major subtopics: organize the entity's major concepts, workflows, and
decisions by reader intent. Put each major subtopic under its own heading;
do not wrap them in a generic `## Subtopics` section.
7. Troubleshooting: diagnose common observable failures under an explicit
`## Troubleshooting` heading.
8. Related: link to guides, references, commands, concepts, and adjacent topics.
Topic pages may be longer than quickstarts, but they should not become exhaustive

View File

@@ -56,7 +56,7 @@ Use this skill for Parallels guest workflows and smoke interpretation. Do not lo
- For unpublished targets, pack the candidate on the host, serve the `.tgz` over the harness HTTP server, and point the guest updater at that served package. Prefer `openclaw update --tag http://<host-ip>:<port>/openclaw-<version>.tgz --yes --json`; when channel persistence also matters, pass `--channel <stable|beta>` and set `OPENCLAW_UPDATE_PACKAGE_SPEC` to the same served URL in the guest update environment. The command under test must still be `openclaw update`, not direct npm.
- For unpublished local-fix validation, remember the old baseline updater code still controls the first hop. A fix that lives only in the new updater code cannot change that already-running old process; the served candidate must either keep package/plugin metadata compatible with the baseline host or the baseline itself must include the updater fix.
- For beta/stable verification, resolve the tag immediately before the run (`npm view openclaw@beta version dist.tarball` or `npm view openclaw@latest ...`). Tags can move while a long VM matrix is already running; restart the matrix when the intended prerelease appears after an earlier registry 404/tag-lag check.
- Source Peter's profile in the host shell (`set -a; source "$HOME/.profile"; set +a`) before OpenAI/Anthropic lanes. Do not print profile contents or env dumps; pass provider secrets through the guest exec environment.
- Use the configured secret workflow to inject only the provider keys needed by OpenAI/Anthropic lanes. Do not print secrets or env dumps; pass provider secrets through the guest exec environment.
- Same-guest update verification should set the default model explicitly to `openai/gpt-5.4` before the agent turn and use a fresh explicit `--session-id` so old session model state does not leak into the check.
- The aggregate npm-update wrapper must resolve the Linux VM with the same Ubuntu fallback policy as `parallels-linux-smoke.sh` before both fresh and update lanes. Treat any Ubuntu guest with major version `>= 24` as acceptable when the exact default VM is missing, preferring the closest version match. On Peter's current host today, missing `Ubuntu 24.04.3 ARM64` should fall back to `Ubuntu 25.10`.
- On macOS same-guest update checks, restart the gateway after the npm upgrade before `gateway status` / `agent`; launchd can otherwise report a loaded service while the old process has exited and the fresh process is not RPC-ready yet.

View File

@@ -227,7 +227,9 @@ pnpm openclaw qa manual \
- Treat the concrete Codex model name as user/config input; do not hardcode it in source, docs examples, or scenarios.
- Live QA preserves `CODEX_HOME` so Codex CLI auth/config works while keeping `HOME` and `OPENCLAW_HOME` sandboxed.
- Mock QA should scrub `CODEX_HOME`.
- If Codex returns fallback/auth text every turn, first check `CODEX_HOME`, `~/.profile`, and gateway child logs before changing scenario assertions.
- If Codex returns fallback/auth text every turn, first check `CODEX_HOME`,
relevant secret-backed auth, and gateway child logs before changing
scenario assertions.
- For model comparison, include `codex-cli/<codex-model>` as another candidate in `qa character-eval`; the report should label it as an opaque model name.
## Repo facts

View File

@@ -0,0 +1,196 @@
---
name: openclaw-refactor-docs
description: Refactor an existing OpenClaw docs page with source-audited preservation, restructuring, and verification.
---
# OpenClaw Refactor Docs
## Overview
Use this skill when the user gives a target OpenClaw docs page and asks to
rewrite, refactor, reorganize, split, shorten, or improve it.
This skill builds on `openclaw-docs`: use that skill for style, page types,
structure, examples, discoverability, and verification. This skill adds the
rewrite workflow needed to avoid losing accurate behavior during a major docs
refactor.
## Inputs
Required:
- A target docs page path, such as `docs/plugins/codex-harness.md`.
Optional:
- Desired page type, such as topic page, guide, reference, or troubleshooting.
- Specific goals, such as shorter main page, move details to reference pages, or
align with current CLI behavior.
- Related source files, schemas, commands, tests, specs, or PRs.
If the target page is missing or ambiguous, ask one concise question before
editing. Otherwise, proceed.
## Working Contract
Refactor the target page to be more useful, concise, and comprehensive within
its stated scope.
Do not treat a rewrite as permission to discard behavior facts. Preserve,
verify, move, or explicitly retire existing material. Incorrect docs are worse
than verbose docs.
Prefer this split:
- Topic or guide pages cover the 80/20 path, decisions readers must make, safe
setup, smallest reliable verification, common failures, and links onward.
- Reference pages cover exhaustive fields, defaults, enums, limits, precedence
rules, API contracts, narrow internals, and rare debugging details.
- Troubleshooting pages start from observable symptoms and map to checks,
causes, and fixes.
## Workflow
### 1. Load the doc standard
Read `../openclaw-docs/SKILL.md` first. Apply its page-type, style,
examples, navigation, and verification guidance throughout the refactor.
Run `pnpm docs:list` when available, then read only the target page and the
likely entry points, references, or related pages needed for the refactor.
### 2. Classify the page
Before editing, decide the intended page type from `openclaw-docs`.
If the current page mixes page types, choose the main page type and plan where
the other material belongs:
- Move exhaustive contracts to an existing or new reference page.
- Move symptom-driven material to an existing or new troubleshooting page.
- Move narrow setup workflows to a guide when they interrupt the main path.
- Keep concise routing, decision, and safety details in the main page when
readers need them to complete the workflow.
### 3. Preserve and audit existing facts
Create a working inventory from the old page before rewriting. Include:
- Config fields, flags, commands, slash commands, env vars, defaults, enums,
nullable values, and constraints.
- Precedence rules, fallback behavior, caps, limits, rate limits, timeouts,
lifecycle states, queueing behavior, and compatibility rules.
- Auth, permission, approval, sandbox, safety, privacy, and destructive-action
behavior.
- Setup requirements, supported versions, dependencies, operating systems,
credentials, and account requirements.
- Error messages, troubleshooting symptoms, diagnostics, and recovery steps.
- Examples, expected output, command routing tables, and cross-links.
For each fact, choose one outcome:
- Keep it in the refactored target page.
- Move it to a specific existing page.
- Move it to a specific new page.
- Delete it because current source proves it is obsolete or out of scope.
Do not infer defaults, permissions, policy, timeout behavior, or safety posture
from names or intent. Verify them.
### 4. Find source of truth
Use the nearest authoritative source for each behavior-sensitive claim:
- Public schema, plugin manifest, generated config docs, or exported types for
config fields.
- CLI implementation, slash-command handlers, help text, and command tests for
commands and flags.
- Runtime source and tests for lifecycle, queueing, permission, fallback,
timeout, and provider behavior.
- Protocol docs, SDK facades, and contract tests for APIs and plugin surfaces.
- Existing docs only as secondary evidence unless the target is purely
conceptual.
If a page promises a reference, compare its tables against the schema,
manifest, CLI help, generated docs, or exported types. Missing public fields,
defaults, precedence rules, caps, or side effects are correctness bugs.
### 5. Plan moved material
When moving detail out of the target page, record the destination before
editing:
- Existing page: name the page and section.
- New page: choose the page type, slug, title, frontmatter summary,
`doc-schema-version: 1`, and `read_when` hints.
- Target page: keep a short summary and link from the point where readers need
the deeper detail.
Avoid duplicate truth. If the same contract appears in multiple places, choose
one canonical page and link to it.
### 6. Rewrite
Rewrite in this order:
1. Make the first screen answer what the reader can do and why this page exists.
2. Put the recommended path before alternatives.
3. Keep only decision-making and common operational detail in the main flow.
4. Move exhaustive tables and rare details to the planned reference pages.
5. Preserve concise routing tables when they help readers choose commands,
config paths, harnesses, plugins, providers, or references.
6. Add troubleshooting from observable symptoms, not internal guesses.
7. Link related concepts, guides, references, diagnostics, and adjacent tools.
Add `doc-schema-version: 1` to the YAML frontmatter of every docs page that the
refactor migrates, creates, or materially rewrites. Apply it only to docs page
files, not `docs.json`, glossary JSON, or other non-page metadata. If a
migrated page is generated, update the generator so regeneration preserves the
marker instead of hand-editing generated output.
Do not leave placeholders such as "TODO", "TBD", or "see docs" unless the user
explicitly asks for a draft.
### 7. Compare old and new
After editing, compare the old and new page:
- Confirm all behavior-sensitive facts were kept, moved, or intentionally
deleted with source-backed reason.
- Check that the main page still covers the 80/20 scenario end to end.
- Check that reference pages remain exhaustive for the scope they claim.
- Check that links from the target page reach moved details.
- Check that headings are stable, searchable, and action-oriented.
If the refactor deliberately removes relevant material, say where it went or why
it was removed in the final report.
### 8. Verify
Run the smallest reliable docs checks for the touched surface:
- `pnpm docs:list`
- `git diff --check -- <touched-files>`
- Targeted `pnpm exec oxfmt --check --threads=1 <touched-files>`
- `pnpm docs:check-mdx`
- `pnpm docs:check-links`
- `pnpm docs:check-i18n-glossary` when link text, navigation, labels, or glossary
surfaces changed
- Generated-doc checks when schemas, generated config docs, API docs, or
generated baselines are touched
Run commands and examples from the page whenever feasible. If you cannot verify
a behavior-sensitive claim, either remove the claim, mark the uncertainty in the
work-in-progress report, or ask for the missing source.
## Final Report
Report:
- What changed in the target page.
- What details moved and their destination pages.
- What source-of-truth checks backed behavior-sensitive claims.
- What validation ran and what failed for unrelated reasons.
Do not include a long rewrite diary. Lead with remaining risks only if there are
any.

View File

@@ -65,8 +65,8 @@ Use this skill for release and publish-time workflow. Keep ordinary development
stable base version section, for example `v2026.4.20-beta.1` uses
`## 2026.4.20` release notes.
- When any beta or stable release is live, make a best-effort Discord
announcement using Peter's bot token from `.profile`; do not block or roll
back the release if the announcement fails.
announcement using the configured secret workflow; do not block or roll back
the release if the announcement fails.
- When asked to announce on X, use `~/Projects/bird/bird` and follow the
release tweet style below.
@@ -288,13 +288,11 @@ node --import tsx scripts/openclaw-npm-postpublish-verify.ts <published-version>
## Check all relevant release builds
- Always validate the OpenClaw npm release path before creating the tag.
- Source Peter's profile before live release validation so OpenAI and Anthropic
credentials are available without printing secrets:
`set -a; source "$HOME/.profile"; set +a`.
- Use the configured secret workflow before live release validation so OpenAI
and Anthropic credentials are available without printing secrets.
- Parallels validation and any local live model QA for this train must use both
`OPENAI_API_KEY` and `ANTHROPIC_API_KEY`. If either is missing after sourcing
`.profile`, stop before starting those local long lanes and report the
missing key.
`OPENAI_API_KEY` and `ANTHROPIC_API_KEY`. If either cannot be injected, stop
before starting those local long lanes and report the missing key.
- Live credentialed channel QA is the GitHub Actions workflow
`QA-Lab - All Lanes` (`.github/workflows/qa-live-telegram-convex.yml`), not a
local substitute. Dispatch it from Actions against the release tag and wait
@@ -592,8 +590,7 @@ node --import tsx scripts/openclaw-npm-postpublish-verify.ts <published-version>
If a pre-npm lane fails before any tag/package leaves the machine, fix and
rerun the same intended beta attempt. Repeat up to the operator's
authorized beta-attempt limit, normally 4.
24. Announce the beta/stable release on Discord best-effort using Peter's bot
token from `.profile`.
24. Announce the beta/stable release on Discord best-effort using the configured secret workflow.
25. If the operator requested beta only, stop after beta verification and the
announcement.
26. If the stable release was published to `beta`, use the light stable

View File

@@ -28,6 +28,9 @@ OPENCLAW_GATEWAY_TOKEN=
# OPENCLAW_STATE_DIR=~/.openclaw
# OPENCLAW_CONFIG_PATH=~/.openclaw/openclaw.json
# OPENCLAW_HOME=~
# Docker setup stores auth profile encryption key material outside the mounted
# OpenClaw state dir and mounts this host directory into the container.
# OPENCLAW_AUTH_PROFILE_SECRET_DIR=/absolute/path/to/.openclaw-auth-profile-secrets
# Allowlist of extra directories that `$include` directives in openclaw.json may
# resolve files from. Path-list separated (':' on POSIX, ';' on Windows). Each

2
.github/CODEOWNERS vendored
View File

@@ -11,6 +11,8 @@
/.github/workflows/codeql.yml @openclaw/openclaw-secops
/.github/workflows/codeql-android-critical-security.yml @openclaw/openclaw-secops
/.github/workflows/codeql-critical-quality.yml @openclaw/openclaw-secops
/.github/workflows/dependency-change-awareness.yml @openclaw/openclaw-secops
/test/scripts/dependency-change-awareness-workflow.test.ts @openclaw/openclaw-secops
/src/security/ @openclaw/openclaw-secops
/src/secrets/ @openclaw/openclaw-secops
/src/config/*secret*.ts @openclaw/openclaw-secops

View File

@@ -24,18 +24,18 @@ Inputs are provided as environment variables:
- `BASELINE_SHA`
- `CANDIDATE_REF`
- `CANDIDATE_SHA`
- `MANTIS_CANDIDATE_TRUST`
- `MANTIS_OUTPUT_DIR`
- `MANTIS_INSTRUCTIONS`
- `CRABBOX_PROVIDER`
- `OPENCLAW_TELEGRAM_USER_PROOF_CMD`
- optional `CRABBOX_LEASE_ID`
Required workflow:
1. Read `.agents/skills/telegram-crabbox-e2e-proof/SKILL.md`.
2. Inspect the PR with `gh pr view "$MANTIS_PR_NUMBER"` and
`gh pr diff "$MANTIS_PR_NUMBER"` when `MANTIS_PR_NUMBER` is set. If the run
came from workflow dispatch without a PR number, inspect
`BASELINE_SHA..CANDIDATE_SHA`.
`gh pr diff "$MANTIS_PR_NUMBER"`.
3. Decide what Telegram message, mock model response, command, callback, button,
media, or sequence best proves the PR. Use `MANTIS_INSTRUCTIONS` as extra
maintainer guidance, not as a replacement for reading the PR.
@@ -43,9 +43,22 @@ Required workflow:
`.artifacts/qa-e2e/mantis/telegram-desktop-proof-worktrees/baseline` and
`.artifacts/qa-e2e/mantis/telegram-desktop-proof-worktrees/candidate`, then
install and build each worktree with the repo's normal `pnpm` commands.
If `MANTIS_CANDIDATE_TRUST` is `fork-pr-head`, treat the
candidate worktree as untrusted fork code: do not pass GitHub, OpenAI,
Crabbox, Convex, or other workflow secrets into candidate install, build, or
runtime commands. The candidate SUT may receive only the proof runner's
short-lived Telegram bot token, generated local config/state paths, and mock
model key needed for this isolated proof.
5. In each worktree, run the real-user Telegram Crabbox proof flow from the
skill. Use the same proof idea for baseline and candidate. You may iterate
and rerun if the visual result is not convincing.
skill with `$OPENCLAW_TELEGRAM_USER_PROOF_CMD`; do not run
`pnpm qa:telegram-user:crabbox` directly. The proof command comes from the
trusted workflow checkout while the current directory controls which
baseline or candidate OpenClaw build is tested. Use
`$OPENCLAW_TELEGRAM_USER_DRIVER_SCRIPT`, the workflow-provided `crabbox`
binary, and the workflow-provided local `ffmpeg`/`ffprobe`; do not generate,
install, or patch replacement proof tooling during the run. Use the same
proof idea for baseline and candidate. You may iterate and rerun if the
visual result is not convincing.
6. Open Telegram Desktop directly to the newest relevant message with the
runner `view` command before finishing each recording. Keep the chat scrolled
to the bottom so new proof messages appear in-frame.

88
.github/labeler.yml vendored
View File

@@ -454,3 +454,91 @@
- changed-files:
- any-glob-to-any-file:
- "extensions/gradium/**"
"extensions: amazon-bedrock":
- changed-files:
- any-glob-to-any-file:
- "extensions/amazon-bedrock/**"
"extensions: anthropic-vertex":
- changed-files:
- any-glob-to-any-file:
- "extensions/anthropic-vertex/**"
"extensions: brave":
- changed-files:
- any-glob-to-any-file:
- "extensions/brave/**"
"extensions: chutes":
- changed-files:
- any-glob-to-any-file:
- "extensions/chutes/**"
"extensions: diffs":
- changed-files:
- any-glob-to-any-file:
- "extensions/diffs/**"
"extensions: elevenlabs":
- changed-files:
- any-glob-to-any-file:
- "extensions/elevenlabs/**"
"extensions: firecrawl":
- changed-files:
- any-glob-to-any-file:
- "extensions/firecrawl/**"
"extensions: github-copilot":
- changed-files:
- any-glob-to-any-file:
- "extensions/github-copilot/**"
"extensions: google":
- changed-files:
- any-glob-to-any-file:
- "extensions/google/**"
"extensions: microsoft":
- changed-files:
- any-glob-to-any-file:
- "extensions/microsoft/**"
"extensions: mistral":
- changed-files:
- any-glob-to-any-file:
- "extensions/mistral/**"
"extensions: ollama":
- changed-files:
- any-glob-to-any-file:
- "extensions/ollama/**"
"extensions: opencode":
- changed-files:
- any-glob-to-any-file:
- "extensions/opencode/**"
"extensions: opencode-go":
- changed-files:
- any-glob-to-any-file:
- "extensions/opencode-go/**"
"extensions: openrouter":
- changed-files:
- any-glob-to-any-file:
- "extensions/openrouter/**"
"extensions: openshell":
- changed-files:
- any-glob-to-any-file:
- "extensions/openshell/**"
"extensions: perplexity":
- changed-files:
- any-glob-to-any-file:
- "extensions/perplexity/**"
"extensions: sglang":
- changed-files:
- any-glob-to-any-file:
- "extensions/sglang/**"
"extensions: thread-ownership":
- changed-files:
- any-glob-to-any-file:
- "extensions/thread-ownership/**"
"extensions: vllm":
- changed-files:
- any-glob-to-any-file:
- "extensions/vllm/**"
"extensions: xai":
- changed-files:
- any-glob-to-any-file:
- "extensions/xai/**"
"extensions: zai":
- changed-files:
- any-glob-to-any-file:
- "extensions/zai/**"

View File

@@ -124,5 +124,6 @@ jobs:
- name: Run Testbox
uses: useblacksmith/run-testbox@5ca05834db1d3813554d1dd109e5f2087a8d7cbc
if: always()
continue-on-error: true
env:
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: "true"

View File

@@ -26,7 +26,7 @@ permissions:
concurrency:
group: ${{ github.event_name == 'workflow_dispatch' && format('{0}-manual-v1-{1}', github.workflow, github.run_id) || (github.event_name == 'pull_request' && format('{0}-v7-{1}', github.workflow, github.event.pull_request.number) || (github.repository == 'openclaw/openclaw' && format('{0}-v7-{1}', github.workflow, github.ref) || format('{0}-v7-{1}-{2}', github.workflow, github.ref, github.sha))) }}
cancel-in-progress: ${{ github.event_name != 'workflow_dispatch' }}
cancel-in-progress: ${{ github.event_name == 'pull_request' }}
env:
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: "true"

View File

@@ -225,11 +225,17 @@ jobs:
"" \
"Command router queued. I will update this comment with the next step.")"
status_payload="$(jq -nc --arg body "$status_body" '{body:$body}')"
status_response="$(GH_TOKEN="$TARGET_TOKEN" gh api \
status_err="$(mktemp)"
if status_response="$(GH_TOKEN="$TARGET_TOKEN" gh api \
"repos/$TARGET_REPO/issues/$ITEM_NUMBER/comments" \
--method POST \
--input - <<< "$status_payload")"
status_comment_id="$(jq -r '.id // empty' <<< "$status_response")"
--input - <<< "$status_payload" 2>"$status_err")"; then
status_comment_id="$(jq -r '.id // empty' <<< "$status_response")"
else
cat "$status_err" >&2
echo "::warning::Could not create ClawSweeper queued status comment; dispatching command router without one."
fi
rm -f "$status_err"
;;
esac
fi

View File

@@ -0,0 +1,171 @@
name: Dependency Change Awareness
on:
pull_request_target: # zizmor: ignore[dangerous-triggers] metadata-only workflow; no checkout or untrusted code execution
types: [opened, reopened, synchronize, ready_for_review]
permissions:
pull-requests: write
issues: write
concurrency:
group: dependency-change-awareness-${{ github.event.pull_request.number }}
cancel-in-progress: true
jobs:
dependency-change-awareness:
if: ${{ !github.event.pull_request.draft }}
runs-on: ubuntu-24.04
timeout-minutes: 5
steps:
- name: Label and comment on dependency changes
uses: actions/github-script@3a2844b7e9c422d3c10d287c895573f7108da1b3 # v9
with:
script: |
const marker = "<!-- openclaw:dependency-change-awareness -->";
const labelName = "dependencies-changed";
const maxListedFiles = 25;
const pullRequest = context.payload.pull_request;
if (!pullRequest) {
core.info("No pull_request payload found; skipping.");
return;
}
const isDependencyFile = (filename) =>
filename === "package.json" ||
filename === "pnpm-lock.yaml" ||
filename === "pnpm-workspace.yaml" ||
filename === "ui/package.json" ||
filename.startsWith("patches/") ||
/^packages\/[^/]+\/package\.json$/u.test(filename) ||
/^extensions\/[^/]+\/package\.json$/u.test(filename);
const sanitizeDisplayValue = (value) =>
String(value)
.replace(/[\u0000-\u001f\u007f]/gu, "?")
.slice(0, 240);
const markdownCode = (value) =>
`\`${sanitizeDisplayValue(value).replaceAll("`", "\\`")}\``;
const ignoreUnavailableWritePermission = (action) => (error) => {
if (error?.status === 403) {
core.warning(
`Skipping dependency change ${action}; token does not have issue write permission.`,
);
return;
}
if (error?.status === 404 || error?.status === 422) {
core.warning(`Dependency change ${action} is unavailable.`);
return;
}
throw error;
};
const files = await github.paginate(github.rest.pulls.listFiles, {
owner: context.repo.owner,
repo: context.repo.repo,
pull_number: pullRequest.number,
per_page: 100,
});
const dependencyFiles = files
.map((file) => file.filename)
.filter((filename) => typeof filename === "string" && isDependencyFile(filename))
.sort((left, right) => left.localeCompare(right));
const comments = await github.paginate(github.rest.issues.listComments, {
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: pullRequest.number,
per_page: 100,
});
const existingComment = comments.find(
(comment) =>
comment.user?.login === "github-actions[bot]" && comment.body?.includes(marker),
);
const labels = await github.paginate(github.rest.issues.listLabelsOnIssue, {
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: pullRequest.number,
per_page: 100,
});
const hasLabel = labels.some((label) => label.name === labelName);
if (dependencyFiles.length === 0) {
if (hasLabel) {
await github.rest.issues.removeLabel({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: pullRequest.number,
name: labelName,
}).catch(ignoreUnavailableWritePermission("label removal"));
}
if (existingComment) {
await github.rest.issues.deleteComment({
owner: context.repo.owner,
repo: context.repo.repo,
comment_id: existingComment.id,
}).catch(ignoreUnavailableWritePermission("comment deletion"));
}
await core.summary
.addHeading("Dependency Change Awareness")
.addRaw("No dependency-related file changes detected.")
.write();
core.info("No dependency-related file changes detected.");
return;
}
if (!hasLabel) {
await github.rest.issues.addLabels({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: pullRequest.number,
labels: [labelName],
}).catch(ignoreUnavailableWritePermission(`label "${labelName}" update`));
}
const listedFiles = dependencyFiles.slice(0, maxListedFiles);
const omittedCount = dependencyFiles.length - listedFiles.length;
const fileLines = listedFiles.map((filename) => `- ${markdownCode(filename)}`);
if (omittedCount > 0) {
fileLines.push(`- ${omittedCount} additional dependency-related files not shown`);
}
const body = [
marker,
"",
"### Dependency Changes Detected",
"",
"This PR changes dependency-related files. Maintainers should confirm these changes are intentional.",
"",
"Changed files:",
...fileLines,
"",
"Maintainer follow-up:",
"- Review whether the dependency changes are intentional.",
"- Inspect resolved package deltas when lockfile or workspace dependency policy changes are present.",
"- Run `pnpm deps:changes:report -- --base-ref origin/main --markdown /tmp/dependency-changes.md --json /tmp/dependency-changes.json` locally for detailed release-style evidence.",
].join("\n");
if (existingComment) {
await github.rest.issues.updateComment({
owner: context.repo.owner,
repo: context.repo.repo,
comment_id: existingComment.id,
body,
}).catch(ignoreUnavailableWritePermission("comment update"));
} else {
await github.rest.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: pullRequest.number,
body,
}).catch(ignoreUnavailableWritePermission("comment creation"));
}
await core.summary
.addHeading("Dependency Change Awareness")
.addRaw(`Detected ${dependencyFiles.length} dependency-related file change(s).`)
.addList(dependencyFiles.map((filename) => markdownCode(filename)))
.write();
core.notice(`Detected ${dependencyFiles.length} dependency-related file change(s).`);

View File

@@ -297,6 +297,7 @@ jobs:
echo "conclusion=${conclusion}" >> "$GITHUB_OUTPUT"
if [[ "$conclusion" != "success" ]]; then
gh run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true
exit 1
fi
}
@@ -396,6 +397,7 @@ jobs:
echo "conclusion=${conclusion}" >> "$GITHUB_OUTPUT"
if [[ "$conclusion" != "success" ]]; then
gh run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true
exit 1
fi
}
@@ -504,6 +506,7 @@ jobs:
echo "conclusion=${conclusion}" >> "$GITHUB_OUTPUT"
if [[ "$conclusion" != "success" ]]; then
gh run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true
exit 1
fi
}
@@ -726,6 +729,7 @@ jobs:
echo "conclusion=${conclusion}" >> "$GITHUB_OUTPUT"
if [[ "$conclusion" != "success" ]]; then
gh run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true
exit 1
fi
summary:
@@ -735,62 +739,6 @@ jobs:
runs-on: ubuntu-24.04
timeout-minutes: 5
steps:
- name: Request private evidence update
env:
RELEASE_PRIVATE_DISPATCH_TOKEN: ${{ secrets.OPENCLAW_RELEASES_PRIVATE_DISPATCH_TOKEN }}
TARGET_REF: ${{ inputs.ref }}
PACKAGE_SPEC: ${{ inputs.evidence_package_spec || inputs.npm_telegram_package_spec }}
GITHUB_RUN_ID_VALUE: ${{ github.run_id }}
RELEASE_CHECKS_RESULT: ${{ needs.release_checks.result }}
run: |
set -euo pipefail
if [[ "$RELEASE_CHECKS_RESULT" == "skipped" ]]; then
echo "Release checks were skipped by rerun group; skipping automatic private evidence update."
exit 0
fi
if [[ -z "${RELEASE_PRIVATE_DISPATCH_TOKEN// }" ]]; then
echo "OPENCLAW_RELEASES_PRIVATE_DISPATCH_TOKEN is not configured; skipping automatic private evidence update."
exit 0
fi
release_id="${TARGET_REF#refs/tags/}"
release_id="${release_id#v}"
if [[ "$PACKAGE_SPEC" =~ ^openclaw@(.+)$ ]]; then
release_id="${BASH_REMATCH[1]}"
fi
release_id="$(printf '%s' "$release_id" | tr '/:@ ' '----' | tr -cd 'A-Za-z0-9._-')"
if [[ -z "$release_id" ]]; then
echo "::error::Could not derive release evidence id from target ref '${TARGET_REF}'."
exit 1
fi
payload="$(
jq -cn \
--arg full_validation_run_id "$GITHUB_RUN_ID_VALUE" \
--arg release_id "$release_id" \
--arg release_ref "$TARGET_REF" \
--arg package_spec "$PACKAGE_SPEC" \
--arg notes "Automatically requested by Full Release Validation ${GITHUB_RUN_ID_VALUE} after child workflows completed; the parent summary re-checks current child run conclusions." \
'{
event_type: "openclaw_full_release_validation_completed",
client_payload: {
full_validation_run_id: $full_validation_run_id,
release_id: $release_id,
release_ref: $release_ref,
package_spec: $package_spec,
notes: $notes
}
}'
)"
curl --fail-with-body \
-X POST \
-H "Accept: application/vnd.github+json" \
-H "Authorization: Bearer ${RELEASE_PRIVATE_DISPATCH_TOKEN}" \
-H "X-GitHub-Api-Version: 2022-11-28" \
https://api.github.com/repos/openclaw/releases-private/dispatches \
-d "$payload"
- name: Verify child workflow results
env:
GH_TOKEN: ${{ github.token }}
@@ -969,3 +917,61 @@ jobs:
summarize_child_timing "npm_telegram" "$NPM_TELEGRAM_RUN_ID"
exit "$failed"
- name: Request private evidence update
env:
RELEASE_PRIVATE_DISPATCH_TOKEN: ${{ secrets.OPENCLAW_RELEASES_PRIVATE_DISPATCH_TOKEN }}
TARGET_REF: ${{ inputs.ref }}
PACKAGE_SPEC: ${{ inputs.evidence_package_spec || inputs.npm_telegram_package_spec }}
GITHUB_RUN_ID_VALUE: ${{ github.run_id }}
RELEASE_CHECKS_RESULT: ${{ needs.release_checks.result }}
run: |
set -euo pipefail
if [[ "$RELEASE_CHECKS_RESULT" == "skipped" ]]; then
echo "Release checks were skipped by rerun group; skipping automatic private evidence update."
exit 0
fi
if [[ -z "${RELEASE_PRIVATE_DISPATCH_TOKEN// }" ]]; then
echo "OPENCLAW_RELEASES_PRIVATE_DISPATCH_TOKEN is not configured; skipping automatic private evidence update."
exit 0
fi
release_id="${TARGET_REF#refs/tags/}"
release_id="${release_id#v}"
if [[ "$PACKAGE_SPEC" =~ ^openclaw@(.+)$ ]]; then
release_id="${BASH_REMATCH[1]}"
fi
release_id="$(printf '%s' "$release_id" | tr '/:@ ' '----' | tr -cd 'A-Za-z0-9._-')"
if [[ -z "$release_id" ]]; then
echo "::warning::Could not derive release evidence id from target ref '${TARGET_REF}'; skipping automatic private evidence update."
exit 0
fi
payload="$(
jq -cn \
--arg full_validation_run_id "$GITHUB_RUN_ID_VALUE" \
--arg release_id "$release_id" \
--arg release_ref "$TARGET_REF" \
--arg package_spec "$PACKAGE_SPEC" \
--arg notes "Automatically requested by Full Release Validation ${GITHUB_RUN_ID_VALUE} after child workflows completed; the parent summary re-checks current child run conclusions." \
'{
event_type: "openclaw_full_release_validation_completed",
client_payload: {
full_validation_run_id: $full_validation_run_id,
release_id: $release_id,
release_ref: $release_ref,
package_spec: $package_spec,
notes: $notes
}
}'
)"
if ! curl --fail-with-body \
-X POST \
-H "Accept: application/vnd.github+json" \
-H "Authorization: Bearer ${RELEASE_PRIVATE_DISPATCH_TOKEN}" \
-H "X-GitHub-Api-Version: 2022-11-28" \
https://api.github.com/repos/openclaw/releases-private/dispatches \
-d "$payload"; then
echo "::warning::Automatic private release evidence dispatch failed; child workflow validation remains authoritative."
fi

View File

@@ -5,19 +5,9 @@ on:
types: [created]
workflow_dispatch:
inputs:
baseline_ref:
description: Ref, tag, or SHA to capture as the before GIF
required: true
default: main
type: string
candidate_ref:
description: Ref, tag, or SHA to capture as the after GIF
required: true
default: main
type: string
pr_number:
description: Optional PR number to receive the QA evidence comment
required: false
description: PR number to capture
required: true
type: string
instructions:
description: Optional freeform proof instructions for the agent
@@ -37,18 +27,15 @@ on:
type: string
permissions:
actions: read
contents: write
issues: write
pull-requests: write
concurrency:
group: mantis-telegram-desktop-proof-${{ github.event.issue.number || inputs.pr_number || inputs.candidate_ref || github.run_id }}-${{ github.run_attempt }}
cancel-in-progress: false
env:
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: "true"
NODE_VERSION: "24.x"
PNPM_VERSION: "10.33.0"
PNPM_VERSION: "11.0.8"
OPENCLAW_BUILD_PRIVATE_QA: "1"
OPENCLAW_ENABLE_PRIVATE_QA_CLI: "1"
CRABBOX_REF: main
@@ -63,10 +50,10 @@ jobs:
(
github.event_name == 'issue_comment' &&
github.event.issue.pull_request &&
contains(github.event.issue.labels.*.name, 'mantis: telegram-visible-proof') &&
(
contains(github.event.comment.body, '@Mantis') ||
contains(github.event.comment.body, '@mantis') ||
contains(github.event.comment.body, '/mantis')
contains(github.event.comment.body, '@openclaw-mantis') ||
contains(github.event.comment.body, '/openclaw-mantis')
)
)
}}
@@ -103,7 +90,6 @@ jobs:
lease_id: ${{ steps.resolve.outputs.lease_id }}
pr_number: ${{ steps.resolve.outputs.pr_number }}
request_source: ${{ steps.resolve.outputs.request_source }}
should_run: ${{ steps.resolve.outputs.should_run }}
steps:
- name: Resolve refs and target PR
id: resolve
@@ -117,47 +103,11 @@ jobs:
core.info(`${name}=${value ?? ""}`);
}
if (eventName === "workflow_dispatch") {
const inputs = context.payload.inputs ?? {};
setOutput("should_run", "true");
setOutput("baseline_ref", inputs.baseline_ref || "main");
setOutput("candidate_ref", inputs.candidate_ref || "main");
setOutput("pr_number", inputs.pr_number || "");
setOutput("instructions", inputs.instructions || "");
setOutput("crabbox_provider", inputs.crabbox_provider || "aws");
setOutput("lease_id", inputs.crabbox_lease_id || "");
setOutput("request_source", "workflow_dispatch");
return;
}
if (eventName !== "issue_comment") {
core.setFailed(`Unsupported event: ${eventName}`);
return;
}
const issue = context.payload.issue;
const body = context.payload.comment?.body ?? "";
if (!issue?.pull_request) {
core.setFailed("Mantis issue_comment trigger requires a pull request comment.");
return;
}
const normalized = body.toLowerCase();
const requested =
(normalized.includes("@mantis") || normalized.includes("/mantis")) &&
normalized.includes("telegram") &&
(normalized.includes("desktop") || normalized.includes("native")) &&
normalized.includes("proof");
if (!requested) {
core.notice("Comment mentioned Mantis but did not request Telegram desktop proof.");
setOutput("should_run", "false");
setOutput("baseline_ref", "");
setOutput("candidate_ref", "");
setOutput("pr_number", "");
setOutput("instructions", "");
setOutput("crabbox_provider", "");
setOutput("lease_id", "");
setOutput("request_source", "unsupported_issue_comment");
const inputs = context.payload.inputs ?? {};
const prNumber =
eventName === "workflow_dispatch" ? inputs.pr_number : String(context.payload.issue?.number ?? "");
if (!prNumber) {
core.setFailed("Mantis Telegram desktop proof requires a pull request.");
return;
}
@@ -165,59 +115,40 @@ jobs:
const { data: pr } = await github.rest.pulls.get({
owner,
repo,
pull_number: issue.number,
pull_number: Number(prNumber),
});
let mergedBaseline = "";
let mergedCandidate = "";
if (pr.merged) {
const { data: commits } = await github.rest.pulls.listCommits({
owner,
repo,
pull_number: issue.number,
per_page: 100,
});
mergedCandidate = pr.merge_commit_sha || commits.at(-1)?.sha || "";
mergedBaseline = mergedCandidate && commits.length > 0 ? `${mergedCandidate}~${commits.length}` : "";
}
const baselineMatch = body.match(/(?:baseline|base)[\s:=]+([^\s`]+)/i);
const candidateMatch = body.match(/(?:candidate|head)[\s:=]+([^\s`]+)/i);
const providerMatch = body.match(/(?:provider|crabbox_provider)[\s:=]+([^\s`]+)/i);
const leaseMatch = body.match(/(?:lease|lease_id|crabbox_lease_id)[\s:=]+([^\s`]+)/i);
const provider = providerMatch?.[1] || "aws";
const body = eventName === "workflow_dispatch" ? inputs.instructions || "" : context.payload.comment?.body || "";
const provider = inputs.crabbox_provider || "aws";
if (!["aws", "hetzner"].includes(provider)) {
core.setFailed(`Unsupported Crabbox provider for Mantis Telegram desktop proof: ${provider}`);
return;
}
const rawCandidate = candidateMatch?.[1];
const candidate =
rawCandidate && !["head", "pr", "pr-head"].includes(rawCandidate.toLowerCase())
? rawCandidate
: mergedCandidate || pr.head.sha;
setOutput("should_run", "true");
setOutput("baseline_ref", baselineMatch?.[1] || mergedBaseline || "main");
setOutput("candidate_ref", candidate);
setOutput("pr_number", String(issue.number));
setOutput("baseline_ref", pr.base.sha);
setOutput("candidate_ref", pr.head.sha);
setOutput("pr_number", String(pr.number));
setOutput("instructions", body);
setOutput("crabbox_provider", provider);
setOutput("lease_id", leaseMatch?.[1] || "");
setOutput("request_source", "issue_comment");
setOutput("lease_id", inputs.crabbox_lease_id || "");
setOutput("request_source", eventName);
await github.rest.reactions.createForIssueComment({
owner,
repo,
comment_id: context.payload.comment.id,
content: "eyes",
}).catch((error) => core.warning(`Could not add eyes reaction: ${error.message}`));
if (eventName === "issue_comment") {
await github.rest.reactions.createForIssueComment({
owner,
repo,
comment_id: context.payload.comment.id,
content: "eyes",
}).catch((error) => core.warning(`Could not add eyes reaction: ${error.message}`));
}
validate_refs:
name: Validate selected refs
needs: resolve_request
if: ${{ needs.resolve_request.outputs.should_run == 'true' }}
runs-on: ubuntu-24.04
outputs:
baseline_revision: ${{ steps.validate.outputs.baseline_revision }}
candidate_revision: ${{ steps.validate.outputs.candidate_revision }}
candidate_trust: ${{ steps.validate.outputs.candidate_trust }}
steps:
- name: Checkout harness ref
uses: actions/checkout@v6
@@ -241,55 +172,56 @@ jobs:
git fetch --no-tags origin "+refs/pull/${PR_NUMBER}/head:refs/remotes/origin/pr/${PR_NUMBER}" || true
fi
validate_ref() {
local label="$1"
resolve_commit() {
local input_ref="$2"
local revision=""
local reason=""
if ! revision="$(git rev-parse --verify "${input_ref}^{commit}" 2>/dev/null)"; then
echo "${label} ref '${input_ref}' is not available in the workflow checkout." >&2
exit 1
fi
if git merge-base --is-ancestor "$revision" refs/remotes/origin/main; then
reason="main-ancestor"
elif git tag --points-at "$revision" | grep -Eq '^v'; then
reason="release-tag"
else
local pr_head_count
pr_head_count="$(
gh api \
-H "Accept: application/vnd.github+json" \
"repos/${GITHUB_REPOSITORY}/commits/${revision}/pulls" \
--jq '[.[] | select(.state == "open" and .head.repo.full_name == "'"${GITHUB_REPOSITORY}"'" and .head.sha == "'"${revision}"'")] | length'
)"
if [[ "$pr_head_count" != "0" ]]; then
reason="open-pr-head"
fi
fi
if [[ -z "$reason" ]]; then
echo "${label} ref '${input_ref}' resolved to ${revision}, which is not trusted for this secret-bearing Mantis run." >&2
echo "$1 ref '${input_ref}' is not available in the workflow checkout." >&2
exit 1
fi
printf '%s\n' "$revision"
}
baseline_revision="$(validate_ref baseline "$BASELINE_REF")"
candidate_revision="$(validate_ref candidate "$CANDIDATE_REF")"
baseline_revision="$(resolve_commit baseline "$BASELINE_REF")"
candidate_revision="$(resolve_commit candidate "$CANDIDATE_REF")"
if ! git merge-base --is-ancestor "$baseline_revision" refs/remotes/origin/main; then
echo "baseline ref '${BASELINE_REF}' resolved to ${baseline_revision}, which is not on main." >&2
exit 1
fi
pr_head="$(
gh api \
-H "Accept: application/vnd.github+json" \
"repos/${GITHUB_REPOSITORY}/pulls/${PR_NUMBER}" \
--jq '{state, head_sha: .head.sha, head_repo: .head.repo.full_name}'
)"
pr_state="$(jq -r '.state' <<<"$pr_head")"
pr_head_sha="$(jq -r '.head_sha' <<<"$pr_head")"
pr_head_repo="$(jq -r '.head_repo' <<<"$pr_head")"
if [[ "$pr_state" != "open" || "$candidate_revision" != "$pr_head_sha" ]]; then
echo "candidate ref '${CANDIDATE_REF}' resolved to ${candidate_revision}, which is not the open PR head." >&2
exit 1
fi
candidate_trust="open-pr-head"
if [[ "$pr_head_repo" != "$GITHUB_REPOSITORY" ]]; then
candidate_trust="fork-pr-head"
fi
echo "baseline_revision=${baseline_revision}" >> "$GITHUB_OUTPUT"
echo "candidate_revision=${candidate_revision}" >> "$GITHUB_OUTPUT"
echo "candidate_trust=${candidate_trust}" >> "$GITHUB_OUTPUT"
{
echo "baseline: \`${BASELINE_REF}\`"
echo "baseline SHA: \`${baseline_revision}\`"
echo "baseline trust: \`main-ancestor\`"
echo "candidate: \`${CANDIDATE_REF}\`"
echo "candidate SHA: \`${candidate_revision}\`"
echo "candidate trust: \`${candidate_trust}\`"
} >> "$GITHUB_STEP_SUMMARY"
run_telegram_desktop_proof:
name: Run agentic native Telegram proof
needs: [resolve_request, validate_refs]
if: ${{ needs.resolve_request.outputs.should_run == 'true' }}
runs-on: blacksmith-16vcpu-ubuntu-2404
timeout-minutes: 360
environment: qa-live-shared
@@ -297,6 +229,31 @@ jobs:
comparison_status: ${{ steps.inspect.outputs.comparison_status }}
output_dir: ${{ steps.inspect.outputs.output_dir }}
steps:
- name: Wait for older Mantis Telegram account run
env:
GH_TOKEN: ${{ github.token }}
shell: bash
run: |
set -euo pipefail
current_created="$(gh api "repos/${GITHUB_REPOSITORY}/actions/runs/${GITHUB_RUN_ID}" --jq .created_at)"
while true; do
blockers="$(
for workflow in mantis-telegram-desktop-proof.yml mantis-telegram-live.yml; do
gh run list --repo "$GITHUB_REPOSITORY" --workflow "$workflow" --limit 100 --json databaseId,status,createdAt,url \
| jq -r \
--argjson current_id "$GITHUB_RUN_ID" \
--arg current_created "$current_created" \
'.[] | select(.databaseId != $current_id) | select(.createdAt < $current_created or (.createdAt == $current_created and .databaseId < $current_id)) | select(.status == "queued" or .status == "in_progress" or .status == "waiting" or .status == "pending" or .status == "requested") | "\(.createdAt)\t#\(.databaseId)\t\(.status)\t\(.url)"'
done | sort -u
)"
if [[ -z "$blockers" ]]; then
break
fi
echo "Waiting for older Mantis Telegram account run:"
printf '%s\n' "$blockers" | head -n 10
sleep 60
done
- name: Checkout harness ref
uses: actions/checkout@v6
with:
@@ -331,6 +288,32 @@ jobs:
crabbox --version
crabbox media preview --help >/dev/null
- name: Install local proof tools
shell: bash
run: |
set -euo pipefail
test -f scripts/e2e/telegram-user-driver.py
cat >"${RUNNER_TEMP}/openclaw-telegram-user-crabbox-proof" <<'EOF'
#!/usr/bin/env bash
set -euo pipefail
exec node --import tsx "${GITHUB_WORKSPACE}/scripts/e2e/telegram-user-crabbox-proof.ts" "$@"
EOF
chmod 0755 "${RUNNER_TEMP}/openclaw-telegram-user-crabbox-proof"
sudo install -m 0755 "${RUNNER_TEMP}/openclaw-telegram-user-crabbox-proof" /usr/local/bin/openclaw-telegram-user-crabbox-proof
/usr/local/bin/openclaw-telegram-user-crabbox-proof --help >/dev/null
media_tools="${RUNNER_TEMP}/mantis-media-tools"
install -d "$media_tools"
curl --fail --location --retry 3 --retry-delay 2 \
--connect-timeout 15 --max-time 180 \
https://github.com/BtbN/FFmpeg-Builds/releases/download/latest/ffmpeg-master-latest-linux64-gpl.tar.xz \
--output "$media_tools/ffmpeg.tar.xz"
tar -xJf "$media_tools/ffmpeg.tar.xz" -C "$media_tools"
bin_dir="$(find "$media_tools" -type d -path '*/bin' | head -n 1)"
sudo install -m 0755 "$bin_dir/ffmpeg" /usr/local/bin/ffmpeg
sudo install -m 0755 "$bin_dir/ffprobe" /usr/local/bin/ffprobe
ffmpeg -version >/dev/null
ffprobe -version >/dev/null
- name: Ensure agent key exists
env:
OPENAI_API_KEY: ${{ secrets.OPENCLAW_MANTIS_AGENT_OPENAI_API_KEY || secrets.OPENAI_API_KEY }}
@@ -350,8 +333,9 @@ jobs:
printf '%s\n' 'Defaults env_keep += "CODEX_HOME CODEX_INTERNAL_ORIGINATOR_OVERRIDE"'
printf '%s\n' 'Defaults env_keep += "BASELINE_REF BASELINE_SHA CANDIDATE_REF CANDIDATE_SHA"'
printf '%s\n' 'Defaults env_keep += "CRABBOX_ACCESS_CLIENT_ID CRABBOX_ACCESS_CLIENT_SECRET CRABBOX_COORDINATOR CRABBOX_COORDINATOR_TOKEN CRABBOX_LEASE_ID CRABBOX_PROVIDER"'
printf '%s\n' 'Defaults env_keep += "GH_TOKEN MANTIS_INSTRUCTIONS MANTIS_OUTPUT_DIR MANTIS_PR_NUMBER"'
printf '%s\n' 'Defaults env_keep += "GH_TOKEN MANTIS_CANDIDATE_TRUST MANTIS_INSTRUCTIONS MANTIS_OUTPUT_DIR MANTIS_PR_NUMBER"'
printf '%s\n' 'Defaults env_keep += "OPENCLAW_BUILD_PRIVATE_QA OPENCLAW_ENABLE_PRIVATE_QA_CLI OPENCLAW_QA_CONVEX_SECRET_CI OPENCLAW_QA_CONVEX_SITE_URL OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR_TOKEN"'
printf '%s\n' 'Defaults env_keep += "OPENCLAW_TELEGRAM_USER_CRABBOX_BIN OPENCLAW_TELEGRAM_USER_CRABBOX_PROVIDER OPENCLAW_TELEGRAM_USER_DRIVER_SCRIPT OPENCLAW_TELEGRAM_USER_PROOF_CMD"'
} | sudo tee /etc/sudoers.d/mantis-codex-env >/dev/null
sudo chmod 0440 /etc/sudoers.d/mantis-codex-env
codex_home="/tmp/mantis-codex-home-${GITHUB_RUN_ID}"
@@ -375,11 +359,12 @@ jobs:
CANDIDATE_SHA: ${{ needs.validate_refs.outputs.candidate_revision }}
CRABBOX_ACCESS_CLIENT_ID: ${{ secrets.CRABBOX_ACCESS_CLIENT_ID }}
CRABBOX_ACCESS_CLIENT_SECRET: ${{ secrets.CRABBOX_ACCESS_CLIENT_SECRET }}
CRABBOX_COORDINATOR: ${{ secrets.CRABBOX_COORDINATOR }}
CRABBOX_COORDINATOR_TOKEN: ${{ secrets.CRABBOX_COORDINATOR_TOKEN }}
CRABBOX_COORDINATOR: ${{ secrets.CRABBOX_COORDINATOR || secrets.OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR }}
CRABBOX_COORDINATOR_TOKEN: ${{ secrets.CRABBOX_COORDINATOR_TOKEN || secrets.OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR_TOKEN }}
CRABBOX_LEASE_ID: ${{ needs.resolve_request.outputs.lease_id }}
CRABBOX_PROVIDER: ${{ needs.resolve_request.outputs.crabbox_provider }}
GH_TOKEN: ${{ github.token }}
MANTIS_CANDIDATE_TRUST: ${{ needs.validate_refs.outputs.candidate_trust }}
MANTIS_INSTRUCTIONS: ${{ needs.resolve_request.outputs.instructions }}
MANTIS_OUTPUT_DIR: ${{ env.MANTIS_OUTPUT_DIR }}
MANTIS_PR_NUMBER: ${{ needs.resolve_request.outputs.pr_number }}
@@ -387,6 +372,10 @@ jobs:
OPENCLAW_QA_CONVEX_SITE_URL: ${{ secrets.OPENCLAW_QA_CONVEX_SITE_URL }}
OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR: ${{ secrets.OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR }}
OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR_TOKEN: ${{ secrets.OPENCLAW_QA_MANTIS_CRABBOX_COORDINATOR_TOKEN }}
OPENCLAW_TELEGRAM_USER_CRABBOX_BIN: /usr/local/bin/crabbox
OPENCLAW_TELEGRAM_USER_CRABBOX_PROVIDER: ${{ needs.resolve_request.outputs.crabbox_provider }}
OPENCLAW_TELEGRAM_USER_DRIVER_SCRIPT: ${{ github.workspace }}/scripts/e2e/telegram-user-driver.py
OPENCLAW_TELEGRAM_USER_PROOF_CMD: /usr/local/bin/openclaw-telegram-user-crabbox-proof
with:
openai-api-key: ${{ secrets.OPENCLAW_MANTIS_AGENT_OPENAI_API_KEY || secrets.OPENAI_API_KEY }}
prompt-file: .github/codex/prompts/mantis-telegram-desktop-proof.md

View File

@@ -33,18 +33,15 @@ on:
type: string
permissions:
actions: read
contents: write
issues: write
pull-requests: write
concurrency:
group: mantis-telegram-live-${{ github.event.issue.number || inputs.pr_number || inputs.candidate_ref || github.run_id }}-${{ github.run_attempt }}
cancel-in-progress: false
env:
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: "true"
NODE_VERSION: "24.x"
PNPM_VERSION: "10.33.0"
PNPM_VERSION: "11.0.8"
OPENCLAW_BUILD_PRIVATE_QA: "1"
OPENCLAW_ENABLE_PRIVATE_QA_CLI: "1"
CRABBOX_REF: main
@@ -253,6 +250,31 @@ jobs:
comparison_status: ${{ steps.run_mantis.outputs.comparison_status }}
output_dir: ${{ steps.run_mantis.outputs.output_dir }}
steps:
- name: Wait for older Mantis Telegram account run
env:
GH_TOKEN: ${{ github.token }}
shell: bash
run: |
set -euo pipefail
current_created="$(gh api "repos/${GITHUB_REPOSITORY}/actions/runs/${GITHUB_RUN_ID}" --jq .created_at)"
while true; do
blockers="$(
for workflow in mantis-telegram-desktop-proof.yml mantis-telegram-live.yml; do
gh run list --repo "$GITHUB_REPOSITORY" --workflow "$workflow" --limit 100 --json databaseId,status,createdAt,url \
| jq -r \
--argjson current_id "$GITHUB_RUN_ID" \
--arg current_created "$current_created" \
'.[] | select(.databaseId != $current_id) | select(.createdAt < $current_created or (.createdAt == $current_created and .databaseId < $current_id)) | select(.status == "queued" or .status == "in_progress" or .status == "waiting" or .status == "pending" or .status == "requested") | "\(.createdAt)\t#\(.databaseId)\t\(.status)\t\(.url)"'
done | sort -u
)"
if [[ -z "$blockers" ]]; then
break
fi
echo "Waiting for older Mantis Telegram account run:"
printf '%s\n' "$blockers" | head -n 10
sleep 60
done
- name: Checkout harness ref
uses: actions/checkout@v6
with:

View File

@@ -427,6 +427,7 @@ jobs:
add_profile_suite live-cli-backend-docker "stable full"
add_profile_suite live-acp-bind-docker "stable full"
add_profile_suite live-codex-harness-docker "stable full"
add_profile_suite live-subagent-announce-docker "stable full"
add_profile_suite native-live-extensions-a-k "full"
add_profile_suite native-live-extensions-media-audio "full"
@@ -2291,6 +2292,12 @@ jobs:
timeout_minutes: 40
profile_env_only: false
profiles: stable full
- suite_id: live-subagent-announce-docker
label: Docker live subagent announce
command: OPENCLAW_LIVE_DOCKER_REPO_ROOT="$GITHUB_WORKSPACE" timeout --foreground --kill-after=30s 20m bash .release-harness/scripts/test-live-subagent-announce-docker.sh
timeout_minutes: 25
profile_env_only: false
profiles: stable full
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
OPENAI_BASE_URL: ${{ secrets.OPENAI_BASE_URL }}

View File

@@ -169,12 +169,27 @@ jobs:
- name: Verify release contents
run: pnpm release:check
- name: Generate dependency release evidence
id: dependency_evidence
env:
RELEASE_REF: ${{ inputs.tag }}
RELEASE_NPM_DIST_TAG: ${{ inputs.npm_dist_tag }}
run: |
set -euo pipefail
node scripts/generate-dependency-release-evidence.mjs \
--release-ref "$RELEASE_REF" \
--npm-dist-tag "$RELEASE_NPM_DIST_TAG" \
--output-dir "$RUNNER_TEMP/openclaw-release-dependency-evidence" \
--github-output "$GITHUB_OUTPUT" \
--github-step-summary "$GITHUB_STEP_SUMMARY"
- name: Pack prepared npm tarball
id: packed_tarball
env:
OPENCLAW_PREPACK_PREPARED: "1"
RELEASE_TAG: ${{ inputs.tag }}
RELEASE_NPM_DIST_TAG: ${{ inputs.npm_dist_tag }}
DEPENDENCY_EVIDENCE_DIR: ${{ steps.dependency_evidence.outputs.dir }}
run: |
set -euo pipefail
PACK_OUTPUT="$RUNNER_TEMP/npm-pack-output.txt"
@@ -246,6 +261,7 @@ jobs:
rm -rf "$ARTIFACT_DIR"
mkdir -p "$ARTIFACT_DIR"
cp "$PACK_PATH" "$ARTIFACT_DIR/"
cp -R "$DEPENDENCY_EVIDENCE_DIR" "$ARTIFACT_DIR/dependency-evidence"
printf '%s\n' "$RELEASE_TAG" > "$ARTIFACT_DIR/release-tag.txt"
printf '%s\n' "$RELEASE_SHA" > "$ARTIFACT_DIR/release-sha.txt"
printf '%s\n' "$RELEASE_NPM_DIST_TAG" > "$ARTIFACT_DIR/release-npm-dist-tag.txt"
@@ -261,6 +277,8 @@ jobs:
packageVersion: process.env.PACKAGE_VERSION,
tarballName: process.env.TARBALL_NAME,
tarballSha256: process.env.TARBALL_SHA256,
dependencyEvidenceDir: "dependency-evidence",
dependencyEvidenceManifest: "dependency-evidence/dependency-evidence-manifest.json",
};
fs.writeFileSync(
path.join(process.env.ARTIFACT_DIR, "preflight-manifest.json"),
@@ -269,6 +287,13 @@ jobs:
NODE
echo "dir=$ARTIFACT_DIR" >> "$GITHUB_OUTPUT"
- name: Upload dependency release evidence
uses: actions/upload-artifact@v7
with:
name: openclaw-release-dependency-evidence-${{ inputs.tag }}
path: ${{ steps.dependency_evidence.outputs.dir }}
if-no-files-found: error
- name: Upload prepared npm publish bundle
uses: actions/upload-artifact@v7
with:

View File

@@ -626,7 +626,7 @@ jobs:
artifact_name: ${{ needs.prepare_release_package.outputs.artifact_name }}
package_sha256: ${{ (needs.resolve_target.outputs.package_acceptance_package_spec == '' && needs.resolve_target.outputs.release_package_spec == '') && needs.prepare_release_package.outputs.package_sha256 || '' }}
suite_profile: custom
docker_lanes: doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor update-restart-auth plugins-offline plugin-update
docker_lanes: doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor root-managed-vps-upgrade update-restart-auth plugins-offline plugin-update
published_upgrade_survivor_baselines: ${{ needs.resolve_target.outputs.run_release_soak == 'true' && 'last-stable-4 2026.4.23 2026.5.2 2026.4.15' || '' }}
published_upgrade_survivor_scenarios: ${{ needs.resolve_target.outputs.run_release_soak == 'true' && 'reported-issues' || '' }}
telegram_mode: mock-openai

View File

@@ -288,7 +288,7 @@ jobs:
wait_for_run() {
local workflow="$1"
local run_id="$2"
local status conclusion url updated_at last_state
local status conclusion url updated_at created_at duration_seconds duration_label last_state
last_state=""
while true; do
@@ -307,11 +307,26 @@ jobs:
sleep 30
done
conclusion="$(gh run view --repo "$GITHUB_REPOSITORY" "$run_id" --json conclusion --jq '.conclusion')"
url="$(gh run view --repo "$GITHUB_REPOSITORY" "$run_id" --json url --jq '.url')"
echo "${workflow} finished with ${conclusion}: ${url}"
run_json="$(gh run view --repo "$GITHUB_REPOSITORY" "$run_id" --json conclusion,url,createdAt,updatedAt)"
conclusion="$(printf '%s' "$run_json" | jq -r '.conclusion')"
url="$(printf '%s' "$run_json" | jq -r '.url')"
created_at="$(printf '%s' "$run_json" | jq -r '.createdAt')"
updated_at="$(printf '%s' "$run_json" | jq -r '.updatedAt')"
duration_seconds="$(
CREATED_AT="${created_at}" UPDATED_AT="${updated_at}" node --input-type=module -e '
const created = Date.parse(process.env.CREATED_AT ?? "");
const updated = Date.parse(process.env.UPDATED_AT ?? "");
console.log(Number.isFinite(created) && Number.isFinite(updated) ? Math.max(0, Math.round((updated - created) / 1000)) : "");
'
)"
if [[ -n "${duration_seconds}" ]]; then
duration_label="$((duration_seconds / 60))m$(printf '%02d' $((duration_seconds % 60)))s"
else
duration_label="unknown duration"
fi
echo "${workflow} finished with ${conclusion} in ${duration_label}: ${url}"
{
echo "- ${workflow}: ${conclusion} (${url})"
echo "- ${workflow}: ${conclusion} in ${duration_label} (${url})"
} >> "$GITHUB_STEP_SUMMARY"
if [[ "$conclusion" != "success" ]]; then
gh run view --repo "$GITHUB_REPOSITORY" "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true
@@ -386,6 +401,33 @@ jobs:
echo "- GitHub release: https://github.com/${GITHUB_REPOSITORY}/releases/tag/${RELEASE_TAG}" >> "$GITHUB_STEP_SUMMARY"
}
upload_dependency_evidence_release_asset() {
local release_version download_dir asset_path asset_name
release_version="${RELEASE_TAG#v}"
download_dir="${RUNNER_TEMP}/openclaw-release-dependency-evidence-asset"
asset_name="openclaw-${release_version}-dependency-evidence.zip"
asset_path="${RUNNER_TEMP}/${asset_name}"
rm -rf "${download_dir}" "${asset_path}"
mkdir -p "${download_dir}"
gh run download "${PREFLIGHT_RUN_ID}" \
--repo "${GITHUB_REPOSITORY}" \
--name "openclaw-npm-preflight-${RELEASE_TAG}" \
--dir "${download_dir}"
if [[ ! -d "${download_dir}/dependency-evidence" ]]; then
echo "Dependency evidence is missing from OpenClaw npm preflight artifact." >&2
find "${download_dir}" -maxdepth 2 -type f -print >&2 || true
exit 1
fi
(cd "${download_dir}" && zip -qr "${asset_path}" dependency-evidence)
gh release upload "${RELEASE_TAG}" "${asset_path}#${asset_name}" \
--repo "${GITHUB_REPOSITORY}" \
--clobber
echo "- Dependency evidence asset: \`${asset_name}\`" >> "$GITHUB_STEP_SUMMARY"
}
{
echo "### Publish sequence"
echo
@@ -414,6 +456,10 @@ jobs:
plugin_npm_run_id="$(dispatch_workflow plugin-npm-release.yml "${npm_args[@]}")"
plugin_clawhub_run_id="$(dispatch_workflow plugin-clawhub-release.yml "${clawhub_args[@]}")"
{
echo "- Plugin npm run ID: \`${plugin_npm_run_id}\`"
echo "- Plugin ClawHub run ID: \`${plugin_clawhub_run_id}\`"
} >> "$GITHUB_STEP_SUMMARY"
if ! wait_for_run plugin-npm-release.yml "${plugin_npm_run_id}"; then
echo "Plugin npm publish failed; cancelling ClawHub publish child ${plugin_clawhub_run_id}." >&2
@@ -428,6 +474,7 @@ jobs:
-f preflight_only=false \
-f preflight_run_id="${PREFLIGHT_RUN_ID}" \
-f npm_dist_tag="${RELEASE_NPM_DIST_TAG}")"
echo "- OpenClaw npm run ID: \`${openclaw_npm_run_id}\`" >> "$GITHUB_STEP_SUMMARY"
else
echo "- OpenClaw npm publish: skipped by input" >> "$GITHUB_STEP_SUMMARY"
fi
@@ -471,4 +518,5 @@ jobs:
if [[ -n "${openclaw_npm_run_id}" ]]; then
create_or_update_github_release
upload_dependency_evidence_release_asset
fi

View File

@@ -386,10 +386,10 @@ jobs:
docker_lanes="npm-onboard-channel-agent gateway-network config-reload"
;;
package)
docker_lanes="npm-onboard-channel-agent doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor update-restart-auth plugins-offline plugin-update"
docker_lanes="npm-onboard-channel-agent doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor root-managed-vps-upgrade update-restart-auth plugins-offline plugin-update"
;;
product)
docker_lanes="npm-onboard-channel-agent doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor update-restart-auth plugins plugin-update mcp-channels cron-mcp-cleanup openai-web-search-minimal openwebui"
docker_lanes="npm-onboard-channel-agent doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor root-managed-vps-upgrade update-restart-auth plugins plugin-update mcp-channels cron-mcp-cleanup openai-web-search-minimal openwebui"
include_openwebui=true
;;
full)

View File

@@ -228,7 +228,20 @@ jobs:
- name: Install ClawHub CLI dependencies
working-directory: clawhub-source
run: bun install --frozen-lockfile
run: |
set -euo pipefail
for attempt in 1 2 3; do
if bun install --frozen-lockfile; then
exit 0
fi
status="$?"
if [[ "${attempt}" == "3" ]]; then
exit "${status}"
fi
echo "bun install failed while preparing ClawHub CLI; retrying (${attempt}/3)."
rm -rf node_modules "${RUNNER_TEMP}/bun-install-cache" || true
sleep $((attempt * 15))
done
- name: Bootstrap ClawHub CLI
run: |
@@ -263,7 +276,7 @@ jobs:
id-token: write
strategy:
fail-fast: false
max-parallel: 12
max-parallel: 32
matrix:
plugin: ${{ fromJson(needs.preview_plugins_clawhub.outputs.matrix) }}
steps:
@@ -309,7 +322,20 @@ jobs:
- name: Install ClawHub CLI dependencies
working-directory: clawhub-source
run: bun install --frozen-lockfile
run: |
set -euo pipefail
for attempt in 1 2 3; do
if bun install --frozen-lockfile; then
exit 0
fi
status="$?"
if [[ "${attempt}" == "3" ]]; then
exit "${status}"
fi
echo "bun install failed while preparing ClawHub CLI; retrying (${attempt}/3)."
rm -rf node_modules "${RUNNER_TEMP}/bun-install-cache" || true
sleep $((attempt * 15))
done
- name: Bootstrap ClawHub CLI
run: |
@@ -392,3 +418,62 @@ jobs:
PACKAGE_TAG: ${{ matrix.plugin.publishTag }}
PACKAGE_DIR: ${{ matrix.plugin.packageDir }}
run: bash scripts/plugin-clawhub-publish.sh --publish "${PACKAGE_DIR}"
- name: Verify published ClawHub package
env:
CLAWHUB_REGISTRY: ${{ env.CLAWHUB_REGISTRY }}
PACKAGE_NAME: ${{ matrix.plugin.packageName }}
PACKAGE_VERSION: ${{ matrix.plugin.version }}
PACKAGE_TAG: ${{ matrix.plugin.publishTag }}
run: |
set -euo pipefail
node --input-type=module <<'EOF'
const registry = (process.env.CLAWHUB_REGISTRY ?? "https://clawhub.ai").replace(/\/+$/, "");
const packageName = process.env.PACKAGE_NAME;
const packageVersion = process.env.PACKAGE_VERSION;
const packageTag = process.env.PACKAGE_TAG;
if (!packageName || !packageVersion || !packageTag) {
throw new Error("Missing ClawHub package verification env.");
}
const encodedName = encodeURIComponent(packageName);
const encodedVersion = encodeURIComponent(packageVersion);
const detailUrl = `${registry}/api/v1/packages/${encodedName}`;
const versionUrl = `${detailUrl}/versions/${encodedVersion}`;
const artifactUrl = `${versionUrl}/artifact/download`;
async function fetchWithRetry(url, options = {}) {
let lastStatus = "unknown";
for (let attempt = 1; attempt <= 12; attempt += 1) {
const response = await fetch(url, { redirect: "manual", ...options });
lastStatus = response.status;
if (response.status !== 429 && response.status < 500) {
return response;
}
await new Promise((resolve) => setTimeout(resolve, attempt * 5000));
}
throw new Error(`${url} did not stabilize; last status ${lastStatus}.`);
}
const detailResponse = await fetchWithRetry(detailUrl, {
headers: { accept: "application/json" },
});
if (!detailResponse.ok) {
throw new Error(`${detailUrl} returned HTTP ${detailResponse.status}.`);
}
const detail = await detailResponse.json();
const tags = detail?.package?.tags ?? {};
if (tags[packageTag] !== packageVersion) {
throw new Error(
`${packageName}: ClawHub tag ${packageTag} points to ${tags[packageTag] ?? "<missing>"}, expected ${packageVersion}.`,
);
}
const versionResponse = await fetchWithRetry(versionUrl);
if (!versionResponse.ok) {
throw new Error(`${versionUrl} returned HTTP ${versionResponse.status}.`);
}
const artifactResponse = await fetchWithRetry(artifactUrl, { method: "HEAD" });
if (artifactResponse.status < 200 || artifactResponse.status >= 400) {
throw new Error(`${artifactUrl} returned HTTP ${artifactResponse.status}.`);
}
console.log(`${packageName}@${packageVersion} verified on ClawHub.`);
EOF

View File

@@ -346,6 +346,185 @@ jobs:
OPENCLAW_EXTENSION_BATCH: ${{ matrix.extensions_csv }}
run: pnpm test:extensions:batch -- "$OPENCLAW_EXTENSION_BATCH"
plugin-prerelease-inspector:
permissions:
contents: read
name: plugin-prerelease-inspector
needs: [preflight]
if: needs.preflight.outputs.run_plugin_prerelease_suite == 'true'
continue-on-error: true
runs-on: ubuntu-24.04
timeout-minutes: 30
steps:
- name: Checkout
uses: actions/checkout@v6
with:
ref: ${{ needs.preflight.outputs.checkout_revision }}
fetch-depth: 1
fetch-tags: false
persist-credentials: false
submodules: false
- name: Setup Node environment
uses: ./.github/actions/setup-node-env
with:
install-bun: "false"
- name: Run plugin inspector advisory sweep
env:
OPENCLAW_PLUGIN_INSPECTOR_VERSION: "0.3.10"
OPENCLAW_PLUGIN_INSPECTOR_ROOT: .artifacts/plugin-inspector
shell: bash
run: |
set -euo pipefail
mkdir -p "$OPENCLAW_PLUGIN_INSPECTOR_ROOT"
set +e
node --input-type=module <<'EOF'
import { existsSync } from "node:fs";
import { mkdir, readdir, readFile, writeFile } from "node:fs/promises";
import path from "node:path";
const artifactRoot = process.env.OPENCLAW_PLUGIN_INSPECTOR_ROOT;
if (!artifactRoot) {
throw new Error("OPENCLAW_PLUGIN_INSPECTOR_ROOT is required");
}
const readJson = async (filePath) => JSON.parse(await readFile(filePath, "utf8"));
const inferSeams = (pluginManifest, packageJson) => {
const contracts = Object.keys(pluginManifest?.contracts ?? {});
if (contracts.includes("tools")) {
return ["dynamic-tool"];
}
const openclawPackage = packageJson?.openclaw ?? {};
if (openclawPackage.extensions || openclawPackage.runtimeExtensions) {
return ["plugin-runtime"];
}
return ["plugin-metadata"];
};
const extensionRoot = path.resolve("extensions");
const fixtures = [];
for (const entry of await readdir(extensionRoot, { withFileTypes: true })) {
if (!entry.isDirectory()) {
continue;
}
const relativePath = `extensions/${entry.name}`;
const packagePath = path.join(extensionRoot, entry.name, "package.json");
const manifestPath = path.join(extensionRoot, entry.name, "openclaw.plugin.json");
if (!existsSync(packagePath) || !existsSync(manifestPath)) {
continue;
}
const packageJson = await readJson(packagePath);
const pluginManifest = await readJson(manifestPath);
fixtures.push({
id: entry.name,
name: pluginManifest.name ?? packageJson.name ?? entry.name,
path: relativePath,
priority: "high",
repo: "local",
seams: inferSeams(pluginManifest, packageJson),
why: "bundled OpenClaw plugin prerelease advisory fixture",
});
}
fixtures.sort((left, right) => left.id.localeCompare(right.id));
if (fixtures.length === 0) {
throw new Error("No bundled plugin fixtures found under extensions/");
}
await mkdir(artifactRoot, { recursive: true });
const config = `${JSON.stringify(
{
version: 1,
submoduleRoot: ".",
openclaw: {
defaultCheckoutPath: ".",
},
fixtures,
},
null,
2,
)}\n`;
await writeFile("plugin-inspector.config.json", config, "utf8");
await writeFile(path.join(artifactRoot, "plugin-inspector.config.json"), config, "utf8");
EOF
config_status=$?
set -e
echo "$config_status" > "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/config-exit-code.txt"
if [ "$config_status" -eq 0 ]; then
set +e
npm exec --yes "@openclaw/plugin-inspector@${OPENCLAW_PLUGIN_INSPECTOR_VERSION}" -- ci \
--config plugin-inspector.config.json \
--openclaw "$PWD" \
--out "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/reports" \
--json \
> "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/plugin-inspector-stdout.json" \
2> "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/plugin-inspector-stderr.log"
inspector_status=$?
set -e
else
inspector_status=127
echo "Skipped plugin-inspector because config generation failed." \
> "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/plugin-inspector-stderr.log"
fi
echo "$inspector_status" > "$OPENCLAW_PLUGIN_INSPECTOR_ROOT/exit-code.txt"
node --input-type=module <<'EOF'
import { existsSync } from "node:fs";
import { appendFile, readFile, writeFile } from "node:fs/promises";
import path from "node:path";
const artifactRoot = process.env.OPENCLAW_PLUGIN_INSPECTOR_ROOT;
const summaryPath = path.join(artifactRoot, "reports/plugin-inspector-ci-summary.json");
const markdownPath = path.join(artifactRoot, "reports/plugin-inspector-ci-summary.md");
const configExitCode = (await readFile(path.join(artifactRoot, "config-exit-code.txt"), "utf8")).trim();
const exitCode = (await readFile(path.join(artifactRoot, "exit-code.txt"), "utf8")).trim();
const lines = [
"## Plugin Inspector Advisory",
"",
`Inspector: @openclaw/plugin-inspector@${process.env.OPENCLAW_PLUGIN_INSPECTOR_VERSION}`,
`Config exit code: ${configExitCode}`,
`Exit code: ${exitCode}`,
];
if (existsSync(summaryPath)) {
const summary = JSON.parse(await readFile(summaryPath, "utf8"));
lines.push(
`Status: ${String(summary.status ?? "unknown").toUpperCase()}`,
"",
"| Metric | Count |",
"| --- | ---: |",
`| Hard breakages | ${summary.summary?.breakages ?? 0} |`,
`| Issues | ${summary.summary?.issues ?? 0} |`,
`| P0 issues | ${summary.summary?.p0Issues ?? 0} |`,
`| P1 issues | ${summary.summary?.p1Issues ?? 0} |`,
`| Compat gaps | ${summary.summary?.compatGaps ?? 0} |`,
`| Inspector gaps | ${summary.summary?.inspectorGaps ?? 0} |`,
"",
"This job is informational; Plugin Prerelease blocking status is unchanged.",
);
await writeFile(path.join(artifactRoot, "advisory-summary.md"), `${lines.join("\n")}\n`, "utf8");
if (existsSync(markdownPath)) {
lines.push("", "### Full inspector summary", "");
lines.push(await readFile(markdownPath, "utf8"));
}
} else {
lines.push("", "No plugin-inspector CI summary was produced.", "");
lines.push("This job is informational; inspect the uploaded stdout/stderr artifacts.");
await writeFile(path.join(artifactRoot, "advisory-summary.md"), `${lines.join("\n")}\n`, "utf8");
}
await appendFile(process.env.GITHUB_STEP_SUMMARY, `${lines.join("\n")}\n`, "utf8");
EOF
- name: Upload plugin inspector advisory artifacts
if: always()
uses: actions/upload-artifact@v7
with:
name: plugin-inspector-advisory
path: .artifacts/plugin-inspector/**
if-no-files-found: warn
plugin-prerelease-docker-suite:
name: plugin-prerelease-docker-suite
needs: [preflight]
@@ -375,6 +554,7 @@ jobs:
- plugin-prerelease-static-shard
- plugin-prerelease-node-shard
- plugin-prerelease-extension-shard
- plugin-prerelease-inspector
- plugin-prerelease-docker-suite
if: ${{ !cancelled() && always() && needs.preflight.outputs.run_plugin_prerelease_suite == 'true' }}
runs-on: ubuntu-24.04
@@ -389,6 +569,7 @@ jobs:
STATIC_RESULT: ${{ needs.plugin-prerelease-static-shard.result }}
NODE_RESULT: ${{ needs.plugin-prerelease-node-shard.result }}
EXTENSIONS_RESULT: ${{ needs.plugin-prerelease-extension-shard.result }}
INSPECTOR_RESULT: ${{ needs.plugin-prerelease-inspector.result }}
DOCKER_RESULT: ${{ needs.plugin-prerelease-docker-suite.result }}
shell: bash
run: |
@@ -411,4 +592,5 @@ jobs:
check_required "plugin-prerelease-node" "$RUN_NODE" "$NODE_RESULT"
check_required "plugin-prerelease-extensions" "$RUN_EXTENSIONS" "$EXTENSIONS_RESULT"
check_required "plugin-prerelease-docker" "$RUN_DOCKER" "$DOCKER_RESULT"
echo "plugin-prerelease-inspector advisory result: ${INSPECTOR_RESULT}"
exit "$failed"

View File

@@ -196,7 +196,10 @@ jobs:
run: |
git config user.name "openclaw-installer-sync[bot]"
git config user.email "openclaw-installer-sync[bot]@users.noreply.github.com"
git add public/install.sh public/install-cli.sh public/install.ps1 public/install.cmd
git add public/install.sh public/install-cli.sh public/install.ps1
if git ls-files --error-unmatch public/install.cmd >/dev/null 2>&1; then
git add -u -- public/install.cmd
fi
git commit -m "chore: sync installers from openclaw ${GITHUB_SHA::12}"
git pull --rebase origin main
git push origin HEAD:main

8
.gitignore vendored
View File

@@ -115,15 +115,23 @@ USER.md
!.agents/skills/blacksmith-testbox/**
!.agents/skills/crabbox/
!.agents/skills/crabbox/**
!.agents/skills/clawdtributor/
!.agents/skills/clawdtributor/**
!.agents/skills/gitcrawl/
!.agents/skills/gitcrawl/**
!.agents/skills/openclaw-docs/**
!.agents/skills/openclaw-refactor-docs/
!.agents/skills/openclaw-refactor-docs/**
!.agents/skills/openclaw-debugging/
!.agents/skills/openclaw-debugging/**
!.agents/skills/openclaw-ghsa-maintainer/
!.agents/skills/openclaw-ghsa-maintainer/**
!.agents/skills/openclaw-parallels-smoke/
!.agents/skills/openclaw-parallels-smoke/**
!.agents/skills/openclaw-pr-maintainer/
!.agents/skills/openclaw-pr-maintainer/**
!.agents/skills/openclaw-refactor-docs/
!.agents/skills/openclaw-refactor-docs/**
!.agents/skills/openclaw-qa-testing/
!.agents/skills/openclaw-qa-testing/**
!.agents/skills/openclaw-release-maintainer/

View File

@@ -10,12 +10,12 @@ Skills own workflows; root owns hard policy and routing.
- Docs/user-visible work: `pnpm docs:list`, then read relevant docs only.
- Fix/triage answers need source, tests, current/shipped behavior, and dependency contract proof.
- Dependency-backed behavior: read upstream docs/source/types first. No API/default/error/timing guesses.
- Live-verify when feasible. Check env/`~/.profile` for keys before saying blocked; never print secrets.
- Live-verify when feasible. Never print secrets.
- Missing deps: `pnpm install`, retry once, then report first actionable error.
- CODEOWNERS: maint/refactor/tests ok. Larger behavior/product/security/ownership: owner ask/review.
- Product/docs/UI/changelog wording: "plugin/plugins"; `extensions/` is internal.
- New channel/plugin/app/doc surface: update `.github/labeler.yml` + GH labels.
- New `AGENTS.md`: add sibling `CLAUDE.md` symlink.
- New `AGENTS.md`: add sibling `CLAUDE.md` symlink; edit `AGENTS.md` only.
## Map
@@ -36,6 +36,7 @@ Skills own workflows; root owns hard policy and routing.
- Channels are implementation under `src/channels/**`; plugin authors get SDK seams. Providers own auth/catalog/runtime hooks; core owns generic loop.
- Hot paths should carry prepared facts forward: provider id, model ref, channel id, target, capability family, attachment class. Do not rediscover with broad plugin/provider/channel/capability loaders.
- Do not fix repeated request-time discovery with scattered caches. Move the canonical fact earlier; reuse prepared runtime objects; delete duplicate lookup branches.
- Inline code comments: brief notes for tricky, bug-prone, or previously buggy logic.
- Gateway protocol changes: additive first; incompatible needs versioning/docs/client follow-through.
- Config contract: exported types, schema/help, metadata, baselines, docs aligned. Retired public keys stay retired; compat in raw migration/doctor only.
- Prompt cache: deterministic ordering for maps/sets/registries/plugin lists/files/network results before model/tool payloads. Preserve old transcript bytes when possible.
@@ -66,18 +67,22 @@ Skills own workflows; root owns hard policy and routing.
## GitHub / PRs
- Use `$openclaw-pr-maintainer` immediately for OpenClaw issue/PR URLs/numbers, review, triage, duplicate search, close, labels, landing, comments, or maintainer evidence.
- PR refs: `gh pr view/diff`, not web search. Prefer `gitcrawl` for local candidate discovery; verify live with `gh` before mutation.
- Use `$openclaw-pr-maintainer` immediately for maintainer-side OpenClaw issue/PR review, triage, duplicates, labels, comments, close, land, or evidence. Contributor PR creation/refresh follows the requested contributor workflow; linked refs alone do not require maintainer archive tooling.
- PR refs: `gh pr view/diff` or `gh api`, not web search. Prefer `gitcrawl` for maintainer discovery; missing/stale `gitcrawl` falls through to live `gh`, not contributor setup. Verify live with `gh` before mutation.
- Bare issue/PR URL/number means review/report in chat. Suggest comment/close/merge when appropriate; mutate only when asked.
- No unsolicited PR comments/reviews/labels/retitles/rebases/fixups/landing. Exception: close/duplicate action that needs a reason comment after explicit close/sweep/landing request.
- Maintainer decision closes the cluster: if deciding reported behavior/proposed fix is not planned, comment+close all directly associated open issues/PRs unless explicitly told to keep one open. Associated means linked PRs/issues, duplicates, companion workaround PRs, and the canonical issue for the rejected behavior.
- Do not leave associated issues open for hypothetical future repros. Close with rationale; ask for a new issue or reopen only if concrete new evidence appears. Close comment states: decision, why, supported alternative, and what evidence would change the decision.
- PR review answer: bug/behavior, URL(s), affected surface, best-fix judgment, evidence from code/tests/CI/current or shipped behavior.
- Issue/PR final answer: last line is the full GitHub URL.
- Changelog: PR landings/fixes need one unless pure test/internal. Do not mention missing changelog as a review finding; Codex handles it during fix/landing.
- PR verification: before merge, post exact local commands, CI/Testbox run IDs, before/after proof when used, and known proof gaps.
- Issue fixed on `main` with proof: comment proof + commit/PR, then close.
- After landing or requested close/sweep: search duplicates; comment proof + canonical commit/PR/release before closing.
- `ship` that fixes an issue: after push, comment proof + commit link, then close the issue.
- GH comments with backticks, `$`, or shell snippets: use heredoc/body file, not inline double-quoted `--body`.
- PR create: real body required. Include Summary + Verification; mention refs, behavior, and proof.
- Real behavior proof section is parsed. Use exact `field: value` labels: `Behavior addressed`, `Real environment tested`, `Exact steps or command run after this patch`, `Evidence after fix`, `Observed result after fix`, `What was not tested`.
- PR artifacts/screenshots: attach to PR/comment/external artifact store. Do not commit `.github/pr-assets`.
- CI polling: exact SHA, relevant checks only, minimal fields. Skip routine noise (`Auto response`, `Labeler`, docs agents, performance/stale). Logs only after failure/completion or concrete need.
- Maintainers: ignore `Real behavior proof` failures that only say PR body lacks real after-fix evidence.
@@ -115,6 +120,7 @@ Skills own workflows; root owns hard policy and routing.
- Codex harness upgrade (`extensions/codex/package.json` `@openai/codex`): refresh `docs/plugins/codex-harness.md` model snapshot from the new harness `model/list`.
- Docs final answers: include relevant full `https://docs.openclaw.ai/...` URL(s). If issue/PR work too, GitHub URL last.
- Changelog entries: active version `### Changes`/`### Fixes`; single-line bullets only.
- Contributor PR authors should not edit `CHANGELOG.md`; maintainer/AI adds entries during landing/merge.
- Contributor-facing changelog entries thank credited human `@author`. Never thank bots, `@openclaw`, `@clawsweeper`, or `@steipete`; if unknown, omit thanks.
## Git
@@ -132,8 +138,7 @@ Skills own workflows; root owns hard policy and routing.
- Never commit real phone numbers, videos, credentials, live config.
- Secrets: channel/provider creds in `~/.openclaw/credentials/`; model auth profiles in `~/.openclaw/agents/<agentId>/agent/auth-profiles.json`.
- Env keys: check `~/.profile`; redact output.
- Dependency patches/overrides/vendor changes need explicit approval. `pnpm.patchedDependencies` exact versions only.
- Dependency patches/overrides/vendor changes need explicit approval. `pnpm-workspace.yaml` patched dependencies use exact versions only.
- Carbon pins owner-only: do not change `@buape/carbon` unless Shadow (`@thewilloftheshadow`, verified by `gh`) asks.
- Releases/publish/version bumps need explicit approval. Use `$openclaw-release-maintainer`.
- GHSA/advisories: `$openclaw-ghsa-maintainer` / `$security-triage`. Secret scanning: `$openclaw-secret-scanning-maintainer`.

View File

@@ -6,14 +6,164 @@ Docs: https://docs.openclaw.ai
### Changes
- ACP: add `acp.fallbacks` so ACP turns can try configured backup runtime backends when the primary backend is unavailable before any output is emitted. (#69542) Thanks @kaseonedge.
### Fixes
- Sessions/status: classify ACP spawn-child sessions as `kind: "spawn-child"` instead of `"direct"` in `openclaw sessions` and status output; extract the duplicated session-kind classifier into a shared helper (`src/sessions/classify-session-kind.ts`) so both surfaces stay in sync. Fixes catalog #19. (#79544)
- Telegram: delete tool-progress-only draft bubbles before rotating to the real answer, preventing orphaned progress messages in streamed replies.
- Codex app-server: keep per-agent `CODEX_HOME` isolation without rewriting `HOME` by default, so Codex-run subprocesses can still find normal user-home config, tokens, and CLI state unless the launch explicitly overrides `HOME`. Thanks @pashpashpash.
- ACP: preserve redacted numeric JSON-RPC `RequestError` details in runtime failure text, so backend diagnostics are visible instead of only `Internal error`. Fixes #81126. (#81188) Thanks @vyctorbrzezowski.
- Agents: cache unchanged PI model discovery stores and model lookups, reducing repeated model-resolution startup latency under large model configs. Fixes #78851.
- Security/Windows ACL audit: classify Anonymous Logon, Guests, Interactive, Local, and Network SIDs as world-equivalent principals so broadly writable paths stay critical instead of being downgraded to group-writable. Fixes #74350. (#74383) Thanks @dwc1997.
- Media-understanding: retry transient remote attachment fetch failures before audio or vision processing, so Discord voice notes are not lost after one network/CDN blip. Fixes #74316. Thanks @vyctorbrzezowski and @gabrielexito-stack.
- Control UI: order timestamped live stream and tool items before untimestamped history fallbacks, keeping chat history in visible time order. Fixes #80759. (#81016) Thanks @akrimm702.
- iMessage: stop sending visible `<media:image>` placeholder text for media-only native image sends while preserving the internal echo key that prevents self-echo duplicate replies. (#81209) Thanks @homer-byte.
- Agents/sessions: create configured agent main sessions before first `sessions_send` or gateway send, so agent-to-agent messages no longer fail when the target agent has not started yet.
- gateway: pass Talk session scope to resolver [AI]. (#81379) Thanks @pgondhi987.
- Gateway protocol: require v4 clients and stream explicit chat `deltaText`/`replace` frames so SDK clients can consume assistant updates without local diffing. (#80725) Thanks @samzong.
- OpenAI plugin: clarify remote Codex OAuth login copy so tunneled users know sign-in may finish automatically before they paste the redirect URL. (#81301) Thanks @rubencu.
- GitHub Copilot: exchange OAuth tokens for Copilot API tokens on image understanding requests and route Gemini image payloads through Chat Completions, fixing Copilot Gemini image descriptions. (#80393, #80442) Thanks @afunnyhy.
- Gateway: hide pending Node pairing commands, capabilities, and permissions until approval, and refresh the live approved surface when pairings change. (#80741) Thanks @samzong.
- SGLang: preserve replayed reasoning history for OpenAI-compatible chat completions, keeping thinking-capable local models from losing prior reasoning turns. (#81091) Thanks @akrimm702.
- Plugins/Feishu/WhatsApp/Line: enforce inbound media size caps while reading download streams, avoiding full buffering of oversized attachments. (#81044, #81050) Thanks @samzong.
- Plugins/install: limit install-time code safety scans to plugin-owned runtime entrypoints while keeping dependency manifest denylist checks, so trusted packages with large dependency trees no longer get blocked or warned on third-party runtime internals.
- Config: serialize and retry semantic config mutations centrally, so concurrent commands can rebase safe changes instead of clobbering or hand-rolling command-local retry loops. (#76601)
- Require approval for setup-code device pairing [AI]. (#81292) Thanks @pgondhi987.
- Plugins/install: preserve third-party peer dependencies in the managed npm root when later plugin installs or updates recalculate the shared dependency tree. Thanks @shakkernerd.
- Plugins/uninstall: prune managed third-party peer dependencies after their owning npm plugin is removed, without blocking plugin cleanup on peer-prune failures.
- Docker: pin setup-time container paths so stale host `.env` OpenClaw paths cannot leak into Linux containers. Fixes #80381. (#81105) Thanks @brokemac79.
- Channels/WeCom: refresh the official onboarding install to `@wecom/wecom-openclaw-plugin@2026.5.7` and update existing managed npm installs instead of failing on the package directory. Fixes #79884. (#80390) Thanks @brokemac79.
- Control UI/WebChat: keep short assistant replies clear of in-bubble copy/open action buttons by applying the existing reserved action spacing in the grouped chat renderer. Fixes #79509. (#81244) Thanks @JARVIS-Glasses.
- Anthropic: reseed Claude CLI fresh-session retries from bounded OpenClaw transcript history after session rotation, preventing conversation amnesia. Fixes #80905. (#80934) Thanks @bitloi.
- Require explicit browser device pairing [AI]. (#81289) Thanks @pgondhi987.
- Require Control UI pairing before proxy-scoped access [AI]. (#81288) Thanks @pgondhi987.
- Installer: honor `--version` for git installs and install from the checked-in lockfile, preventing recent dependency pins from tripping pnpm's minimum-release-age gate during tag installs.
- Agents: deliver same-process subagent completion handoffs through the in-process agent dispatcher instead of opening a Gateway RPC loopback.
- Harden trusted-proxy source validation [AI]. (#81290) Thanks @pgondhi987.
- Agents: add permissive item schemas to array tool parameters before provider submission, preventing OpenAI-compatible schema validation from rejecting plugin tools that omit `items`. Fixes #81175. (#81217) Thanks @JARVIS-Glasses.
- Agents: escalate LLM idle watchdog timeouts through profile rotation and configured model fallback instead of leaving agent turns stuck after a silent model stream. Fixes #76877. (#80449) Thanks @jimdawdy-hub.
- Discord voice: treat OpenAI Realtime startup auth failures as fatal, suppress duplicate realtime error logs, and stop autoJoin from retrying the same broken voice channel until credentials are fixed.
- ACPX: stop forwarding unsupported timeout config options to Claude ACP while preserving OpenClaw's own turn timeout. (#80812) Thanks @sxxtony.
- Session transcripts: redact sensitive message content in the centralized JSONL append path so CLI turns, gateway transcript injection, transcript mirrors, and guarded tool results use the same configured redaction behavior. Fixes #73565. Refs #73563. (#79645) Thanks @Ziy1-Tan.
- Channels/iMessage: ignore Apple link-preview plugin payload attachments when users paste URLs, keeping the URL text while avoiding phantom media context. (#79374) Thanks @homer-byte.
- Telegram: detect polling stalls from `getUpdates` liveness only, so outbound API calls no longer mask dead inbound polling; log polling-cycle starts after transport rebuilds. Fixes #78473.
- fix(plugins): scan installed dependency runtime code [AI]. (#81066) Thanks @pgondhi987.
- Inherit tool restrictions for delegated sessions [AI]. (#80979) Thanks @pgondhi987.
- Codex harness: make the live test wrapper portable to Windows and defer locked temp cleanup so native Windows and WSL2 live runs complete.
- Telegram: discard legacy long-poll update offsets that cannot be tied to the current bot token, so token rotation no longer leaves bots silently skipping new messages. (#80671) Thanks @sxxtony.
- browser: enforce navigation checks for act interactions [AI]. (#81070) Thanks @pgondhi987.
- Validate node exec event provenance [AI]. (#81071) Thanks @pgondhi987.
- Gateway: keep active reply runs visible to stuck-session diagnostics and clear no-active-work recovery state, preventing stale queued lanes after compaction or tool failures. Fixes #80677. (#81302)
- Codex app-server: rotate incompatible context-engine-managed native threads so Lossless-managed sessions do not resume stale hidden Codex history. (#81223) Thanks @jalehman.
- Codex cron: execute scheduled command-style automation payloads before workspace bootstrap or memory review, preserving existing isolated cron jobs after Codex harness migration. (#81510) Thanks @jalehman.
- Gateway/OpenAI HTTP: return OpenAI-compatible 400 errors for invalid sampling params and provider validation failures instead of collapsing them to 500s. (#81275) Thanks @Lellansin.
- Telegram: publish plugin and skill command description localizations to native command menus while filtering unsupported locale codes and preserving Telegram command limits. (#81351) Thanks @jzakirov.
- Limit hook CLI tool authority [AI]. (#81065) Thanks @pgondhi987.
- Require admin scope for node device token management [AI]. (#81067) Thanks @pgondhi987.
- Restrict chat sender allowlist matching [AI]. (#80898) Thanks @pgondhi987.
- Update: suppress the false newer-config warning during restart health probing after an update handoff, while keeping future-version mutation guards intact. (#78652)
- Sessions: redact persisted tool result detail metadata before writing transcripts so diagnostic secrets do not survive tool output redaction. (#80444) Thanks @nimbleenigma.
- Codex runtime: allow the official installed `@openclaw/codex` package to use its private task-runtime and MCP projection SDK helpers, fixing `MODULE_NOT_FOUND` during migrated OpenAI/Codex beta runs.
- Codex migration: make Enter activate the highlighted checkbox row before continuing, so `Skip for now` and bulk-selection rows work even when planned items start preselected.
- Link understanding: fetch page content through the SSRF guard before running configured CLI summarizers, preventing curl/wget-style link fetchers from reaching private redirect or DNS-rebound targets.
- fix: harden safe-bin argument validation [AI]. (#80999) Thanks @pgondhi987.
- fix: scan plugin runtime entries during install [AI]. (#80998) Thanks @pgondhi987.
- Codex harness: keep auth-profile-backed media tools such as `image_generate` available when OpenAI auth lives in the agent's auth-profile store instead of environment variables.
- Require auth for sandbox browser CDP relay [AI]. (#81002) Thanks @pgondhi987.
- fix: detect carried exec command forms [AI]. (#81000) Thanks @pgondhi987.
- Reject truncated exec approval commands [AI]. (#81001) Thanks @pgondhi987.
- Enforce inline shell wrapper payload matching [AI]. (#80978) Thanks @pgondhi987.
- fix(node-pairing): replace changed pending requests [AI]. (#80894) Thanks @pgondhi987.
- Rate limit Google Chat webhook requests [AI]. (#80974) Thanks @pgondhi987.
- Docker: mount the auth-profile secret key directory so OAuth-backed auth profiles survive container rebuilds. (#80991)
- Onboarding: accept Codex auth profiles for canonical OpenAI model checks, avoiding false missing-auth warnings. (#80913) Thanks @rubencu.
- fix(feishu): normalize webhook rate-limit client keys [AI]. (#80975) Thanks @pgondhi987.
- fix(auth): prevent bootstrap pairing scope changes [AI]. (#80976) Thanks @pgondhi987.
- Validate Control UI loopback retry endpoints [AI]. (#80900) Thanks @pgondhi987.
- Harden exported markdown link rendering [AI]. (#80902) Thanks @pgondhi987.
- fix(gateway): honor minimal discovery mode for wide-area DNS-SD [AI]. (#80903) Thanks @pgondhi987.
- slack: enforce reaction notification policy [AI]. (#80907) Thanks @pgondhi987.
- Enforce gateway command scopes by caller context [AI]. (#80891) Thanks @pgondhi987.
- Telegram/groups: in single-account setups, treat an explicit empty `accounts.<id>.groups: {}` map the same as undefined so the root `channels.telegram.groups` allowlist still applies, instead of silently dropping every group update under the default `groupPolicy: "allowlist"`. Multi-account semantics are unchanged so per-account explicit-empty groups still scope-disable a single account without affecting siblings; the explicit way to block all groups for any account remains `groupPolicy: "disabled"`. Fixes #79427. (#81030) Thanks @kinjitakabe.
- Codex (app-server): project user-configured `mcp.servers` into new Codex thread configs, matching the codex-cli runtime's existing `-c mcp_servers=...` behavior so app-server-runtime agents see the same user MCP servers the CLI runtime already exposes. Plugin-curated apps remain attached via the separate `apps` config patch. Fixes #80814. Thanks @kinjitakabe.
- Enforce Slack plugin approval button authorization [AI]. (#80899) Thanks @pgondhi987.
- Recognize PowerShell -ec inline commands [AI]. (#80893) Thanks @pgondhi987.
- fix(qqbot): authorize approval button callbacks [AI]. (#80892) Thanks @pgondhi987.
- Telegram: render supported HTML tags in streamed and durable replies instead of showing literal markup. (#80977)
- Scrub streamable MCP redirect headers [AI]. (#80906) Thanks @pgondhi987.
- fix(memory-wiki): require admin scope for ingest [AI]. (#80897) Thanks @pgondhi987.
- memory-wiki: require write scope for Obsidian search [AI]. (#80904) Thanks @pgondhi987.
- WhatsApp: externalize the channel as a ClawHub/npm plugin outside the core npm runtime bundle, and bump Baileys to `7.0.0-rc11` so libsignal resolves from the registry instead of a GitHub tarball.
- WhatsApp: keep optional audio decoding dependencies local to the external plugin so the core npm install no longer pulls WhatsApp-only media helpers.
- Build: skip copied metadata for bundled plugins that are excluded from build entries, preventing update/status rebuilds from advertising missing QQ Bot runtime files. (#80925)
- Control UI/sessions: nest subagent sessions under their parent session in the session picker dropdown using a visual `└─ ` prefix, making the parent-child relationship clear. Fixes #77628. (#78623) Thanks @chinar-amrutkar.
- Telegram: limit concurrent startup `getMe` probes across multi-account bots so large Telegram configs do not fan out all account probes at once during gateway startup. Refs #80695. (#80986) Thanks @stainlu.
- fix(config): reject auto-managed meta.lastTouched\* paths in config set/unset (#80856). Thanks @ai-hpc
- Auto-reply: surface a visible error when the configured model backend fails and fallback produces no visible reply, while preserving intentional silent turns and side-effect-only deliveries. (#80917) Thanks @dutifulbob.
- Agents/exec: skip redundant heartbeat wake-ups for subagent session exec completions, preventing spurious LLM invocations on parent sessions. Fixes #66748. (#66749) Thanks @ggzeng.
- Provider streams: keep OpenAI-compatible SSE and JSON fallback streams draining across split chunks and fail Azure Responses streams with a bounded first-event diagnostic instead of stalling. Refs #80926. (#80927) Thanks @galiniliev and @CaptainTimon.
- Agents: rewrite generic provider internal errors with support request IDs into user-friendly transient error copy. (#49401) Thanks @y471823206.
- WhatsApp: finish handling pending debounced inbound messages before closing the socket. (#81246) Thanks @mcaxtr.
- CLI/commitments: write `--json` output to stdout instead of diagnostic logs so automation can parse commitment list and dismiss results. (#81215) Thanks @giodl73-repo.
- Update: allow pnpm GitHub-source OpenClaw updates to approve the OpenClaw package build, so source installs complete their prepare/prepack lifecycle. (#81294) Thanks @fuller-stack-dev.
- Test state: seed isolated auth-profile secret keys for generated homes, preventing helper-backed proof runs from falling back to host Keychain secrets. (#81393) Thanks @altaywtf.
- Plugins/runtime: attribute deprecated runtime config load/write warnings to the plugin id and source that triggered them so logs and plugin doctor runs are actionable. Refs #81394. (#81425) Thanks @BKF-Gitty.
- Plugins/update: clear stale allow/deny entries and selected plugin slots when disabling a plugin after update failure, keeping failed external plugin updates from leaving half-disabled config. (#81512) Thanks @JARVIS-Glasses.
- Memory/LanceDB: make auto-capture recognize short CJK memory phrases and configurable literal triggers, so Chinese, Japanese, and Korean users can capture memories without regex or LLM intent detection. Fixes #75680. Thanks @vyctorbrzezowski and @guokewuming.
- Plugins doctor: report stale plugin config warnings and avoid claiming full plugin health when config warnings remain. (#81515) Thanks @BKF-Gitty.
- Sessions: display `model: "<agentId>-acp"` / `modelProvider: "acpx"` (ACP-runtime sentinel) for ACP control-plane sessions in `openclaw sessions` output, instead of the agent's configured model which was misleading. Catalog finding 20. (#79543)
- Slack: normalize message read `before` and `after` timestamp bounds before calling Slack history or thread reply APIs. Fixes #80835. (#81338) Thanks @honor2030.
### Changes
- Control UI: add a browser-local Text size setting in Appearance and Quick Settings, scaling chat and dense UI text while keeping inputs above the mobile Safari focus-zoom threshold. Fixes #8547. Thanks @BunsDev.
- Docs: add a dedicated ds4 provider page with local DeepSeek V4 Flash config, on-demand startup, context sizing, and live verification steps.
- Release validation: add a package-installed Docker user-journey lane that verifies onboarding, mocked model setup, external plugin install/uninstall, ClickClack outbound/inbound messaging, Gateway restart survival, and doctor.
- Release validation: add package-installed Docker lanes for real TTY onboarding, media and memory persistence, published-package upgrade journeys, and local marketplace plugin install/update/uninstall coverage.
- Maintainers: add a Clawdtributor skill for Discrawl-backed contributor PR triage, live status checks, and compact review formatting.
- Telegram: support Mini App `web_app` buttons in generic message presentation payloads, allowing `openclaw message send --presentation` to render Telegram Web App inline buttons for private chats. (#81356) Thanks @jzakirov.
- Scripts: add `OPENCLAW_HEAVY_CHECK_LOCK_SCOPE=worktree` so high-capacity local worktrees can use independent heavy-check locks while shared locks remain the default. Fixes #80729. (#80734) Thanks @samzong.
- Agents/subagents: deliver native `sessions_spawn` tasks in the child session's first visible `[Subagent Task]` message instead of hiding the task in the sub-agent system prompt, keeping delegation auditable without duplicating tokens. Fixes #78592. Thanks @bradestes and @stainlu.
- Messages/queue: make mid-turn prompts steer active runs by default via `/queue steer`, preserve `/queue followup` and `/queue collect` for users who want messages to queue by default, and make `/steer` continue as a normal prompt when steering is unavailable. (#77023) Thanks @fuller-stack-dev.
- Voice Call/Telnyx: add realtime media-streaming call support for conversational voice calls. (#81024) Thanks @dynamite-bud.
- Gateway/OpenAI HTTP: honor `max_completion_tokens` and `max_tokens` on inbound `/v1/chat/completions` requests so client-provided token caps reach the upstream provider via `streamParams.maxTokens`, with `max_completion_tokens` taking precedence when both are sent. Thanks @Lellansin.
- Models/OpenAI CLI auth: make `openclaw models auth login --provider openai` start the ChatGPT/Codex account login by default, while `--method api-key` remains the explicit OpenAI API-key setup path.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids inside explicit SDK OAuth auth-result config patches, so provider helpers emit `google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids inside SDK OAuth auth-result default config patches, so helper-built provider auth flows emit `google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids returned by direct `openclaw models auth login --set-default` provider auth flows before writing config, so Gemini testing targets `google/gemini-3.1-pro-preview`.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids in per-agent config defaults and auth patches, so agent-specific emitted config keeps targeting `google/gemini-3.1-pro-preview`.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids in provider catalog rows when API-key onboarding only reapplies the agent default, so emitted config keeps testing `google/gemini-3.1-pro-preview`.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids in `config set` mutation output for agent overrides and provider catalog rows, so current config emits `google/gemini-3.1-pro-preview`.
- Google/Gemini: canonicalize provider-qualified retired Gemini 3 Pro Preview refs during Google forward-compatible model resolution, so emitted config uses `google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- Google/Gemini: normalize proxy-prefixed retired Gemini 3 Pro Preview catalog rows, so emitted configs use `google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids inside per-agent model overrides before writing config, so agent-specific config emits `google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids in subagent, heartbeat, compaction, and subagent-tool model config during writes, so current config keeps emitting `google/gemini-3.1-pro-preview`.
- Docs/subagents: document `agents.defaults.subagents.announceTimeoutMs` in the sub-agent and configuration references. (#75509) Thanks @akrimm702.
- Cron: add direct `cron.get`, `openclaw cron get <id>`, and agent-tool `get` support for inspecting one stored cron job by id. (#75117) Thanks @samzong.
- Agents/tools: add per-sender tool policies with canonical channel-scoped sender keys, so operators can restrict dangerous tools by requester identity across global, agent, group, core, bundled, and plugin tool surfaces. (#66933) Thanks @JerranC.
- ACP: expose Gateway session lineage metadata through ACP session listings and session info snapshots so clients can render subagent graphs without private Gateway side channels. (#73458) Thanks @samzong.
- Channels/iMessage: add `openclaw channels status --channel <name>` filtering and document the BlueBubbles-to-imsg cutover path so operators can probe iMessage without starting both channel monitors. (#80706) Thanks @omarshahine.
- CI: add a non-blocking `plugin-inspector-advisory` artifact to Plugin Prerelease so release runs capture bundled plugin compatibility triage without changing the blocking gate.
- Runtime/Fly: detect Fly Machines as container environments from their runtime env vars, so gateway bind and Bonjour defaults match remote container launches. (#80209) Thanks @liorb-mountapps.
- Providers/fal: route GPT Image 2 and Nano Banana 2 reference-image edit requests to `/edit` with `image_urls` array, enforce NB2 edit geometry using `aspect_ratio` and `resolution` params, lift Fal edit mode input-image caps to 10 for GPT Image 2 and 14 for Nano Banana 2, and allow aspect-ratio hints in edit mode. (#77295) Thanks @leoge007.
- Control UI: show a plain HTML recovery panel when the app module never registers, giving blank dashboard pages a retry path and browser-extension troubleshooting link. Fixes #44107. Thanks @BunsDev.
- Docs: rename the broad tools nav to Capabilities, keep automation and agent coordination as sections, and keep the tools overview focused on tools, skills, and plugins. https://docs.openclaw.ai/tools
- Build: enable additional low-churn oxlint rules for promise, TypeScript, and runtime footgun checks.
- Build: enable stricter Vitest lint rules for focused, disabled, conditional, hook, matcher, and expectation hazards.
- Build: pin explicit oxfmt defaults in the shared formatter config to keep formatting behavior stable across upgrades.
- TypeScript: enable stricter compiler checks for implicit returns, side-effect imports, overrides, and unused production code.
- Logging: add targeted model transport, payload, SSE, and code-mode diagnostics with redacted URL handling.
- Agents: allow `session.agentToAgent.maxPingPongTurns` up to 20 while keeping the default at 5 for longer agent-to-agent reply chains. Fixes #52382. (#52400) Thanks @thirumaleshp.
- Agents: add per-agent `tools.message.crossContext` overrides so sandboxed/public agents can restrict message sends to the current conversation without changing the global bot policy.
- Agents: add per-agent `tools.message.actions.allow` overrides so sandboxed/public agents can expose and enforce send-only message tools.
- Agents: omit the sandbox workspace marker from compact command progress previews while keeping internal sandbox diagnostics unchanged.
- Agents: widen progress draft command preview lines by 50% so Discord inline tool updates preserve more useful command context.
- Codex app-server: retire timed-out app-server clients after bounded turn interrupts so Discord agents do not reuse a CPU-spinning Codex process after an attempt timeout.
- Codex app-server: default migrated native plugin destructive-action policy to enabled while preserving explicit global and per-plugin false overrides.
- Build: upgrade workspace package management to pnpm 11 and keep Docker, install, update, and release workflows on the pnpm 11 config surface. (#79414) Thanks @altaywtf.
- Build: align Telegram QA workflows and git source installs with the pnpm 11 workspace build allowlist surface. (#80588) Thanks @altaywtf.
- Models: add provider-level `localService` startup for on-demand local model servers before OpenAI-compatible requests, including one-shot model probes.
- Agents: trim default system prompt guidance and send-only message tool schemas to reduce prompt tokens while preserving GPT-5 personality guidance.
- Context: add `/context map` to send a treemap image of the current session context contributors. (#79867)
@@ -32,9 +182,13 @@ Docs: https://docs.openclaw.ai
- Talk: add `talk.realtime.instructions` so operators can append realtime voice style instructions while preserving OpenClaw's built-in agent-consult guidance. (#79081) Thanks @VACInc.
- Discord/voice: default test and source installs to the pure-JS `opusscript` decoder by ignoring optional native `@discordjs/opus` builds, avoiding slow native addon compiles outside dedicated voice-performance lanes.
- Discord/voice: add an opt-in native `@discordjs/opus` install script and decoder preference for live voice-performance lanes without charging unrelated Docker/tests for native addon builds.
- Discord/voice: add `voice.allowedChannels` to restrict voice joins and bot voice-state moves to configured channels while preserving open voice behavior when unset.
- Gateway/skills: add an opt-in private skill archive upload install path gated by `skills.install.allowUploadedArchives`, so trusted Gateway clients can stage and install zip-backed skills only when operators explicitly enable the code-install surface. (#74430) Thanks @samzong.
- Codex app-server: enable Codex native code-mode-only for harness threads so deferred OpenClaw dynamic tools run through Codex's own searchable code execution surface instead of a PI-style wrapper.
- Dependencies: refresh workspace pins and patch targets, including ACPX `@agentclientprotocol/claude-agent-acp` `0.33.1`, Codex ACP `0.14.0`, Baileys `7.0.0-rc10`, Google GenAI `2.0.1`, OpenAI `6.37.0`, AWS SDK `3.1045.0`, Kysely `0.29.0`, Tlon skill `0.3.6`, Aimock `1.19.5`, and tsdown `0.22.0`.
- Dependencies: refresh workspace pins for Anthropic SDK, Smithy shared ini loading, Playwright, YAML, Aimock, TypeScript native preview, Vitest, Oxlint/Oxfmt, Vite, and pnpm 11.1.0.
- Dependencies: hard-pin non-peer direct dependency specs across bundled packages and add a changed-check guard so runtime installs resolve the exact versions tested by maintainers.
- Dependencies: add release dependency evidence reports, npm advisory gating, and PR dependency-change awareness so maintainers can review dependency risk before and during releases. Thanks @joshavant.
- Dependencies: move embedded Pi packages to the `@earendil-works` namespace, refresh Twitch Twurple packages, and move `@openclaw/fs-safe` from the GitHub release pin to the published npm package.
- Build: route Testbox changed-check delegation through Crabbox and remove the OpenClaw-specific Blacksmith Testbox helper scripts.
- Agents/compaction: preserve scoped background exec/process session references across embedded compaction and after-turn runtime contexts without exposing sessions from unrelated scopes. Fixes #79284. (#79307) Thanks @TurboTheTurtle.
@@ -45,25 +199,97 @@ Docs: https://docs.openclaw.ai
- Dependencies: refresh workspace pins and move the WhatsApp plugin from `@whiskeysockets/baileys` to `baileys` while keeping the `7.0.0-rc10` runtime.
- Plugin SDK: add bundled-plugin session actions, `sendSessionAttachment`, and Cron-backed `scheduleSessionTurn`/tag cleanup under the grouped session namespace. Replaces #75578/#75581/#75588 and part of #73384/#74483. Thanks @100yenadmin.
- Plugin SDK/media-understanding: add `extractStructuredWithModel(...)` plus the optional provider-side `extractStructured(...)` seam so trusted plugins can run bounded image-first structured extraction with optional supplemental text context through provider-owned runtimes such as Codex.
- Exec approvals: add `tools.exec.commandHighlighting` so parser-derived command highlighting in approval prompts can be enabled globally or per agent. (#79348) Thanks @jesse-merhi.
- Codex app-server: mirror native Codex subagent spawn lifecycle events into Task Registry so app-server child agents appear in task/status surfaces without relying on transcript text. (#79512) Thanks @mbelinky.
- Gateway: expose optional `isHeartbeat` metadata on agent event payloads so clients can distinguish scheduled heartbeat runs from ordinary chat runs. (#80610) Thanks @medns.
- Agents: add `agents.defaults.runRetries` and `agents.list[].runRetries` config for embedded Pi runner retry loop limits. (#80661) Thanks @medns.
### Fixes
- Agents/heartbeat: fix seven layered issues that broke multi-agent heartbeat cadence — (1) fan out the scheduler broadcast wake across agents in parallel via `Promise.all` instead of awaiting each `runOnce` sequentially, so one agent doing real work no longer starves every later agent in iteration order; (2) scope `skipWhenBusy` to lanes attributable to the firing agent via session-key parsing of `session:agent:<id>:…` / `nested:agent:<id>:…` lane names, instead of consulting the global `subagent` lane, so a single stuck subagent on one agent no longer silently disables every other agent's heartbeat; (3) always append workspace `HEARTBEAT.md` directives (everything outside an optional `tasks:` block) to the dispatch prompt, so prose-runbook `HEARTBEAT.md` files reach the model directly instead of being silently dropped unless periodic tasks are declared; (4) race the initial stream-establishment promise inside `streamWithIdleTimeout` against the same watchdog timer that previously only guarded inter-token gaps, so SDK requests stuck at TCP/TLS handshake or before the first response byte no longer hang indefinitely (the stalled-session diagnostic's `recovery=none` case); (5) emit an `openclaw doctor` warning when `heartbeat.session` pins a session key that has no entry in the agent's session store, so silently-dropped heartbeat deliveries surface at config-validation time; (6) also route the commitment-only task dispatch path (tasks configured, none due) through `appendHeartbeatFileDirectives` so prose directives outside the `tasks:` block reach the model on this path as well; (7) wrap the synchronous `baseFn(...)` invocation inside `streamWithIdleTimeout` in a try/catch that clears the connect watchdog timer before rethrowing, so a provider stream function that throws during setup no longer leaves a live timer that can fire `onIdleTimeout` later with a stale error and keep the process open past the real failure. Thanks @zeroaltitude.
- Matrix: stop running `npm install`/`pnpm install` at runtime from a parent-derived plugin path; missing Matrix runtime dependencies now fail with repair guidance instead of mutating the wrong `node_modules` tree. Fixes #80758. (#80876) Thanks @kinjitakabe.
- CLI/media: render terminal QR codes with full-block characters by default so the bundled `qrcode` terminal renderer does not emit a pathologically dense ANSI final row in compact half-block mode that breaks scanning in some terminals. Fixes #77820. Thanks @KrasimirKralev.
- Agents/compaction: read post-compaction AGENTS.md refresh context from the queued run workspace instead of the runner process cwd, so CLI-backed follow-up turns re-inject the correct workspace startup rules after compaction. Fixes #70541. (#75532) Thanks @vyctorbrzezowski.
- Agents/read tool: treat positive offsets beyond EOF as empty ranges instead of surfacing the upstream read error, so stale pagination cursors no longer crash tool calls while unrelated read failures still fail loud. Fixes #62466. (#75536) Thanks @vyctorbrzezowski.
- Agents/memory-flush: surface non-abort memory-flush failures (provider timeout, transport error, generic agent failure) as visible reply payloads so the outer reply loop short-circuits and isolated cron runs propagate the error into `meta.error` instead of completing silently with `status: "ok"` and an empty payload. Previously only the specific "Memory flush writes are restricted to ..." message was surfaced. Fixes #80755. Thanks @nailujac.
- Google/Gemini: normalize retired Gemini 3 Pro Preview refs left in Google API-key onboarding model allowlists and fallbacks, so setup-emitted config keeps testing `google/gemini-3.1-pro-preview` instead of `google/gemini-3-pro-preview`.
- Telegram/context: bound selected topic context to the active session so messages from before `/new` or `/reset` are not replayed into later turns. (#80848) Thanks @VACInc.
- Google/Gemini: normalize retired nested Gemini 3 Pro Preview ids when resolving exact configured proxy-provider refs, so `kilocode/google/gemini-3-pro-preview` resolves to `kilocode/google/gemini-3.1-pro-preview` for Gemini 3.1 testing.
- CLI: strip generic OSC terminal escape payloads from sanitized output fields, preventing clipboard/title escape bodies from leaking into commitment tables and other terminal-safe text. Thanks @shakkernerd.
- Codex app-server: match connector-backed plugin approval elicitations by stable connector id so enabled destructive actions no longer fall through to display-name-only rejection.
- Build: replace selected build utility `tsx` preloads with Node native type stripping so Node 26 build paths no longer emit `DEP0205` module loader deprecation warnings. (#78584) Thanks @keshavbotagent.
- Channels/loop-guard: enforce shared per-pair bot loop protection in the core channel-turn kernel, with Discord, Slack, Matrix, and Google Chat supplying bot-pair facts where they can reliably identify accepted bot-authored messages. The generic guard keys on `(scope, conversation, participant pair)`, suppresses every additional bot-to-bot event in either direction once a pair crosses the configured budget, and lifts suppression after `cooldownSeconds`. Defaults are `maxEventsPerWindow: 20`, `windowSeconds: 60`, and `cooldownSeconds: 60` whenever a channel lets bot-authored messages reach dispatch; they can be set globally via `channels.defaults.botLoopProtection` and overridden per channel/account or supported per-conversation config. Fixes #58789. Thanks @pandadev66.
- Media generation: honor configured music and video generation timeouts when tool calls omit `timeoutMs`, matching image generation behavior. (#80687)
- CLI/update/status: label beta-channel plugin fallback and model-pricing refresh failures as warnings, keeping mixed beta/latest plugin cohorts visible without making core update or Gateway reachability look failed. Fixes #80689. Thanks @BKF-Gitty.
- Doctor/plugins: relink managed npm plugin `openclaw` peer dependencies during `doctor --fix`, while refusing to follow package-local `node_modules` symlinks outside the plugin package. (#77412) Thanks @TheCrazyLex.
- iMessage: route inbound tapbacks as reaction system events instead of normal messages, defaulting to bot-authored-message notifications while allowing `reactionNotifications: "off" | "own" | "all"` overrides. Fixes #60274; refs #39031 and #39322. Thanks @hyperclaw.
- Control UI/performance: scope Nodes polling to the active Nodes tab, debounce stale session-list reconciliation, and bound chat-side session refreshes so long-running dashboards avoid background reload churn. Thanks @BunsDev.
- Plugins/channels: explain bundled channel entry files that reach the legacy plugin loader as setup-runtime loader mismatches instead of generic missing-register failures. Thanks @chinar-amrutkar.
- Plugins/session-end: fire a typed `session_end` plugin hook with reason `shutdown` (or `restart` when a restart is expected) for every session that was still active when the gateway process stops. Previously SIGTERM/SIGINT/restart paths closed the gateway without enumerating active sessions, leaving downstream `session_end` plugins (e.g. claude-mem) with ghost rows accumulating across restarts. The new shutdown finalizer drains an in-memory tracker that is populated by `session_start` and forgotten by replace / reset / delete / compaction emitters, so previously-finalized sessions are never double-fired. The drain is bounded to a 2 s total budget so a slow plugin cannot block process exit. Adds `"shutdown"` and `"restart"` to `PluginHookSessionEndReason`. Fixes #57790. Thanks @pandadev66.
- Codex app-server: clamp Codex code-mode sandboxing to workspace-write when an OpenClaw sandbox is active, preventing Docker gateway socket access from becoming a danger-full-access Codex turn.
- TUI: exit immediately on Ctrl+C/SIGINT after gateway disconnect and bound shutdown drain so terminal teardown cannot strand sessions. Fixes #75379. (#75381) Thanks @udaymanish6.
- Matrix: default outbound markdown tables to bullet lists instead of fenced code blocks. Fixes #78990. (#80890) Thanks @kinjitakabe.
- Bonjour/Gateway: treat active ciao probing and fresh name-conflict renames as in-progress so the mDNS watchdog waits for probe settlement before retrying, preventing rapid re-advertise loops on Windows, WSL, and other multicast-hostile hosts. (#74778) Refs #74242. Thanks @fuller-stack-dev.
- Providers/MiniMax: send a minimal Anthropic-compatible user fallback when message conversion filters a turn to an empty payload, so MiniMax M2.7 no longer returns `chat content is empty` after tool-heavy sessions. Fixes #74589. Thanks @neeravmakwana and @DerekEXS.
- Tools/media: preserve implicit allow-all semantics from `tools.alsoAllow`-only policies when preconstructing built-in media generation and PDF tools, so configured media tools become live without forcing `tools.allow: ["*", ...]`. Fixes #77841. Thanks @trialanderrorstudios.
- Codex/Telegram: separate code-mode tool progress from final replies, render bridged tool calls with native tool labels, and repair persisted missing tool results for safer follow-up turns. (#80663) Thanks @jalehman.
- Memory/search: load the platform-specific `sqlite-vec-<platform>-<arch>` variant directly when the meta `sqlite-vec` package is missing from a global install, so vector recall keeps working on `npm install -g openclaw@latest` upgrades where optionalDependencies left only the platform variant on disk. Fixes #77838. Thanks @corevibe555 and @Simon2256928.
- Cron: keep long manual cron runs active in the task registry until completion, preventing transient `lost` markers before durable recovery reconciles. Fixes #78233. (#78243) Thanks @Feelw00.
- Doctor/GitHub CLI: surface a `GH_CONFIG_DIR` hint when the GitHub skill is usable but `gh` auth lives under a different operator HOME than the agent process, without warning for disabled or filtered skills. Fixes #78063. (#78095) Thanks @tmimmanuel.
- Gateway: dedupe concurrent `send`, `poll`, and `message.action` requests while delivery is still in flight, preventing duplicate outbound work for the same idempotency key. (#68341) Thanks @thesomewhatyou.
- Cron: keep main-session `systemEvent` heartbeat wakes on their bound session route for both direct and queued wake paths by dropping inherited explicit heartbeat destinations when forcing `target: "last"`. Fixes #73900. Thanks @richardmqq.
- Telegram: honor forced document delivery for video media so `--force-document` sends MP4s as documents instead of typed videos. Fixes #80389. (#80405) Thanks @jbetala7.
- Gateway: clear speculative node wake state when APNs registration is missing, preventing unregistered or mistyped node IDs from retaining wake throttle entries. Fixes #68847. (#68848) Thanks @Feelw00.
- Auto-reply: keep late follow-up queue drain finalizers from deleting a replacement queue registered after `/stop`, preventing immediate follow-up messages from being orphaned. Fixes #68838. (#68839) Thanks @Feelw00.
- Feishu: make manual App ID/App Secret setup the default channel-binding path while keeping QR scan-to-create as an optional best-effort flow, and document the manual fallback for domestic Feishu mobile clients that do not react to the QR code. Fixes #80591. Thanks @wei-wei-zhao.
- Memory: cap dreaming promotion writes to `MEMORY.md` by compacting oldest auto-promoted sections while preserving user-authored notes, keeping active memory below the bootstrap budget. Fixes #73691. (#74088) Thanks @YB0y.
- Telegram: show resolved thinking defaults in native `/status` and `/think` menus while preserving explicit session overrides. (#80341) Thanks @VACInc.
- Channels: cache selected channel registry lookups against the active fallback snapshot so pinned-empty registries refresh native command and alias routing after active registry swaps. (#80333) Thanks @samzong.
- Codex app-server: reuse native Codex CLI OAuth for isolated app-server harness login, refresh, and app inventory cache keys so ChatGPT-authenticated Codex runs no longer fall back to unauthenticated OpenAI API calls. (#79877) Thanks @jeffjhunter.
- Gateway: scope `sessions.resolve` sessionId and label store loads to the requested agent so large unrelated agent stores are not parsed for scoped lookups. Fixes #51264. (#79474) Thanks @samzong.
- Gateway: share serialized streaming event envelopes across eligible WebSocket and node subscribers while preserving per-client sequence numbers. (#80299) Thanks @samzong.
- Gateway: consolidate duplicate `openclaw doctor` service config panels while preserving the declined-repair `--force` hint. Fixes #80287. (#78688) Thanks @YB0y.
- Browser: report Chrome MCP existing-session page readiness in browser status without letting status probes exceed the client timeout. Fixes #80268. (#80280) Thanks @ai-hpc.
- WhatsApp: route opening-phase Baileys 428 connectionClosed through the WhatsApp reconnect policy and keep post-open 428 closes retryable, so transient setup socket closes retry with WhatsApp diagnostics instead of escaping as a bare `channel exited` error. Fixes #75736; mitigates #77443. Thanks @dataCenter430.
- Agents: disable Pi's default filesystem resource discovery for embedded runs while keeping OpenClaw inline extension factories active, avoiding Windows event-loop stalls during first WhatsApp-triggered agent startup. Fixes #77443. Thanks @dataCenter430.
- Providers/self-hosted: read model-scoped llama.cpp runtime context from `/props.default_generation_settings.n_ctx` while keeping top-level `n_ctx` as a fallback, so session budgeting reflects the loaded context window. Fixes #73664. (#74057) Thanks @brokemac79.
- Memory: reject symlinked directory components in configured extra memory paths before reading Markdown files. (#80331) Thanks @samzong.
- Sessions/transcripts: replace whole-file `readFile` scans with shared streaming helpers (`streamSessionTranscriptLines` and `streamSessionTranscriptLinesReverse`) for idempotency lookup, latest/tail assistant text reads, delivery-mirror dedupe, and compaction fork loading, so long-running sessions no longer materialize the full transcript in memory. Forward scans use `readline` over a bounded `createReadStream`; reverse scans read bounded chunks from the file end and decode complete JSONL lines newest-first without a fixed tail cap. Synthetic 200 MiB transcript: peak RSS delta drops from +252 MiB to +27 MiB while preserving malformed-line tolerance and idempotency-key return semantics. Fixes #54296. Thanks @jack-stormentswe.
- Browser/CDP: filter browser-internal targets from raw CDP and persistent Playwright tab selection so navigation opens real page tabs. Fixes #55734. Thanks @Demine4.
- WhatsApp: apply hot-reloaded `dmPolicy` and `allowFrom` settings to the active Web listener before processing new inbound DMs. Fixes #80538. Thanks @Ampaskopi129.
- Plugins: let `openclaw doctor --fix` repair managed plugin installs whose package entrypoints fail package-directory boundary validation after local state moves. Fixes #80592. Thanks @wei-wei-zhao.
- Voice-call: resume voice-originated exec approval follow-ups as internal non-delivery turns instead of rejecting them as `unknown channel: voice`. Fixes #80540. Thanks @patrickmch.
- Control UI: preserve the composer draft when Stop is tapped during an active chat run, preventing accidental prompt loss on mobile. Fixes #80586. Thanks @KCALLC.
- Infra/retry: keep jittered retry delays at or above server-supplied Retry-After lower bounds when the hint can be honored. Fixes #68541. (#68543) Thanks @Feelw00.
- Docs: clarify that `/model provider/model` is an exact session route, while duplicate bare model ids only use configured fallback order on non-session override paths. Refs #80562. Thanks @gaodaabao.
- Redact persisted secret-shaped payloads [AI]. (#79006) Thanks @pgondhi987.
- Agents: label `.openclaw/sandboxes` exec workdirs as sandbox runs in compact tool summaries instead of showing the full path.
- OpenAI Codex: surface browser OAuth and device-code login failures instead of treating failed logins as empty successful auth results. Refs #80363.
- CLI agents: carry runtime-only current-turn sender/reply context into CLI model prompts while keeping prompt-build hook input and transcript text clean.
- Control UI: keep workspace file presence checks from treating `fs-safe` stat helper failures as missing files, restoring Agents file status for existing Windows workspace files. Fixes #79953. Thanks @lovelefeng-glitch.
- Microsoft Foundry: report an explicit error when the Azure subscription prompt returns an id that is not present in the enabled subscription list, instead of continuing from an unsafe subscription assertion. (#62742) Thanks @oliviareid-svg.
- fix(matrix): gate name-based allowlist resolution [AI]. (#79007) Thanks @pgondhi987.
- Slack: include the bot's own root/parent message in new thread sessions so in-thread replies reach the agent with the parent text the user is responding to, instead of only `reply_to_id` metadata. Fixes #79338. Thanks @sxxtony.
- Docker: keep image builds on the source pnpm workspace policy so pnpm 11 can prune production dependencies without a Docker-only workspace rewrite.
- Agents/compaction: restore info-level gateway logs for embedded compaction start, completion, and incomplete outcomes. (#71961) Thanks @rubencu.
- Telegram: build reply-aware inbound turns through the shared channel context path so agents see the current reply target inline with the current message.
- Telegram: recover legacy message cache files that mixed JSON-array and line-delimited entries so restarted gateways preserve reply-window context. (#80567)
- Telegram: update the reply-context cache when messages are edited, so streamed bot replies appear in later agent context with their final text instead of the first draft.
- Skills/Windows: normalize compacted skill prompt locations to forward slashes after home-prefix compaction so Windows skill paths remain readable by model file tools. (#52200) Thanks @chienchandler.
- Control UI/Windows: update `@openclaw/fs-safe` so agent workspace file presence checks fall back correctly on Windows, preventing existing AGENTS.md, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, and MEMORY.md files from showing as missing. Fixes #79953. Thanks @lovelefeng-glitch.
- Memory: skip managed dreaming cron reconciliation warnings for ordinary cron and heartbeat hook contexts that cannot manage Gateway cron. (#77027) Thanks @rubencu.
- Cron: treat Codex app-server turn acceptance, CLI process spawn, and tool starts as execution milestones, preventing isolated runs from tripping the early startup watchdog after work has begun.
- Codex app-server: treat current-turn `<turn_aborted>` raw markers as terminal so interrupted native-tool turns release Discord agent sessions instead of waiting for the outer timeout.
- Yuanbao: bump `openclaw-plugin-yuanbao` to 2.13.1 to support `sourceReplyDeliveryMode: "automatic"` for group chat. (#79814) Thanks @loongfay.
- Memory: keep `memory_search` result `corpus` labels aligned with the hit source, so session transcript hits surface as `sessions` and memory-file hits stay `memory`. Fixes #72885. (#71898, #72886) Thanks @rubencu.
- Codex app-server: default native plugin app tool approvals to automatic so non-destructive read tools run when destructive actions are disabled.
- Codex app-server: expose OpenClaw's sandbox-routed shell as `sandbox_exec`/`sandbox_process` for non-Docker sandbox backends so SSH sandbox agents keep a correctly routed shell path without shadowing Codex native shell. Fixes #80322. Thanks @keramblock.
- Plugins: allow untracked local source plugins in the global extensions directory to load TypeScript package entries while keeping managed installs strict about compiled runtime output. Fixes #80503. Thanks @Kaspre.
- Google/Gemini: normalize retired nested Gemini 3 Pro Preview ids while converting manifest catalog rows into emitted provider config, so `google/gemini-3.1-pro-preview` is used for testing instead of `google/gemini-3-pro-preview`.
- Google/Gemini: normalize retired nested Gemini 3 Pro Preview ids inside saved model allowlists and fallback chains, so proxy routes like `openrouter/google/gemini-3-pro-preview` are persisted as Gemini 3.1 Pro Preview.
- Google/Gemini: normalize retired nested Gemini 3 Pro Preview ids in configured proxy/provider-auth model catalogs, so regenerated config keeps testing `google/gemini-3.1-pro-preview` instead of `google/gemini-3-pro-preview`.
- Google/Gemini: normalize retired nested Gemini 3 Pro Preview ids while onboarding provider catalog presets, so setup-emitted proxy configs test `google/gemini-3.1-pro-preview` instead of `google/gemini-3-pro-preview`.
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids in provider catalog rows during generic config writes, so unrelated config changes keep testing `google/gemini-3.1-pro-preview`.
- Models: keep configured fallback chains ahead of configured primary models for override selections with duplicate model ids, preventing fallback jumps to the wrong provider. Fixes #80562.
- Native apps: advertise the Gateway protocol compatibility range so chat and node sessions can connect to v3 gateways after additive v4 client updates.
- Gateway/agents: keep stale `sessions_send` ACP manager and `web_fetch` runtime chunks importable after package updates, preventing live gateways from breaking before restart. Fixes #78804. Thanks @Gomesy72.
- Gateway/install: preserve service environment value-source metadata in `openclaw gateway install`, so systemd reinstall paths keep env-file-backed secrets out of inline unit metadata. Refs #77406, #77427. Thanks @stainlu and @brokemac79.
@@ -77,6 +303,7 @@ Docs: https://docs.openclaw.ai
- Codex app-server: preserve prompt-local current-turn context through context-engine prompt projection, so replied-to Telegram messages stay visible to the Codex model input.
- Telegram: pass agent-scoped media roots through gateway message actions so workspace-local media from the active agent is not rejected as cross-agent access. Thanks @frankekn.
- CLI/gateway: keep `gateway status --deep` plugin-aware so configured plugin manifest warnings, including missing channel config metadata, stay visible during install and update smoke checks.
- Doctor/status: clarify gateway token source conflict warnings and suppress them inside the managed Gateway service credential context.
- Feishu: accept Schema 2 card callbacks whose operator identity is nested under `operator.user_id`, so card buttons dispatch instead of being dropped as malformed. Fixes #71670. (#71787) Thanks @rubencu.
- Feishu: fall back to a top-level group send when normal group quoted replies target a withdrawn or missing message, preventing replies from disappearing silently while preserving native topic safety. Fixes #79349. Thanks @arlen8411.
- Doctor: stop flagging the live compatibility agent directory as orphaned when the configured default agent is not `main`. Fixes #74313. (#74438) Thanks @carlos4s.
@@ -84,6 +311,8 @@ Docs: https://docs.openclaw.ai
- Context: render `/context map` only from actual run context and persist Codex app-server run reports without counting deferred tool-search schemas as prompt-loaded tool schemas.
- Codex app-server: report Codex-native tool execution to diagnostics so long-running native `bash`, web, file, and MCP tools no longer look like stale embedded runs to the watchdog. (#80217)
- Codex app-server: refresh Codex account rate limits after subscription usage-limit failures so Discord and other channel replies can show the next reset time instead of saying Codex returned none. Thanks @pashpashpash.
- Agents/auth: let Codex-backed OpenAI agent turns use `auth.order.openai` entries for Codex-compatible OAuth and API-key profiles while keeping existing `openai-codex` profile ordering valid.
- Codex app-server: emit async `after_tool_call` observations for native tool completions not covered by the native hook relay so observability plugins can record Codex-native tools. (#80372) Thanks @VACInc.
- Tasks: route group and channel task completions through the requester session so the parent agent can send the visible summary instead of stopping at a generic task-status line. Fixes #77251. (#77365) Thanks @funmerlin.
- Telegram: preserve blank lines between manually indented bullet blocks and following numbered sections in rendered replies. Fixes #76998. Thanks @evgyur.
- Agents/sandbox: allow read-only sandbox sessions to read the `/agent` workspace mount while keeping write/edit/apply_patch workspace-only guarded, restoring `read /agent/...` for `workspaceAccess: "ro"`. Fixes #39497. Thanks @stainlu and @teosborne.
@@ -101,8 +330,10 @@ Docs: https://docs.openclaw.ai
- Slack: prefer full rich-text block content over truncated socket-mode message previews so long inbound Slack messages reach agents intact. Fixes #79027. Thanks @BobAccentWebDev.
- Slack: include structured Slack API error details in setup, probe, streaming, and reply logs while preserving token redaction. (#53966) Thanks @deucemask.
- Gateway/agents: keep structured reasons when active-run queueing fails and deprecate the legacy boolean queue helper, so steering and subagent wake diagnostics distinguish completed, non-streaming, and compacting runs. Fixes #80156. Thanks @markus-lassfolk.
- System events: dedupe keyed events across the queue while preserving unkeyed, delivery-route, and trust-boundary event identity. (#73040) Thanks @statxc.
- Agents/UI: compact exec and tool progress rows by hiding redundant shell tool names, replacing known workspace paths with short context markers, and preserving Discord trace scrubbing for compact command lines.
- ACPX: run and await the embedded ACP backend startup probe by default so the gateway `ready` signal no longer fires before the acpx runtime has either become usable or reported a probe failure; set `OPENCLAW_ACPX_RUNTIME_STARTUP_PROBE=0` to restore lazy startup. Fixes #79596. Thanks @bzelones.
- Agents/memory-flush: surface non-abort memory-flush failures (provider timeout, transport error, generic agent failure) as visible reply payloads so the outer reply loop short-circuits and isolated cron runs propagate the error into `meta.error` instead of completing silently with `status: "ok"` and an empty payload. Previously only the specific "Memory flush writes are restricted to ..." message was surfaced. Refs #80755. Thanks @kinjitakabe and @nailujac.
- Gateway/status: surface model-pricing bootstrap and refresh failures as degraded health/status warnings while keeping Gateway liveness healthy. Fixes #79599. Thanks @bzelones.
- OpenAI-compatible models: strip prior assistant reasoning fields from replayed Chat Completions history by default, preventing oMLX/vLLM Qwen follow-up turns from rejecting or stalling on stale `reasoning` payloads. Fixes #46637. Thanks @zipzagster and @lexhoefsloot.
- CLI/onboarding: give non-Azure custom providers a safe generated context window and heal legacy 4k wizard entries without overwriting explicit valid small model limits, preventing first-turn compaction loops. Fixes #79428. (#79911) Thanks @Jefsky.
@@ -111,16 +342,21 @@ Docs: https://docs.openclaw.ai
- Ollama: stop native `/api/chat` requests from copying catalog `contextWindow` or `maxTokens` into `options.num_ctx` unless `params.num_ctx` is explicitly configured, avoiding pathological prompt-ingestion latency on local large-context models. Fixes #62267. Thanks @BenSHPD.
- Ollama: keep the model idle watchdog enabled for `*:cloud` models routed through a local Ollama host, so cloud-backed tool-loop stalls fail over visibly instead of inheriting local-model no-idle behavior. Fixes #79350. Thanks @geek111.
- Voice/Ollama: honor routed voice agent `tools.allow` for classic embedded voice responses, including empty allowlists, so no-tool Ollama agents do not receive tool schemas. Fixes #79506. Thanks @donkeykong91.
- Agents/doctor: warn when channel-routed agents cannot call the `message` tool, so operators can fix tool policy mismatches before explicit channel actions such as attachments or thread replies fail. Refs #80128. Thanks @jeffjhunterai.
- Gateway: reread config from disk after the first in-process restart loop startup, preventing SIGUSR1 restarts from reusing a stale startup snapshot and dropping config written after boot. Fixes #79947. Thanks @TheLevti.
- Codex app-server: deliver native image-generation outputs from Codex `savedPath` events as reply media, so blank-text image generation turns still attach the generated file. Thanks @keshavbotagent.
- Network/SSRF: keep pinned automatic DNS lookups on IPv4 when dual-stack hosts also publish AAAA records, and treat `EADDRNOTAVAIL` as a transient gateway network failure instead of a fatal crash. Fixes #80078. Thanks @takamasa-aiso.
- Control UI: show compact one-line live/idle/terminal run status badges in the Sessions table and rename the active-minute filter to its updated-within meaning. Fixes #78307. Thanks @BunsDev.
- Control UI: scope chat session-list refreshes by agent and skip disk-only agent store discovery for configured-only lists, preventing post-first-message session switching stalls on large Windows stores. Fixes #79675. Thanks @lovelefeng-glitch, @BunsDev.
- Control UI: allow Appearance tweakcn theme imports through the served CSP so browser-local custom theme links no longer fail with a `connect-src` violation. Fixes #78504. Thanks @BunsDev.
- Control UI/config: remove plugin allowlist entries that the form auto-added when a plugin enable toggle is reverted before saving, so reverting the visible toggle clears dirty state without persisting unintended allowlist changes. (#78329) Thanks @samzong.
- Gateway/mobile: reuse bootstrap-issued device-token scopes on handoff reconnects and surface device-token scope mismatches separately from token mismatches while preserving full shared-token dashboard/native sessions. Fixes #79292. Thanks @BunsDev.
- Media/host-read: allow buffer-verified gzip, tar, and 7z archives in the shared host-local media validator alongside ZIP and document attachments.
- Plugins/install: retry managed npm plugin installs without npm alias overrides after npm's `Invalid comparator: npm:` failure, so older npm versions can install official plugins instead of aborting. (#80539) Thanks @rubencu.
- Plugins/doctor: invalidate persisted plugin registry snapshots when plugin diagnostics point at deleted source paths, so `openclaw doctor` stops repeating stale warnings after a local extension is replaced by a managed npm plugin. Fixes #80087. (#80134) Thanks @hclsys.
- Doctor/OpenAI Codex: preserve Codex auth intent when auto-repairing legacy `openai-codex/*` model refs to canonical `openai/*` by adding provider/model-scoped Codex runtime policy, preventing repaired configs from falling through to direct OpenAI API-key auth. Fixes #78533 and #78570. Thanks @superck110 and @Azmodump.
- CLI/agents: surface durable message delivery status from `sendDurableMessageBatch` in `deliverAgentCommandResult` and `openclaw agent --json --deliver`, preserving suppressed hook outcomes as terminal no-retry results while exposing partial and failed sends for automation. Supersedes #53961 and #57755. Thanks @Kaspre.
- Agents: apply the LLM idle watchdog while provider stream setup is still pending, preventing silent pre-stream model hangs from waiting for the full agent timeout.
- Cron: let isolated self-cleanup runs inspect their own job run history while keeping other cron jobs and mutation actions blocked. Fixes #80019. Thanks @hclsys.
- Cron: report isolated agent-turn setup and pre-model stalls with phase-specific timeout errors instead of waiting for the full job budget when no model call starts. Fixes #74803. Thanks @jeffsteinbok-openclaw and @dgkim311.
- CLI/plugins: treat arbitrary unknown subcommands outside plugin CLI metadata as normal unknown commands instead of suggesting `plugins.allow`, while preserving allowlist guidance for real plugin command roots. Fixes #80109. (#80123) Thanks @kagura-agent.
@@ -145,6 +381,7 @@ Docs: https://docs.openclaw.ai
- Gateway/logging: install console capture before foreground Gateway fast-path parsing and suppress known libsignal session dumps even in verbose mode, preventing raw terminal logs from printing WhatsApp session key material. (#76306) Thanks @rubencu.
- Exec approvals: keep `exec.approval.list` on the lightweight policy-summary path so listing pending approvals no longer loads the rich tree-sitter command explainer. (#76943) Thanks @rubencu.
- Agents: surface concise default-visible warnings when `exec`/`bash` tool calls fail after the assistant claims success, while keeping raw stderr hidden unless verbose details are enabled. Fixes #60497. (#80003) Thanks @jbetala7.
- Channels/iMessage: keep redacted failed probe details in non-sensitive health snapshots so Full Disk Access failures no longer appear as configured/OK in status output. Fixes #79795.
- Agents: stop blank model-emitted tool calls before dispatch while preserving id-based tool-name recovery, preventing Kimi/NVIDIA blank-name retry loops without creating a callable `_blank` sentinel. Fixes #34129. (#56391) Thanks @smartchainark.
- Agents/Telegram: deliver the canonical final assistant answer instead of replaying accumulated pre-tool text blocks, preventing duplicate Telegram replies and raw-looking tool-output fragments from leaking into chat delivery. Fixes #79621 and #79986. Thanks @nonzeroclaw and @dudaefj.
- Auto-reply/TUI: keep fallback timeout recovery deliverable after a primary model lifecycle error by emitting fallback progress and deferring terminal TUI errors until recovery has a chance to finish. Fixes #80000. (#80009) Thanks @TurboTheTurtle.
@@ -175,6 +412,7 @@ Docs: https://docs.openclaw.ai
- Google/Gemini: normalize retired Gemini 3 Pro Preview ids inside provider auth config patches so setup-emitted provider catalogs test `google/gemini-3.1-pro-preview`.
- GitHub Copilot: mint short-lived Copilot API tokens with the same `vscode-chat` integration identity used by runtime requests, and refresh legacy cached tokens missing that identity so image-capable Copilot models no longer inherit the `copilot-language-server` scope. Fixes #79946, #80074. Thanks @TurboTheTurtle.
- Plugins/doctor: drop stale managed npm install records when `openclaw doctor --fix` removes npm packages that shadow bundled plugins, so the rebuilt registry no longer resurrects the removed package metadata.
- Doctor: warn when a per-agent model config omits the `fallbacks` key and `agents.defaults.model.fallbacks` is non-empty. Covers both string-form (`"model": "..."`) and partial-object form (`"model": { "primary": "..." }`) — both silently clobber the defaults chain at runtime. Use `"fallbacks": []` to explicitly opt out of fallbacks, or add `"fallbacks": [...]` to inherit or override. Fixes #79369. Thanks @Kaspre.
- Discord/voice: reuse or suppress late realtime consult tool calls without stealing newer speaker context or speaking forced fallback answers twice.
- Discord/voice: skip likely incomplete realtime forced-consult transcript fragments and non-actionable closings so stale partial speech does not queue delayed answers over the next turn.
- Discord/voice: keep realtime forced consults from clearing active exact-speech playback, so back-to-back voice answers queue instead of cutting each other off.
@@ -213,6 +451,10 @@ Docs: https://docs.openclaw.ai
- Agents/Pi: wait for embedded abort cleanup to settle before releasing the session write lock, preventing follow-up turns from racing previous prompt teardown. (#80239) Thanks @samzong.
- WhatsApp: downgrade OpenClaw watchdog-triggered Web reconnects from runtime errors to recovery warnings and clear the recovered reconnect status after the next healthy connection. (#77026) Thanks @rubencu.
- ACPX/Windows: hide the MCP proxy target child process window on Windows so ACP-backed agents do not flash or fail because of terminal window handling. Fixes #60672. (#60678) Thanks @KChow-ctrl.
- Agents: abort generic repeated no-progress tool loops at the critical threshold when identical calls keep returning identical outcomes. (#80668) Thanks @frankekn.
- Exec approvals: omit generated command highlights for non-POSIX Windows and shell-wrapper approval commands until those command languages have native highlighting support. (#80566) Thanks @jesse-merhi.
- Telegram: keep verbose tool progress and result drafts separate from the final assistant answer so tool output no longer blends into the final Telegram message. (#80294) Thanks @jalehman.
- Plugin SDK/Windows: enable the native require fast path for root `openclaw/plugin-sdk` dist aliases instead of forcing Jiti transforms. (#80878) Thanks @medns.
## 2026.5.9
@@ -220,6 +462,7 @@ Docs: https://docs.openclaw.ai
- Skills: add `skills.load.allowSymlinkTargets` so intentional symlinked skill folders can resolve into trusted sibling repos without disabling root containment.
- Agents/tools: add core Tool Search so agents can search and call large OpenClaw, MCP, and client tool catalogs through one compact PI bridge.
- Doctor: warn when a per-agent model config omits the `fallbacks` key and `agents.defaults.model.fallbacks` is non-empty. Covers both string-form (`"model": "..."`) and partial-object form (`"model": { "primary": "..." }`) — both silently clobber the defaults chain at runtime. Use `"fallbacks": []` to explicitly opt out of fallbacks, or add `"fallbacks": [...]` to inherit or override. Fixes #79369.
- Chat commands: add `/think default` and `/fast default` to clear session overrides and inherit configured/provider defaults. (#79385) Thanks @VACInc.
- Dependencies: refresh workspace dependency pins and lockfile, including `@openai/codex` `0.130.0`, `acpx` `0.7.0`, AWS SDK `3.1044.0`, OpenTelemetry `0.217.0`, `typebox` `1.1.38`, `vite` `8.0.11`, `oxfmt` `0.48.0`, and `oxlint` `1.63.0`, and update the Codex harness model snapshot for the new bundled app-server catalog.
- Plugins/install: add guarded plugin install overrides so onboarding and repair tests can route specific plugins to registry specs or local `npm pack` artifacts via environment variables.
@@ -264,6 +507,7 @@ Docs: https://docs.openclaw.ai
- Telegram/streaming: continue over-limit draft previews in a new message instead of stopping when rendered preview text crosses Telegram's message limit. (#74508) Thanks @anagnorisis2peripeteia.
- Slack: route handled top-level channel turns in implicit-conversation channels to thread-scoped sessions when Slack reply threading is enabled, keeping the root turn and later thread replies on one OpenClaw session. (#78522) Thanks @zeroth-blip.
- Telegram: re-probe the primary fetch transport after repeated sticky fallback success so transient IPv4 or pinned-IP fallback promotion can recover without a gateway restart. Fixes #77088. (#77157) Thanks @MkDev11.
- Agents/harness: skip tool-result middleware validation when no handler is registered, and sanitize incoming tool result `details` (functions, symbols, bigints, cycles, oversized payloads) before middleware sees them. Tool emitters legitimately produce raw dependency payloads on `details`, and the harness owes any registered middleware a JSON-safe view of that payload; otherwise a no-op middleware (e.g. bundled `tokenjuice` on the `pi` runtime) causes the validator to reject every tool result and silently substitute a failure sentinel, dropping outbound Discord messages, exec output, cron results, and any other tool whose payload carries non-serializable values. Thanks @solomonneas.
- Runtime/install: raise the supported Node 22 floor to `22.16+` so native SQLite query handling can rely on the `node:sqlite` statement metadata API while continuing to recommend Node 24. (#78921)
- Discord/voice: make duplicate same-guild auto-join entries resolve to the last configured channel so moving an agent between voice channels does not keep joining the stale channel.
- Discord/voice: add realtime `/vc` modes so Discord voice channels can run as STT/TTS, a realtime talk buffer with the OpenClaw agent brain, or a bidi realtime session with `openclaw_agent_consult`.
@@ -296,10 +540,12 @@ Docs: https://docs.openclaw.ai
- Matrix: move the Matrix channel back to an official external ClawHub/npm plugin so core installs no longer need Matrix SDK runtime dependencies.
- Matrix: attach `com.openclaw.presentation` metadata to semantic presentation replies so OpenClaw-aware Matrix clients can render rich buttons, selects, context rows, and dividers while stock clients keep the plain text fallback. (#73312) Thanks @kakahu2015.
- Codex app-server: disarm the short post-tool completion watchdog after current-turn activity, expose `appServer.turnCompletionIdleTimeoutMs`, and include raw assistant item context in idle-timeout diagnostics so status-only post-tool stalls stop failing as idle. Fixes #77984. Thanks @roseware-dev and @rubencu.
- Codex app-server: release the session lane after a completed assistant message item goes quiet without `turn/completed`, and stop global rate-limit notifications from keeping stuck turns alive.
- Plugin skills/Windows: publish plugin-provided skill directories as junctions on Windows so standard users without Developer Mode can register plugin skills without symlink EPERM failures. Fixes #77958. (#77971) Thanks @hclsys and @jarro.
- Process tool: show input-wait hints from `log` and `poll` for idle interactive background sessions so operators can inspect stuck CLIs and resume them with existing input actions. Fixes #33957. Thanks @bitloi and @vincentkoc.
- Shell env/Windows: hide the login-shell environment probe child window so gateway startup and shell-env refreshes do not flash a console on Windows. Fixes #78159. (#78266) Thanks @BradGroux.
- MS Teams: surface blocked Bot Framework egress by logging JWKS fetch network failures and adding a Bot Connector send hint for transport-level reply failures. Fixes #77674. (#78081) Thanks @Beandon13.
- Windows/restart: skip duplicate scheduled-task `/Run` calls when the gateway task is already running, using a locale-stable PowerShell task-state probe before retrying. Fixes #52044. (#52487) Thanks @andyk-ms.
- Media/host-read: allow buffer-verified ZIP archives in the host-local media validator so agents can send ZIP attachments via the message tool. Fixes #78057. (#78292) Thanks @Linux2010.
- Gateway/sessions: fast-path already-qualified model refs while building session-list rows so `openclaw sessions` and Control UI session lists avoid heavyweight model resolution on large stores. (#77902) Thanks @ragesaq.
- Contributor PRs: remind external contributors to redact private information like IP addresses, API keys, phone numbers, and non-public endpoints from real behavior proof. Thanks @pashpashpash.
@@ -337,6 +583,7 @@ Docs: https://docs.openclaw.ai
- Gateway/performance: reuse the compatible plugin metadata snapshot across dashboard and channel agent turns so auto-enabled runtime config does not repeatedly rescan plugin metadata before provider calls. Thanks @shakkernerd.
- Gateway/performance: reuse current plugin metadata for provider activation, auth/env candidate lookup, and bundle settings during dashboard and channel agent turns while keeping the configless secret-target cache unscoped and refusing stale unscoped reuse when plugin discovery roots differ. Thanks @shakkernerd.
- Gateway/performance: avoid resolving plugin auto-enable metadata twice in one runtime config pass, reducing repeated dashboard turn metadata scans. Thanks @shakkernerd.
- Control UI/performance: pre-scope config tab schemas before rendering, load Channels with cached/runtime status before manual probes, preserve channel rows through failed status summaries, and keep stale slow probes from replacing newer snapshots. Thanks @BunsDev.
- Auth/providers: pass `config` and `workspaceDir` lookup context through to provider-id resolution so workspace-scoped auth aliases resolve correctly when no explicit alias map is supplied. Thanks @shakkernerd.
- Gateway/diagnostics: add startup phase spans, active work labels, stale terminal bridge markers, and opt-in sync-I/O tracing in `pnpm gateway:watch` so slow Gateway turns are easier to attribute from logs and stability diagnostics.
- QA/Mantis: add an opt-in Discord thread attachment before/after scenario that creates a real thread, calls `message.thread-reply` with `filePath`, and captures baseline/candidate screenshot evidence.
@@ -380,6 +627,7 @@ Docs: https://docs.openclaw.ai
- Channels/iMessage: honor `channels.imessage.groups.<chat_id>.systemPrompt` (and the `groups["*"]` wildcard) by forwarding it as `GroupSystemPrompt` on inbound group turns, mirroring the byte-identical resolver semantic from WhatsApp where defining the key as an empty string on a specific group suppresses the wildcard fallback. Brings iMessage to parity with the per-group `systemPrompt` pattern already supported by Discord, Telegram, IRC, Slack, GoogleChat, and the retired BlueBubbles channel. Fixes #78285. (#79383) Thanks @omarshahine.
- iMessage: add opt-in inbound catchup that replays messages received while the gateway was offline (crash, restart, mac sleep) on next startup. Enable with `channels.imessage.catchup.enabled: true`; tunables for `maxAgeMinutes`, `perRunLimit`, `firstRunLookbackMinutes`, and `maxFailureRetries`. Persists a per-account cursor under the OpenClaw state dir (`<openclawStateDir>/imessage/catchup/`), replays each row through the live dispatch path so allowlists/group policy/dedupe behave identically on replayed and live messages, and force-advances past wedged guids after `maxFailureRetries` to prevent stuck cursors. Extends the persisted echo-cache retention window so the agent's own outbound rows from before a gap are not re-fed as inbound on replay. Includes a regenerated `src/config/bundled-channel-config-metadata.generated.ts` so the runtime AJV schema accepts the new `channels.imessage.catchup` block. Fixes #78649. (#79387) Thanks @omarshahine.
- Channels/Yuanbao: bump the bundled `openclaw-plugin-yuanbao` npm spec from `2.11.0` to `2.13.0` in the official external channel catalog and refresh the pinned integrity hash, so fresh installs and catalog-driven reinstalls pick up the newer Yuanbao channel plugin release. (#79620) Thanks @loongfay.
- Gateway/OpenAI-compatible Chat Completions: support function `tools`, `tool_choice`, `tool_calls`, and `role: "tool"` follow-up turns while keeping tool-call stream finalization aligned with the command result and reporting client-tool name conflicts as invalid requests. (#66278) Thanks @Lellansin.
- Providers/Mistral: add `mistral-medium-3-5` to the bundled catalog with reasoning support. Thanks @sliekens.
- Docs/Mistral: document Medium 3.5 setup, local infer smoke usage, adjustable reasoning, and the Mistral HTTP 400 caveat for `reasoning_effort="high"` with `temperature: 0`.
@@ -389,6 +637,10 @@ Docs: https://docs.openclaw.ai
### Fixes
- Models/auth: keep `agents.defaults.model` when `openclaw models auth login` runs without `--set-default`, so provider onboarding patches add models without silently switching the primary. Fixes #78162. (#78241) Thanks @neeravmakwana.
- Control UI/chat: localize the remaining chat welcome, composer, run-control, session/model/thinking selector, and zh-CN Skills labels through the Control UI i18n pipeline so non-English browser locales no longer see those chat controls in English. Fixes #79937. Thanks @BunsDev.
- Control UI: surface browser-blocked WebSocket security failures with wss:// and loopback dashboard guidance instead of leaving the connection on a dead security error. Thanks @BunsDev.
- Gateway/diagnostics: keep active-only transient event-loop max-delay samples as info-level stability telemetry instead of warning-level liveness diagnostics. Thanks @BunsDev.
- Google/Gemini: default new API-key onboarding to stable `google/gemini-2.5-flash` instead of the preview Pro route, reducing surprise daily quota exhaustion. Fixes #79670. Thanks @HugeBunny.
- Amazon Bedrock: expose Claude thinking profiles through the lightweight provider policy surface so `/think:adaptive` validates before the Bedrock runtime plugin is loaded. Fixes #79754. Thanks @phoenixyy and @hclsys.
- Codex/transcripts: mirror dynamic tool calls and outputs into Codex app-server transcripts so tool activity is visible alongside assistant text instead of being elided, with per-item output capped at 12,000 characters. (#79952) Thanks @scoootscooob.
@@ -440,6 +692,7 @@ Docs: https://docs.openclaw.ai
- QA-lab/parity: bump the live mock-openai parity baseline from `claude-opus-4-6`/`claude-sonnet-4-6` to `claude-opus-4-7`/`claude-sonnet-4-7` and the candidate alt from `gpt-5.4-alt` to `gpt-5.5-alt` in `openclaw-release-checks.yml` and `qa-live-transports-convex.yml`, matching the active Opus 4.7 / GPT-5.5 defaults already used elsewhere on main. Carries forward the surface-bump portion of #74290. Thanks @100yenadmin.
- QA-lab/scenarios: raise the `approval-turn-tool-followthrough` per-turn fallback timeouts from 20s/30s to 60s so cold mock-gateway parity runs do not flake on the approval-turn chain. Carries forward the timeout-bump portion of #74290. Thanks @100yenadmin.
- Gateway/restart continuation: treat routed post-reboot agent turns as trusted internal continuations while preserving the original Telegram topic route, and retry briefly when the previous run is still shutting down, so owner-only tools remain available for chained restart workflows after reboot.
- MS Teams: normalize pre-thread-qualified route session keys before deriving channel-thread lanes so cached route reuse cannot create malformed mixed `:thread:OLD:thread:NEW` sessions. Fixes #66771. (#78850) Thanks @harrisali0101.
- Agents/compaction: keep the recent tail after manual `/compact` when Pi returns an empty or no-op compaction summary, preventing blank checkpoints from replacing the live context.
- Native commands: handle slash commands before workspace and agent-reply bootstrap so Telegram `/status` and other command-only native replies do not wait behind full agent turn setup.
- Telegram/groups: include the recent local chat window and nearby reply-target window as generic inbound context so stale reply ancestry does not overshadow the live group conversation.
@@ -460,7 +713,7 @@ Docs: https://docs.openclaw.ai
- Control UI/chat: hide retired and non-public Google Gemini model IDs from chat model catalogs and route the bare `gemini-3-pro` alias to Gemini 3.1 Pro Preview instead of the shut-down Gemini 3 Pro Preview. Thanks @BunsDev.
- CLI/infer: canonicalize case-only catalog model refs in `infer model run --model` so mixed-case provider/model strings resolve to the canonical catalog entry instead of failing with `Unknown model`. (#78940) Thanks @ai-hpc.
- CLI/infer: allow explicit local `infer model run --model <provider/model>` probes to use exact bundled static catalog rows before the provider is written to config, surfacing missing credentials as auth errors instead of `Unknown model`.
- CLI/install: refuse state-mutating OpenClaw CLI runs as root by default, keep an explicit `OPENCLAW_ALLOW_ROOT=1` escape hatch for intentional root/container use, and update DigitalOcean setup guidance to run OpenClaw as a non-root user. Fixes #67478. Thanks @Jerry-Xin and @natechicago.
- CLI/install: revert the beta-only global root-refusal guard so existing root-managed VPS installs keep working; the DigitalOcean split-brain protection will move to a narrower image/install-specific path. Refs #67478 and #67509. Thanks @vincentkoc.
- Auto-reply/media: resolve `scp` from `PATH` when staging sandbox media so nonstandard OpenSSH installs can copy remote attachments.
- Agents/PI: route PI-native OpenAI-compatible default streams through OpenClaw boundary-aware transports so local-compatible model runs keep API-key injection and transport policy.
- Gateway/media: require authenticated owner or admin context for managed outgoing image bytes instead of trusting requester-session headers.
@@ -477,6 +730,7 @@ Docs: https://docs.openclaw.ai
- Gateway/live tests: avoid full model-registry enumeration for explicit provider-qualified live model filters, preventing `.profile` OpenAI gateway profile runs from hanging before provider dispatch.
- Gateway/status: surface CLI and gateway runtime versions, warn about stale PATH/global wrappers when they differ, and add stale-wrapper checks to the newer-config warning. Refs #79091. Thanks @RamaAditya49 and @sallyom.
- Google/Gemini: retry stalled Gemini 3 preview direct API-key streams with a lean first-response payload and share Gemini tool-schema cleanup across direct Google and Gemini CLI providers, so main sessions with coding tools can recover before the LLM idle watchdog fires. (#79668) Thanks @joshavant.
- Update/plugins: run a mandatory post-core convergence pass after `openclaw update` swaps the core package and before the gateway restarts, repairing missing configured plugin payloads, validating active install records including `openclaw.extensions`, and exiting with structured repair guidance instead of restarting the gateway with broken plugins. (#79143) Thanks @BKF-Gitty.
- Providers: preserve non-OK `text/event-stream` response bodies so provider HTTP errors keep their JSON detail instead of collapsing to generic streaming failures. Fixes #78180.
- Gateway/auth: make explicit `trusted-proxy` mode fail closed instead of accepting local password fallback credentials after trusted-proxy identity checks fail. Fixes #78684.
- Active memory: treat Google Chat `spaces/...` conversation ids as scoped targets instead of runnable channel names so recall runs no longer fail bundled-plugin dirName validation. Fixes #78918.
@@ -528,6 +782,8 @@ Docs: https://docs.openclaw.ai
- OpenRouter: keep the default `openrouter/auto` model ref canonical while preventing TUI and Control UI catalog pickers from displaying or submitting `openrouter/openrouter/auto`. Fixes #62655.
- Status/Claude CLI: show `oauth (claude-cli)` for working Claude CLI OAuth runtime sessions instead of `unknown` when no local auth profile exists. Fixes #78632. Thanks @gorkem2020.
- Memory search: preserve keyword-only hybrid FTS matches when vector scoring is unavailable or below the configured minimum score, so exact lexical hits are not dropped by weighted min-score filtering.
- Heartbeat/async exec: remap cron-run session keys to agent-main (or `"global"` under `session.scope=global`) at the bash exec, ACP, gateway node-event, and CLI watchdog enqueue sites, and treat cron-run descendants as ephemeral for retention pruning, so async exec completion events land in the same queue the heartbeat drains instead of being stranded under the ephemeral cron-run key. Refs #52305. Thanks @Kaspre.
- Wake protocol/system event CLI: type an optional `sessionKey` on `WakeParamsSchema`, add `--session-key` to `openclaw system event`, and keep cron enqueue/wake adapters resolving session-key-only targets symmetrically so callers can target a specific session for async-task completion relays instead of always hitting the agent's main session. Refs #52305. Thanks @Kaspre.
- Exec approvals/node: let trusted backend node invokes complete no-device Control UI approvals after the original request connection changes, while keeping node, command, cwd, env, and allow-once replay bindings enforced. Fixes #78569. Thanks @naturedogdog.
- Agents/subagents: keep background completion delivery on the requester-agent handoff/queue-retry path instead of raw-sending child results directly, and strip child-result wrapper or OpenClaw runtime-context scaffolding from queued outbound retries. Fixes #78531. Thanks @EthanSK.
- Sandbox: recreate cached browser bridges when JavaScript-evaluation permission changes, keep failed prune removals tracked for retry, and make cross-device directory moves copy-then-commit without partially emptying the source on failure.
@@ -537,6 +793,7 @@ Docs: https://docs.openclaw.ai
- Discord/groups: tell Discord-channel agents to wrap bare URLs as `<https://example.com>` so link previews do not expand into uninvited embeds. (#78614)
- Agents/fallback: fail fast on session write-lock timeouts instead of trying fallback models for local file contention. Fixes #66646. Thanks @sallyom.
- Browser/SSRF: stop closing user-owned Chrome tabs when a read-only operation (snapshot/screenshot/interactions) is rejected by the SSRF guard — only OpenClaw-initiated navigations now close on policy denial. Thanks @scotthuang.
- iMessage: stage native inbound attachments into OpenClaw-managed media and convert HEIC/HEIF images to JPEG before dispatch, so image tools can read photos sent over native iMessage without requiring BlueBubbles.
- Agents/Gateway: throttle and cap live exec command-output events so noisy tool runs cannot flood Gateway WebSocket clients or starve RPC handling. (#78645) Thanks @joshavant.
- Memory Wiki: skip empty and whitespace-only source pages when refreshing generated Related blocks, preventing blank pages from being rewritten into Related-only stubs. Fixes #78121. Thanks @amknight.
- Telegram: keep duplicate message-tool-only Codex turns from posting generic silent-reply fallback text, so private finals stay private after inbound dedupe. Thanks @rubencu.
@@ -547,10 +804,18 @@ Docs: https://docs.openclaw.ai
- Agents/DeepSeek: suppress provider-private DSML transport syntax (tool-use-error, tool-call, function-call shadow blocks) so it never leaks into assistant-visible text; native `delta.tool_calls` remains the only authoritative tool-call source. (#78331) Thanks @samzong.
- Agents/subagents: preserve the delegated task prompt when a spawned target agent uses `systemPromptOverride`, so `sessions_spawn(mode: "run")` child runs still see their assigned task. Fixes #77950. Thanks @amknight.
- Node/Windows: fall back to the Startup-folder launcher when Spanish-localized `schtasks` reports `Acceso denegado`, matching the existing access-denied fallback path. Fixes #77993. Thanks @jackonedev.
- Plugins/diagnostics: make source-only TypeScript package warnings actionable by explaining that missing compiled runtime output is a publisher packaging issue and pointing users to update/reinstall or disable/uninstall the plugin. Fixes #77835. Thanks @googlerest.
- Control UI/chat: keep persisted assistant progress text visible when the same transcript turn also contains tool-use metadata, so chat.history reloads no longer make those replies vanish after the next user message. Fixes #77374. Thanks @BunsDev.
- Cron: repair persisted future `nextRunAtMs` values that no longer line up with the cron schedule, so daily timezone-aware jobs do not stay jumped to stale future dates. Fixes #77867. Thanks @hongfangsong.
- Agents/memory: keep error payloads visible during silent maintenance turns, so restricted memory-flush tool writes surface as chat errors instead of disappearing behind a silent run. Fixes #77821. Thanks @praxstack.
- TUI: skip the generic CLI respawn wrapper for interactive launches, exit cleanly on terminal loss, and refuse to restore heartbeat sessions as the remembered chat session, preventing stale heartbeat history and orphaned `openclaw-tui` processes on first boot. Thanks @vincentkoc.
- Doctor/sessions: move heartbeat-poisoned default main session store entries to recovery keys and clear stale TUI restore pointers, so `doctor --fix` can repair instances already stuck on `agent:main:main` heartbeat history. Thanks @vincentkoc.
- Agents/context engines: keep hidden OpenClaw runtime-context custom messages out of context-engine assemble, afterTurn, and ingest hooks so transcript reconstruction plugins only see conversation messages. Thanks @vincentkoc.
- Agents/compaction: treat visible custom-message, bash, and branch-summary entries as real conversation anchors so safeguard mode does not write empty fallback summaries for cron and split-turn sessions with substantive tool work. Fixes #78300. Thanks @amknight.
- Network/runtime: avoid importing Undici's package dispatcher during no-proxy timeout bootstrap so external channel plugin fetch requests with explicit Content-Length keep working. Fixes #78007. Thanks @shakkernerd.
- Status/doctor: treat a single healthy OpenClaw Gateway listener on loopback, LAN, or wildcard bind as the expected configured gateway instead of warning that the port is already in use. Fixes #77939. Thanks @GitHoubi and @brokemac79.
- Agents/TTS: send media-bearing block replies directly when block streaming is off, so agent `tts` tool audio attached to a final text reply is delivered instead of being consumed before final Telegram/media delivery. Thanks @Conan-Scott.
- Doctor: avoid crashing on partial Linux environments when the legacy crontab probe or terminal note wrapper receives missing or non-string output. Fixes #77773. Thanks @brokemac79 and @blackflame7983.
- Gateway/performance: reuse the current compatible plugin metadata snapshot across hot read-only status, channel, auth, skills, and embedded agent settings paths, avoiding repeated synchronous plugin metadata scans during Gateway activity. Fixes #77983. Thanks @shakkernerd.
- Tasks/maintenance: prune stale cron run session registry entries while preserving running cron jobs and non-cron sessions. Fixes #73867. Thanks @brokemac79.
- Plugins: dispatch cached descriptor-backed tools by the resolved runtime tool name for unnamed factories, fixing multi-tool plugins whose shared manifest contracts exposed sibling tools but failed at execution. Fixes #78671. Thanks @zanni098.
@@ -696,6 +961,7 @@ Docs: https://docs.openclaw.ai
- Control UI/performance: keep chat and channel tabs responsive while history payloads and channel probes are slow, label partial channel status, and record slow chat/config render timings in the event log. Thanks @BunsDev.
- Control UI/sessions: fire the documented `/new` command and lifecycle hooks only for explicit Control UI session creation, restoring session-memory and custom hook capture without changing SDK parent-session creates. Fixes #76957. Thanks @BunsDev.
- Exec approvals: fall back to a guarded copy when Windows rejects rename-overwrite for `exec-approvals.json`, while preserving symlink, hard-link, and owner-only permission safeguards. Fixes #77785. (#77907) Thanks @Alex-Alaniz and @MilleniumGenAI.
- Status/session store: derive `totalTokens` for CLI backends from `agentMeta.lastCallUsage` (and set it on Claude CLI runs) so `/status` context usage is not shown as `?` while cache/token lines are populated. Fixes #78194. Thanks @neeravmakwana.
- Slack: preserve Socket Mode SDK error context and structured Slack API fields in reconnect logs, so startup failures no longer collapse to a bare `unknown error`.
- iOS pairing: allow setup-code and manual `ws://` connects for private LAN and `.local` gateways while keeping Tailscale/public routes on `wss://`, and prefer explicit gateway passwords over stale bootstrap tokens in mixed-auth reconnects. Fixes #47887; carries forward #65185. Thanks @draix and @BunsDev.
- Plugins/diagnostics: make source-only TypeScript package warnings actionable by explaining that missing compiled runtime output is a publisher packaging issue and pointing users to update/reinstall or disable/uninstall the plugin. Fixes #77835. Thanks @googlerest.
@@ -806,6 +1072,7 @@ Docs: https://docs.openclaw.ai
- Discord/status: add degraded Discord transport and gateway event-loop starvation signals to `openclaw channels status`, `openclaw status --deep`, and fetch-timeout logs so intermittent socket resets do not look like a healthy running channel. (#76327) Thanks @joshavant.
- Providers/OpenRouter: add opt-in response caching params that send OpenRouter's `X-OpenRouter-Cache`, `X-OpenRouter-Cache-TTL`, and cache-clear headers only on verified OpenRouter routes. Thanks @vincentkoc.
- Providers/OpenRouter: expand app-attribution categories so OpenClaw advertises coding, programming, writing, chat, and personal-agent usage on verified OpenRouter routes. Thanks @vincentkoc.
- Providers/OpenRouter: add inbound audio STT support to media-understanding via OpenRouter's JSON `/audio/transcriptions` contract, including default audio model metadata and auto-selection priority. (#77490) Thanks @remdev.
- Plugins/update: make package upgrades swap pnpm/npm-prefix installs cleanly, keep legacy plugin install runtime chunks working, and on the beta channel fall back default-line npm plugins to default/latest when plugin beta releases are missing or fail install validation. Thanks @vincentkoc and @joshavant.
- Channels/WhatsApp: support explicit WhatsApp Channel/Newsletter `@newsletter` outbound message targets with channel session metadata instead of DM routing. Fixes #13417; carries forward the narrow outbound target idea from #13424. Thanks @vincentkoc and @agentz-manfred.
- Exec approvals: add a tree-sitter-backed shell command explainer for future approval and command-review surfaces. (#75004) Thanks @jesse-merhi.
@@ -817,6 +1084,8 @@ Docs: https://docs.openclaw.ai
### Fixes
- Browser/chrome-mcp: read Chrome DevTools MCP screenshot output from the extension-suffixed path, fixing ENOENT on screenshot capture. Fixes #77222. (#74685) Thanks @barbarhan.
- macOS/launchd: set generated Gateway LaunchAgent plists to `ProcessType=Interactive` so the gateway keeps timely execution during idle periods. Fixes #58061; refs #62294 and closed duplicate #66992. (#62308) Thanks @bryanpearson and @zssggle-rgb.
- Plugins/install: honor the beta update channel for onboarding and doctor-managed plugin installs by requesting floating npm and ClawHub specs with `@beta` while keeping persistent install records on the catalog default. Thanks @vincentkoc.
- WhatsApp/onboarding: canonicalize setup and pairing allowlist entries to WhatsApp's digit-only phone ids while still accepting E.164, JID, and `whatsapp:` inputs, so personal-phone allowlists match WhatsApp Web sender ids after setup. Thanks @vincentkoc.
@@ -1255,6 +1524,7 @@ Docs: https://docs.openclaw.ai
- Plugins/npm: build package-local runtime dist files for publishable plugins and stop listing root-package-excluded plugin sidecars in the core package metadata, so npm plugin installs such as `@openclaw/diffs` and `@openclaw/discord` no longer publish source-only runtime payloads. Fixes #76426. Thanks @PrinceOfEgypt.
- Channels/secrets: resolve SecretRef-backed channel credentials through external plugin secret contracts after the plugin split, covering runtime startup, target discovery, webhook auth, disabled-account enumeration, and late-bound web_search config. Fixes #76371. (#76449) Thanks @joshavant and @neeravmakwana.
- Docker/Gateway: pass Docker setup `.env` values into gateway and CLI containers and preserve exec SecretRef `passEnv` keys in managed service plans, so 1Password Connect-backed Discord tokens keep resolving after doctor or plugin repair. Thanks @vincentkoc.
- Exec/security: treat configured `tools.exec.security` as authoritative for normal tool calls so model-supplied `security` arguments cannot downgrade or tighten the operator policy, while preserving explicitly granted elevated-full overrides. (#65933) Thanks @bryanpearson.
- Control UI/WebChat: explain compaction boundaries in chat history and link directly to session checkpoint controls so pre-compaction turns no longer look silently lost after refresh. Fixes #76415. Thanks @BunsDev.
- Agents/compaction: add an optional bundled compaction notifier hook and retry once from the compacted transcript when automatic compaction leaves a turn without a final visible reply. (#76651) Thanks @simplyclever914.
- Agents/incomplete-turn: detect and surface a warning when the agent's final text after a tool-call chain is silently dropped because the post-tool assistant response was never produced, instead of completing the turn with only the pre-tool analysis text. Fixes #76477. Thanks @amknight.
@@ -1805,6 +2075,7 @@ Docs: https://docs.openclaw.ai
- Gateway/sessions: stream bounded transcript reads for session detail, history, artifacts, compaction, and send/subscribe sequence paths so small Gateway requests no longer materialize large transcripts or OOM on oversized session logs. Thanks @vincentkoc.
- Gateway/chat: bound chat-history transcript reads to the requested display window so large session logs no longer OOM the Gateway when clients ask for a small history page. Thanks @vincentkoc.
- BlueBubbles: detect audio attachments by Apple UTIs (`public.audio`, `public.mpeg-4-audio`, `com.apple.m4a-audio`, `com.apple.coreaudio-format`) in addition to `audio/*` MIME, so iMessage voice notes whose webhook payload only carries the UTI are now classified as audio in the inbound `<media:audio>` placeholder instead of falling through to the generic `<media:attachment>` tag. Thanks @omarshahine.
- Active Memory: classify topic-threaded Telegram DM main session keys as direct chats, so recall and transcript persistence run for `agent:main:main:thread:{chatId}:{topicId}` sessions. Fixes #70061. (#75533) Thanks @vyctorbrzezowski.
- Voice Call/Twilio: honor stored pre-connect TwiML before realtime webhook shortcuts and reject DTMF sequences outside conversation mode, so Meet PIN entry cannot be skipped or silently dropped. Thanks @donkeykong91 and @PfanP.
- Docs/sandboxing: clarify that sandbox setup scripts (`sandbox-setup.sh`, `sandbox-common-setup.sh`, `sandbox-browser-setup.sh`) are only available from a source checkout, and add inline `docker build` commands for npm-installed users so sandbox image setup works without cloning the repo. Fixes #75485. Thanks @amknight.
- Google Meet/Voice Call: play Twilio Meet DTMF before opening the realtime media stream and carry the intro as the initial Voice Call message, so the greeting is generated after Meet admits the phone participant instead of racing a live-call TwiML update. Thanks @donkeykong91 and @PfanP.
@@ -1929,6 +2200,7 @@ Docs: https://docs.openclaw.ai
- QQBot: unify slash command auth and c2cOnly gating in the command registry, pass `allowQQBotDataDownloads` when sending slash command file attachments, align clear-storage with actual downloads directory, and add `/bot-me` to display sender user ID. (#73616) Thanks @cxyhhhhh.
- CLI/agents/status: keep `openclaw agents`, text `agents list`, and plain text `status` on read-only metadata paths so human output no longer preloads plugin runtimes or live channel scans before printing. Fixes #74195. Thanks @NianJiuZst.
- Agents/local models: derive context-window guard thresholds from the effective model window with 4k/8k safety floors, so small local models are no longer rejected by fixed 16k/32k preflight cutoffs. Fixes #42999. Thanks @chengjialu8888.
- Providers/media: retry transient provider 5xx, timeout, and selected network failures on the same API key for opted-in media and Google embedding calls while preserving 429 key rotation. Fixes #60422. Thanks @sqsge.
- PDF extraction: resolve PDF.js standard fonts from the installed package root and pass a filesystem path to the Node fallback extractor, so built-in font PDFs render without `file://` URL lookup failures. Fixes #51455; carries forward #70936, #54447, and #62175. Thanks @anyech, @JuanRdBO, and @solomonneas.
- Media: treat legacy Word/OLE attachments with `application/msword` or `application/x-cfb` MIME as binary so printable-looking `.doc` files are not embedded into prompts as text. Fixes #54176; carries forward #54380. Thanks @andyliu.
- Config: accept documented `browser.tabCleanup` keys in strict root config validation, so configured tab cleanup no longer fails before runtime reads it. Fixes #74577. Thanks @lonexreb and @ezdlp.
@@ -2281,6 +2553,7 @@ Docs: https://docs.openclaw.ai
### Fixes
- Channels/QQBot: re-evaluate routing bindings against the current runtime config on every inbound message instead of the snapshot captured at gateway start, so peer-specific bindings added via the CLI take effect without restarting the gateway. Fixes #69546 via #73567. Thanks @statxc and @F32138.
- CLI/channel-setup: auto-skip the redundant "Install \<plugin\>?" confirmation when only one install source (npm or local) exists, show `download from <npm-spec>` hints for installable catalog channels in the picker, and suppress misleading npm hints for already-bundled channels. Fixes #73419. Thanks @sliverp.
- BlueBubbles: tighten DM-vs-group routing across the outbound session route (`chat_guid:iMessage;-;...` DMs no longer classified as groups), reaction handling (drop group reactions that arrive without any chat identifier instead of synthesizing a `"group"` literal peerId), inbound `chatGuid` fallback (no longer fall back to the sender's DM chatGuid when resolving a group whose webhook omits chatGuid+chatId+chatIdentifier), and short message id resolution (carry caller chat context so a numeric short id reused after a long group conversation cannot silently resolve to a message in a different chat, with the same cross-chat guard applied to full GUIDs so retries cannot bypass it). Thanks @zqchris.
- Gateway/sessions: clone cached session stores through the persisted JSON shape instead of `structuredClone`, reducing native-memory growth on the remaining #54155 Gateway RSS/session-accumulation path while keeping #54155 as the broader tracker and carrying forward the #45438 session-cache hypothesis. Thanks @vincentkoc and the #45438 reporters/commenters.

View File

@@ -107,6 +107,7 @@ For coordinated change sets that genuinely need more than 20 PRs, join the **#cl
- Test locally with your OpenClaw instance
- External PRs must include a filled **Real behavior proof** section in the PR body. Show the real setup you tested, the exact command or steps you ran after the patch, after-fix evidence, the observed result, and anything you did not test. Screenshots, recordings, terminal screenshots, console output, copied live output, linked artifacts, and redacted runtime logs all count. Unit tests, mocks, snapshots, lint, typechecks, and CI are useful but do not satisfy this requirement by themselves. Maintainers may apply `proof: override` only when the proof gate should not apply.
- Do not edit `CHANGELOG.md` in contributor PRs. Maintainers or ClawSweeper add the changelog entry when landing user-facing changes.
- Run tests: `pnpm build && pnpm check && pnpm test`
- For iterative local commits, `scripts/committer --fast "message" <files...>` passes `FAST_COMMIT=1` through to the pre-commit hook so it skips the repo-wide `pnpm check`. Only use it when you've already run equivalent targeted validation for the touched surface.
- For extension/plugin changes, run the fast local lane first:

View File

@@ -1,5 +1,3 @@
# syntax=docker/dockerfile:1.7
# Opt-in plugin dependencies at build time (space- or comma-separated directory names).
# Example: docker build --build-arg OPENCLAW_EXTENSIONS="diagnostics-otel,matrix" .
#

View File

@@ -65,8 +65,8 @@ android {
applicationId = "ai.openclaw.app"
minSdk = 31
targetSdk = 36
versionCode = 2026051000
versionName = "2026.5.10"
versionCode = 2026051200
versionName = "2026.5.12"
ndk {
// Support all major ABIs — native libs are tiny (~47 KB per ABI)
abiFilters += listOf("armeabi-v7a", "arm64-v8a", "x86", "x86_64")

View File

@@ -1612,15 +1612,6 @@ internal fun resolveOperatorSessionConnectAuth(
)
}
val explicitBootstrapToken = auth.bootstrapToken?.trim()?.takeIf { it.isNotEmpty() }
if (explicitBootstrapToken != null) {
return NodeRuntime.GatewayConnectAuth(
token = null,
bootstrapToken = explicitBootstrapToken,
password = null,
)
}
return null
}

View File

@@ -1,4 +1,4 @@
package ai.openclaw.app.gateway
const val GATEWAY_PROTOCOL_VERSION = 4
const val GATEWAY_MIN_PROTOCOL_VERSION = 3
const val GATEWAY_MIN_PROTOCOL_VERSION = 4

View File

@@ -64,6 +64,7 @@ data class GatewayConnectErrorDetails(
val code: String?,
val canRetryWithDeviceToken: Boolean,
val recommendedNextStep: String?,
val pauseReconnect: Boolean? = null,
val reason: String? = null,
)
@@ -736,6 +737,7 @@ class GatewaySession(
code = it["code"].asStringOrNull(),
canRetryWithDeviceToken = it["canRetryWithDeviceToken"].asBooleanOrNull() == true,
recommendedNextStep = it["recommendedNextStep"].asStringOrNull(),
pauseReconnect = it["pauseReconnect"].asBooleanOrNull(),
reason = it["reason"].asStringOrNull(),
)
}
@@ -1040,20 +1042,17 @@ class GatewaySession(
detailCode == "AUTH_TOKEN_MISMATCH"
}
private fun shouldPauseReconnectAfterAuthFailure(error: ErrorShape): Boolean =
when (error.details?.code) {
"AUTH_TOKEN_MISSING",
"AUTH_BOOTSTRAP_TOKEN_INVALID",
"AUTH_PASSWORD_MISSING",
"AUTH_PASSWORD_MISMATCH",
"AUTH_RATE_LIMITED",
"PAIRING_REQUIRED",
"CONTROL_UI_DEVICE_IDENTITY_REQUIRED",
"DEVICE_IDENTITY_REQUIRED",
-> true
"AUTH_TOKEN_MISMATCH" -> deviceTokenRetryBudgetUsed && !pendingDeviceTokenRetry
else -> false
}
private fun shouldPauseReconnectAfterAuthFailure(error: ErrorShape): Boolean {
val target = desired
return shouldPauseGatewayReconnectAfterAuthFailure(
error = error,
hasBootstrapToken = target?.bootstrapToken?.trim()?.isNotEmpty() == true,
role = target?.options?.role,
scopes = target?.options?.scopes ?: emptyList(),
deviceTokenRetryBudgetUsed = deviceTokenRetryBudgetUsed,
pendingDeviceTokenRetry = pendingDeviceTokenRetry,
)
}
private fun shouldClearStoredDeviceTokenAfterRetry(error: ErrorShape): Boolean = error.details?.code == "AUTH_DEVICE_TOKEN_MISMATCH"
@@ -1068,6 +1067,36 @@ class GatewaySession(
}
}
internal fun shouldPauseGatewayReconnectAfterAuthFailure(
error: GatewaySession.ErrorShape,
hasBootstrapToken: Boolean,
role: String?,
scopes: List<String>,
deviceTokenRetryBudgetUsed: Boolean,
pendingDeviceTokenRetry: Boolean,
): Boolean =
when (error.details?.code) {
"AUTH_TOKEN_MISSING",
"AUTH_BOOTSTRAP_TOKEN_INVALID",
"AUTH_PASSWORD_MISSING",
"AUTH_PASSWORD_MISMATCH",
"AUTH_RATE_LIMITED",
"CONTROL_UI_DEVICE_IDENTITY_REQUIRED",
"DEVICE_IDENTITY_REQUIRED",
-> true
"PAIRING_REQUIRED" ->
!(
hasBootstrapToken &&
role?.trim() == "node" &&
scopes.isEmpty() &&
error.details.reason == "not-paired" &&
(error.details.pauseReconnect == false ||
error.details.recommendedNextStep == "wait_then_retry")
)
"AUTH_TOKEN_MISMATCH" -> deviceTokenRetryBudgetUsed && !pendingDeviceTokenRetry
else -> false
}
internal fun buildGatewayWebSocketUrl(
host: String,
port: Int,

View File

@@ -29,14 +29,14 @@ import java.util.UUID
@Config(sdk = [34])
class GatewayBootstrapAuthTest {
@Test
fun connectsOperatorSessionWhenOnlyBootstrapAuthExists() {
assertTrue(
fun doesNotConnectOperatorSessionWhenOnlyBootstrapAuthExists() {
assertFalse(
shouldConnectOperatorSession(
NodeRuntime.GatewayConnectAuth(token = "", bootstrapToken = "bootstrap-1", password = ""),
storedOperatorToken = "",
),
)
assertTrue(
assertFalse(
shouldConnectOperatorSession(
NodeRuntime.GatewayConnectAuth(token = null, bootstrapToken = "bootstrap-1", password = null),
storedOperatorToken = null,
@@ -84,17 +84,14 @@ class GatewayBootstrapAuthTest {
}
@Test
fun resolveOperatorSessionConnectAuthUsesBootstrapWhenNoStoredOperatorTokenExists() {
fun resolveOperatorSessionConnectAuthIgnoresBootstrapWhenNoStoredOperatorTokenExists() {
val resolved =
resolveOperatorSessionConnectAuth(
auth = NodeRuntime.GatewayConnectAuth(token = null, bootstrapToken = "bootstrap-1", password = null),
storedOperatorToken = null,
)
assertEquals(
NodeRuntime.GatewayConnectAuth(token = null, bootstrapToken = "bootstrap-1", password = null),
resolved,
)
assertNull(resolved)
}
@Test
@@ -174,7 +171,7 @@ class GatewayBootstrapAuthTest {
assertEquals("fp-1", prefs.loadGatewayTlsFingerprint(endpoint.stableId))
assertEquals("setup-bootstrap-token", desiredBootstrapToken(runtime, "nodeSession"))
assertEquals("setup-bootstrap-token", desiredBootstrapToken(runtime, "operatorSession"))
assertNull(desiredBootstrapToken(runtime, "operatorSession"))
}
@Test

View File

@@ -0,0 +1,116 @@
package ai.openclaw.app.gateway
import org.junit.Assert.assertFalse
import org.junit.Assert.assertTrue
import org.junit.Test
class GatewaySessionReconnectTest {
@Test
fun bootstrapNodePairingRequiredKeepsReconnectActive() {
val error =
GatewaySession.ErrorShape(
code = "NOT_PAIRED",
message = "pairing required",
details =
GatewayConnectErrorDetails(
code = "PAIRING_REQUIRED",
canRetryWithDeviceToken = false,
recommendedNextStep = "wait_then_retry",
pauseReconnect = false,
reason = "not-paired",
),
)
assertFalse(
shouldPauseGatewayReconnectAfterAuthFailure(
error = error,
hasBootstrapToken = true,
role = "node",
scopes = emptyList(),
deviceTokenRetryBudgetUsed = false,
pendingDeviceTokenRetry = false,
),
)
}
@Test
fun bootstrapNodePairingRequiredWithoutRetryHintPausesReconnect() {
val error =
GatewaySession.ErrorShape(
code = "NOT_PAIRED",
message = "pairing required",
details =
GatewayConnectErrorDetails(
code = "PAIRING_REQUIRED",
canRetryWithDeviceToken = false,
recommendedNextStep = null,
reason = "not-paired",
),
)
assertTrue(
shouldPauseGatewayReconnectAfterAuthFailure(
error = error,
hasBootstrapToken = true,
role = "node",
scopes = emptyList(),
deviceTokenRetryBudgetUsed = false,
pendingDeviceTokenRetry = false,
),
)
}
@Test
fun nonBootstrapPairingRequiredStillPausesReconnect() {
val error =
GatewaySession.ErrorShape(
code = "NOT_PAIRED",
message = "pairing required",
details =
GatewayConnectErrorDetails(
code = "PAIRING_REQUIRED",
canRetryWithDeviceToken = false,
recommendedNextStep = "wait_then_retry",
reason = "not-paired",
),
)
assertTrue(
shouldPauseGatewayReconnectAfterAuthFailure(
error = error,
hasBootstrapToken = false,
role = "node",
scopes = emptyList(),
deviceTokenRetryBudgetUsed = false,
pendingDeviceTokenRetry = false,
),
)
}
@Test
fun bootstrapRoleUpgradeStillPausesReconnect() {
val error =
GatewaySession.ErrorShape(
code = "NOT_PAIRED",
message = "pairing required",
details =
GatewayConnectErrorDetails(
code = "PAIRING_REQUIRED",
canRetryWithDeviceToken = false,
recommendedNextStep = null,
reason = "role-upgrade",
),
)
assertTrue(
shouldPauseGatewayReconnectAfterAuthFailure(
error = error,
hasBootstrapToken = true,
role = "node",
scopes = emptyList(),
deviceTokenRetryBudgetUsed = false,
pendingDeviceTokenRetry = false,
),
)
}
}

View File

@@ -1,5 +1,9 @@
# OpenClaw iOS Changelog
## 2026.5.12 - 2026-05-12
Maintenance update for the current OpenClaw beta release.
## 2026.5.10 - 2026-05-10
Maintenance update for the current OpenClaw beta release.

View File

@@ -2,8 +2,8 @@
// Source of truth: apps/ios/version.json
// Generated by scripts/ios-sync-versioning.ts.
OPENCLAW_IOS_VERSION = 2026.5.10
OPENCLAW_MARKETING_VERSION = 2026.5.10
OPENCLAW_IOS_VERSION = 2026.5.12
OPENCLAW_MARKETING_VERSION = 2026.5.12
OPENCLAW_BUILD_VERSION = 1
#include? "../build/Version.xcconfig"

View File

@@ -1,3 +1,3 @@
{
"version": "2026.5.10"
"version": "2026.5.12"
}

View File

@@ -521,7 +521,8 @@ actor MacNodeRuntime {
let sessionKey = (params.sessionKey?.trimmingCharacters(in: .whitespacesAndNewlines).isEmpty == false)
? params.sessionKey!.trimmingCharacters(in: .whitespacesAndNewlines)
: self.mainSessionKey
let runId = UUID().uuidString
let providedRunId = params.runId?.trimmingCharacters(in: .whitespacesAndNewlines) ?? ""
let runId = providedRunId.isEmpty ? UUID().uuidString : providedRunId
let envOverrideDiagnostics = HostEnvSanitizer.inspectOverrides(
overrides: params.env,
blockPathOverrides: true)

View File

@@ -15,9 +15,9 @@
<key>CFBundlePackageType</key>
<string>APPL</string>
<key>CFBundleShortVersionString</key>
<string>2026.5.10</string>
<string>2026.5.12</string>
<key>CFBundleVersion</key>
<string>2026051000</string>
<string>2026051200</string>
<key>CFBundleIconFile</key>
<string>OpenClaw</string>
<key>CFBundleURLTypes</key>

View File

@@ -16,6 +16,7 @@ struct ConnectOptions {
var displayName: String?
var role: String = "operator"
var scopes: [String] = defaultOperatorConnectScopes
var scopesAreExplicit: Bool = false
var help: Bool = false
static func parse(_ args: [String]) -> ConnectOptions {
@@ -43,6 +44,7 @@ struct ConnectOptions {
"--scopes": { opts, raw in
opts.scopes = raw.split(separator: ",").map { $0.trimmingCharacters(in: .whitespacesAndNewlines) }
.filter { !$0.isEmpty }
opts.scopesAreExplicit = true
},
]
var i = 0
@@ -126,6 +128,7 @@ func runConnect(_ args: [String]) async {
let connectOptions = GatewayConnectOptions(
role: opts.role,
scopes: opts.scopes,
scopesAreExplicit: opts.scopesAreExplicit,
caps: [],
commands: [],
permissions: [:],

View File

@@ -4,6 +4,7 @@ import OpenClawProtocol
import Testing
@testable import OpenClaw
@Suite(.serialized)
struct GatewayChannelConnectTests {
private final class ConnectParamsRecorder: @unchecked Sendable {
private let lock = NSLock()
@@ -25,6 +26,23 @@ struct GatewayChannelConnectTests {
}
}
private final class ScopeCapture: @unchecked Sendable {
private let lock = NSLock()
private var scopes: [String]?
func set(_ scopes: [String]?) {
self.lock.lock()
self.scopes = scopes
self.lock.unlock()
}
func snapshot() -> [String]? {
self.lock.lock()
defer { self.lock.unlock() }
return self.scopes
}
}
private final class TLSFailureSession: WebSocketSessioning, GatewayTLSFailureProviding, @unchecked Sendable {
private var failure: GatewayTLSValidationFailure?
@@ -92,6 +110,23 @@ struct GatewayChannelConnectTests {
})
}
private func withTemporaryStateDir<T>(_ operation: () async throws -> T) async throws -> T {
let tempDir = FileManager.default.temporaryDirectory
.appendingPathComponent(UUID().uuidString, isDirectory: true)
try FileManager.default.createDirectory(at: tempDir, withIntermediateDirectories: true)
let previousStateDir = ProcessInfo.processInfo.environment["OPENCLAW_STATE_DIR"]
setenv("OPENCLAW_STATE_DIR", tempDir.path, 1)
defer {
if let previousStateDir {
setenv("OPENCLAW_STATE_DIR", previousStateDir, 1)
} else {
unsetenv("OPENCLAW_STATE_DIR")
}
try? FileManager.default.removeItem(at: tempDir)
}
return try await operation()
}
@Test func `concurrent connect is single flight on success`() async throws {
let session = self.makeSession(response: .helloOk(delayMs: 200))
let channel = try GatewayChannelActor(
@@ -152,6 +187,126 @@ struct GatewayChannelConnectTests {
#expect(session.snapshotMakeCount() == 1)
}
@Test func `default operator connect scopes preserve pairing and admin`() async throws {
try await self.withTemporaryStateDir {
let capture = ScopeCapture()
let session = GatewayTestWebSocketSession(
taskFactory: {
GatewayTestWebSocketTask(sendHook: { _, message, sendIndex in
if sendIndex == 0 {
capture.set(GatewayWebSocketTestSupport.connectScopes(from: message))
}
})
})
let channel = try GatewayChannelActor(
url: #require(URL(string: "ws://example.invalid")),
token: nil,
session: WebSocketSessionBox(session: session))
try await channel.connect()
#expect(capture.snapshot() == [
"operator.admin",
"operator.read",
"operator.write",
"operator.approvals",
"operator.pairing",
])
}
}
@Test func `bootstrap token connect scopes are bootstrap-compatible`() async throws {
let capture = ScopeCapture()
let session = GatewayTestWebSocketSession(
taskFactory: {
GatewayTestWebSocketTask(sendHook: { _, message, sendIndex in
if sendIndex == 0 {
capture.set(GatewayWebSocketTestSupport.connectScopes(from: message))
}
})
})
let channel = try GatewayChannelActor(
url: #require(URL(string: "ws://example.invalid")),
token: nil,
bootstrapToken: "setup-bootstrap-token",
session: WebSocketSessionBox(session: session))
try await channel.connect()
#expect(capture.snapshot() == [
"operator.approvals",
"operator.read",
"operator.write",
])
}
@Test func `stored device token connect scopes reuse cached scopes`() async throws {
try await self.withTemporaryStateDir {
let identity = DeviceIdentityStore.loadOrCreate()
let storedEntry = DeviceAuthStore.storeToken(
deviceId: identity.deviceId,
role: "operator",
token: "bootstrap-device-token",
scopes: ["operator.read", "operator.write", "operator.approvals"])
let capture = ScopeCapture()
let session = GatewayTestWebSocketSession(
taskFactory: {
GatewayTestWebSocketTask(sendHook: { _, message, sendIndex in
if sendIndex == 0 {
capture.set(GatewayWebSocketTestSupport.connectScopes(from: message))
}
})
})
let channel = try GatewayChannelActor(
url: #require(URL(string: "ws://example.invalid")),
token: nil,
session: WebSocketSessionBox(session: session))
try await channel.connect()
#expect(capture.snapshot() == storedEntry.scopes)
}
}
@Test func `explicit device token connect scopes preserve requested scopes`() async throws {
try await self.withTemporaryStateDir {
let identity = DeviceIdentityStore.loadOrCreate()
_ = DeviceAuthStore.storeToken(
deviceId: identity.deviceId,
role: "operator",
token: "bootstrap-device-token",
scopes: ["operator.read", "operator.write", "operator.approvals"])
let requestedScopes = ["operator.admin", "operator.pairing"]
let capture = ScopeCapture()
let session = GatewayTestWebSocketSession(
taskFactory: {
GatewayTestWebSocketTask(sendHook: { _, message, sendIndex in
if sendIndex == 0 {
capture.set(GatewayWebSocketTestSupport.connectScopes(from: message))
}
})
})
let channel = try GatewayChannelActor(
url: #require(URL(string: "ws://example.invalid")),
token: nil,
session: WebSocketSessionBox(session: session),
connectOptions: GatewayConnectOptions(
role: "operator",
scopes: requestedScopes,
scopesAreExplicit: true,
caps: [],
commands: [],
permissions: [:],
clientId: "openclaw-macos",
clientMode: "ui",
clientDisplayName: "OpenClaw macOS Debug CLI"))
try await channel.connect()
#expect(capture.snapshot() == requestedScopes)
}
}
@Test func `connect surfaces structured auth failure`() async throws {
let session = self.makeSession(response: .authFailed(
delayMs: 0,

View File

@@ -36,6 +36,15 @@ enum GatewayWebSocketTestSupport {
return obj["params"] as? [String: Any]
}
static func connectScopes(from message: URLSessionWebSocketTask.Message) -> [String]? {
guard let obj = self.requestFrameObject(from: message) else { return nil }
guard (obj["type"] as? String) == "req", (obj["method"] as? String) == "connect" else {
return nil
}
let params = obj["params"] as? [String: Any]
return params?["scopes"] as? [String]
}
static func connectOkData(id: String) -> Data {
let json = """
{

View File

@@ -14,6 +14,18 @@ struct MacNodeRuntimeTests {
}
}
actor ExecEventProbe {
private var captured: [(event: String, json: String)] = []
func append(event: String, json: String?) {
self.captured.append((event: event, json: json ?? ""))
}
func events() -> [(event: String, json: String)] {
self.captured
}
}
@Test func `handle invoke rejects unknown command`() async {
let runtime = MacNodeRuntime()
let response = await runtime.handleInvoke(
@@ -45,6 +57,40 @@ struct MacNodeRuntimeTests {
#expect(response.ok == false)
}
@Test func `system run denied event preserves gateway run id`() async throws {
let stateDir = FileManager().temporaryDirectory
.appendingPathComponent("openclaw-state-\(UUID().uuidString)", isDirectory: true)
defer { try? FileManager().removeItem(at: stateDir) }
try await TestIsolation.withEnvValues(["OPENCLAW_STATE_DIR": stateDir.path]) {
let probe = ExecEventProbe()
let runtime = MacNodeRuntime()
await runtime.setEventSender { event, json in
await probe.append(event: event, json: json)
}
let params = OpenClawSystemRunParams(
command: ["/bin/sh", "-lc", "printf ok"],
sessionKey: "agent:main:main",
runId: "gateway-run-1")
let json = try String(data: JSONEncoder().encode(params), encoding: .utf8)
let response = await runtime.handleInvoke(
BridgeInvokeRequest(
id: "req-run-id",
command: OpenClawSystemCommand.run.rawValue,
paramsJSON: json))
#expect(response.ok == false)
let denied = try #require((await probe.events()).first { $0.event == "exec.denied" })
struct Payload: Decodable {
var sessionKey: String
var runId: String
}
let payload = try JSONDecoder().decode(Payload.self, from: Data(denied.json.utf8))
#expect(payload.sessionKey == "agent:main:main")
#expect(payload.runId == "gateway-run-1")
}
}
@Test func `handle invoke rejects blocked system run env override before execution`() async throws {
let runtime = MacNodeRuntime()
let params = OpenClawSystemRunParams(

View File

@@ -79,6 +79,7 @@ public struct WebSocketSessionBox: @unchecked Sendable {
public struct GatewayConnectOptions: Sendable {
public var role: String
public var scopes: [String]
public var scopesAreExplicit: Bool
public var caps: [String]
public var commands: [String]
public var permissions: [String: Bool]
@@ -93,6 +94,7 @@ public struct GatewayConnectOptions: Sendable {
public init(
role: String,
scopes: [String],
scopesAreExplicit: Bool = false,
caps: [String],
commands: [String],
permissions: [String: Bool],
@@ -103,6 +105,7 @@ public struct GatewayConnectOptions: Sendable {
{
self.role = role
self.scopes = scopes
self.scopesAreExplicit = scopesAreExplicit
self.caps = caps
self.commands = commands
self.permissions = permissions
@@ -132,6 +135,8 @@ private func gatewayErrorDetails(_ error: ErrorShape?) -> [String: ProtoAnyCodab
if let error {
if details["code"] == nil {
details["code"] = ProtoAnyCodable(error.code)
} else {
details["errorCode"] = ProtoAnyCodable(error.code)
}
details["message"] = ProtoAnyCodable(error.message)
if let retryable = error.retryable {
@@ -169,6 +174,7 @@ private struct SelectedConnectAuth {
let authPassword: String?
let signatureToken: String?
let storedToken: String?
let storedScopes: [String]?
let authSource: GatewayAuthSource
}
@@ -408,7 +414,19 @@ public actor GatewayChannelActor {
let clientId = options.clientId
let clientMode = options.clientMode
let role = options.role
let scopes = options.scopes
let requestedScopes = options.scopes
let scopesAreExplicit = options.scopesAreExplicit
let includeDeviceIdentity = options.includeDeviceIdentity
let identity = includeDeviceIdentity ? DeviceIdentityStore.loadOrCreate() : nil
let selectedAuth = self.selectConnectAuth(
role: role,
includeDeviceIdentity: includeDeviceIdentity,
deviceId: identity?.deviceId)
let scopes = self.resolveConnectScopes(
role: role,
requestedScopes: requestedScopes,
scopesAreExplicit: scopesAreExplicit,
selectedAuth: selectedAuth)
let reqId = UUID().uuidString
var client: [String: ProtoAnyCodable] = [
@@ -440,12 +458,6 @@ public actor GatewayChannelActor {
if !options.permissions.isEmpty {
params["permissions"] = ProtoAnyCodable(options.permissions)
}
let includeDeviceIdentity = options.includeDeviceIdentity
let identity = includeDeviceIdentity ? DeviceIdentityStore.loadOrCreate() : nil
let selectedAuth = self.selectConnectAuth(
role: role,
includeDeviceIdentity: includeDeviceIdentity,
deviceId: identity?.deviceId)
if selectedAuth.authDeviceToken != nil, self.pendingDeviceTokenRetry {
self.pendingDeviceTokenRetry = false
}
@@ -528,10 +540,11 @@ public actor GatewayChannelActor {
let explicitBootstrapToken =
self.bootstrapToken?.trimmingCharacters(in: .whitespacesAndNewlines).nilIfEmpty
let explicitPassword = self.password?.trimmingCharacters(in: .whitespacesAndNewlines).nilIfEmpty
let storedToken =
let storedEntry =
(includeDeviceIdentity && deviceId != nil)
? DeviceAuthStore.loadToken(deviceId: deviceId!, role: role)?.token
? DeviceAuthStore.loadToken(deviceId: deviceId!, role: role)
: nil
let storedToken = storedEntry?.token
let shouldUseDeviceRetryToken =
includeDeviceIdentity && self.pendingDeviceTokenRetry &&
storedToken != nil && explicitToken != nil && self.isTrustedDeviceRetryEndpoint()
@@ -563,6 +576,7 @@ public actor GatewayChannelActor {
authPassword: explicitPassword,
signatureToken: authToken ?? authBootstrapToken,
storedToken: storedToken,
storedScopes: storedEntry?.scopes,
authSource: authSource)
}
@@ -596,6 +610,27 @@ public actor GatewayChannelActor {
}
}
private func resolveConnectScopes(
role: String,
requestedScopes: [String],
scopesAreExplicit: Bool,
selectedAuth: SelectedConnectAuth) -> [String]
{
if selectedAuth.authSource == .bootstrapToken,
let filteredScopes = self.filteredBootstrapHandoffScopes(role: role, scopes: requestedScopes)
{
return filteredScopes
}
if selectedAuth.authSource == .deviceToken,
!scopesAreExplicit,
let storedScopes = selectedAuth.storedScopes,
!storedScopes.isEmpty
{
return storedScopes
}
return requestedScopes
}
private func persistBootstrapHandoffToken(
deviceId: String,
role: String,

View File

@@ -10,6 +10,7 @@ public struct GatewayConnectionProblem: Equatable, Sendable {
case gatewayAuthPasswordNotConfigured
case bootstrapTokenInvalid
case deviceTokenMismatch
case deviceTokenScopeMismatch
case pairingRequired
case pairingRoleUpgradeRequired
case pairingScopeUpgradeRequired
@@ -97,7 +98,7 @@ public struct GatewayConnectionProblem: Equatable, Sendable {
public var needsPairingApproval: Bool {
switch self.kind {
case .pairingRequired, .pairingRoleUpgradeRequired, .pairingScopeUpgradeRequired,
.pairingMetadataUpgradeRequired:
.pairingMetadataUpgradeRequired, .deviceTokenScopeMismatch:
true
default:
false
@@ -327,6 +328,20 @@ public enum GatewayConnectionProblemMapper {
retryable: false,
pauseReconnect: true,
authError: authError)
case .authScopeMismatch:
return self.problem(
kind: .deviceTokenScopeMismatch,
owner: .both,
title: authError.titleOverride ?? "Device permissions need approval",
message: authError.userMessageOverride
?? "The gateway accepted this device token but rejected the requested operator scopes.",
actionLabel: authError.actionLabel ?? "Review pairing",
actionCommand: authError.actionCommand ?? pairingCommand,
docsURL: self.docsURL(authError.docsURLString, fallback: "https://docs.openclaw.ai/gateway/pairing"),
requestId: authError.requestId,
retryable: false,
pauseReconnect: true,
authError: authError)
case .pairingRequired:
return self.pairingProblem(for: authError)
case .controlUiDeviceIdentityRequired, .deviceIdentityRequired:

View File

@@ -7,6 +7,7 @@ public enum GatewayConnectAuthDetailCode: String, Sendable {
case authTokenMismatch = "AUTH_TOKEN_MISMATCH"
case authBootstrapTokenInvalid = "AUTH_BOOTSTRAP_TOKEN_INVALID"
case authDeviceTokenMismatch = "AUTH_DEVICE_TOKEN_MISMATCH"
case authScopeMismatch = "AUTH_SCOPE_MISMATCH"
case authTokenMissing = "AUTH_TOKEN_MISSING"
case authTokenNotConfigured = "AUTH_TOKEN_NOT_CONFIGURED"
case authPasswordMissing = "AUTH_PASSWORD_MISSING"
@@ -160,6 +161,7 @@ public struct GatewayConnectAuthError: LocalizedError, Sendable {
.authPasswordMismatch,
.authPasswordNotConfigured,
.authRateLimited,
.authScopeMismatch,
.pairingRequired,
.controlUiDeviceIdentityRequired,
.deviceIdentityRequired:

View File

@@ -29,6 +29,7 @@ public struct OpenClawSystemRunParams: Codable, Sendable, Equatable {
public var needsScreenRecording: Bool?
public var agentId: String?
public var sessionKey: String?
public var runId: String?
public var approved: Bool?
public var approvalDecision: String?
@@ -41,6 +42,7 @@ public struct OpenClawSystemRunParams: Codable, Sendable, Equatable {
needsScreenRecording: Bool? = nil,
agentId: String? = nil,
sessionKey: String? = nil,
runId: String? = nil,
approved: Bool? = nil,
approvalDecision: String? = nil)
{
@@ -52,6 +54,7 @@ public struct OpenClawSystemRunParams: Codable, Sendable, Equatable {
self.needsScreenRecording = needsScreenRecording
self.agentId = agentId
self.sessionKey = sessionKey
self.runId = runId
self.approved = approved
self.approvalDecision = approvalDecision
}

View File

@@ -3,7 +3,7 @@
import Foundation
public let GATEWAY_PROTOCOL_VERSION = 4
public let GATEWAY_MIN_PROTOCOL_VERSION = 3
public let GATEWAY_MIN_PROTOCOL_VERSION = 4
private struct GatewayAnyCodingKey: CodingKey, Hashable {
let stringValue: String
@@ -500,6 +500,7 @@ public struct AgentEvent: Codable, Sendable {
public let stream: String
public let ts: Int
public let spawnedby: String?
public let isheartbeat: Bool?
public let data: [String: AnyCodable]
public init(
@@ -508,6 +509,7 @@ public struct AgentEvent: Codable, Sendable {
stream: String,
ts: Int,
spawnedby: String?,
isheartbeat: Bool?,
data: [String: AnyCodable])
{
self.runid = runid
@@ -515,6 +517,7 @@ public struct AgentEvent: Codable, Sendable {
self.stream = stream
self.ts = ts
self.spawnedby = spawnedby
self.isheartbeat = isheartbeat
self.data = data
}
@@ -524,6 +527,7 @@ public struct AgentEvent: Codable, Sendable {
case stream
case ts
case spawnedby = "spawnedBy"
case isheartbeat = "isHeartbeat"
case data
}
}
@@ -941,18 +945,22 @@ public struct AgentWaitParams: Codable, Sendable {
public struct WakeParams: Codable, Sendable {
public let mode: AnyCodable
public let text: String
public let sessionkey: String?
public init(
mode: AnyCodable,
text: String)
text: String,
sessionkey: String?)
{
self.mode = mode
self.text = text
self.sessionkey = sessionkey
}
private enum CodingKeys: String, CodingKey {
case mode
case text
case sessionkey = "sessionKey"
}
}
@@ -967,6 +975,7 @@ public struct NodePairRequestParams: Codable, Sendable {
public let modelidentifier: String?
public let caps: [String]?
public let commands: [String]?
public let permissions: [String: AnyCodable]?
public let remoteip: String?
public let silent: Bool?
@@ -981,6 +990,7 @@ public struct NodePairRequestParams: Codable, Sendable {
modelidentifier: String?,
caps: [String]?,
commands: [String]?,
permissions: [String: AnyCodable]?,
remoteip: String?,
silent: Bool?)
{
@@ -994,6 +1004,7 @@ public struct NodePairRequestParams: Codable, Sendable {
self.modelidentifier = modelidentifier
self.caps = caps
self.commands = commands
self.permissions = permissions
self.remoteip = remoteip
self.silent = silent
}
@@ -1009,6 +1020,7 @@ public struct NodePairRequestParams: Codable, Sendable {
case modelidentifier = "modelIdentifier"
case caps
case commands
case permissions
case remoteip = "remoteIp"
case silent
}
@@ -2086,6 +2098,8 @@ public struct SessionsPatchParams: Codable, Sendable {
public let spawndepth: AnyCodable?
public let subagentrole: AnyCodable?
public let subagentcontrolscope: AnyCodable?
public let inheritedtoolallow: AnyCodable?
public let inheritedtooldeny: AnyCodable?
public let sendpolicy: AnyCodable?
public let groupactivation: AnyCodable?
@@ -2109,6 +2123,8 @@ public struct SessionsPatchParams: Codable, Sendable {
spawndepth: AnyCodable?,
subagentrole: AnyCodable?,
subagentcontrolscope: AnyCodable?,
inheritedtoolallow: AnyCodable?,
inheritedtooldeny: AnyCodable?,
sendpolicy: AnyCodable?,
groupactivation: AnyCodable?)
{
@@ -2131,6 +2147,8 @@ public struct SessionsPatchParams: Codable, Sendable {
self.spawndepth = spawndepth
self.subagentrole = subagentrole
self.subagentcontrolscope = subagentcontrolscope
self.inheritedtoolallow = inheritedtoolallow
self.inheritedtooldeny = inheritedtooldeny
self.sendpolicy = sendpolicy
self.groupactivation = groupactivation
}
@@ -2155,6 +2173,8 @@ public struct SessionsPatchParams: Codable, Sendable {
case spawndepth = "spawnDepth"
case subagentrole = "subagentRole"
case subagentcontrolscope = "subagentControlScope"
case inheritedtoolallow = "inheritedToolAllow"
case inheritedtooldeny = "inheritedToolDeny"
case sendpolicy = "sendPolicy"
case groupactivation = "groupActivation"
}
@@ -3208,6 +3228,7 @@ public struct TalkSessionCancelTurnParams: Codable, Sendable {
public struct TalkSessionCreateParams: Codable, Sendable {
public let sessionkey: String?
public let spawnedby: String?
public let provider: String?
public let model: String?
public let voice: String?
@@ -3222,6 +3243,7 @@ public struct TalkSessionCreateParams: Codable, Sendable {
public init(
sessionkey: String?,
spawnedby: String?,
provider: String?,
model: String?,
voice: String?,
@@ -3235,6 +3257,7 @@ public struct TalkSessionCreateParams: Codable, Sendable {
ttlms: Int?)
{
self.sessionkey = sessionkey
self.spawnedby = spawnedby
self.provider = provider
self.model = model
self.voice = voice
@@ -3250,6 +3273,7 @@ public struct TalkSessionCreateParams: Codable, Sendable {
private enum CodingKeys: String, CodingKey {
case sessionkey = "sessionKey"
case spawnedby = "spawnedBy"
case provider
case model
case voice
@@ -3623,18 +3647,22 @@ public struct TalkSpeakResult: Codable, Sendable {
public struct ChannelsStatusParams: Codable, Sendable {
public let probe: Bool?
public let timeoutms: Int?
public let channel: String?
public init(
probe: Bool?,
timeoutms: Int?)
timeoutms: Int?,
channel: String?)
{
self.probe = probe
self.timeoutms = timeoutms
self.channel = channel
}
private enum CodingKeys: String, CodingKey {
case probe
case timeoutms = "timeoutMs"
case channel
}
}
@@ -6216,12 +6244,138 @@ public struct ChatInjectParams: Codable, Sendable {
}
}
public struct ChatEvent: Codable, Sendable {
public struct ChatDeltaEvent: Codable, Sendable {
public let runid: String
public let sessionkey: String
public let spawnedby: String?
public let seq: Int
public let state: AnyCodable
public let state: String
public let message: AnyCodable?
public let deltatext: String
public let replace: Bool?
public let usage: AnyCodable?
public init(
runid: String,
sessionkey: String,
spawnedby: String?,
seq: Int,
state: String,
message: AnyCodable?,
deltatext: String,
replace: Bool?,
usage: AnyCodable?)
{
self.runid = runid
self.sessionkey = sessionkey
self.spawnedby = spawnedby
self.seq = seq
self.state = state
self.message = message
self.deltatext = deltatext
self.replace = replace
self.usage = usage
}
private enum CodingKeys: String, CodingKey {
case runid = "runId"
case sessionkey = "sessionKey"
case spawnedby = "spawnedBy"
case seq
case state
case message
case deltatext = "deltaText"
case replace
case usage
}
}
public struct ChatFinalEvent: Codable, Sendable {
public let runid: String
public let sessionkey: String
public let spawnedby: String?
public let seq: Int
public let state: String
public let message: AnyCodable?
public let usage: AnyCodable?
public let stopreason: String?
public init(
runid: String,
sessionkey: String,
spawnedby: String?,
seq: Int,
state: String,
message: AnyCodable?,
usage: AnyCodable?,
stopreason: String?)
{
self.runid = runid
self.sessionkey = sessionkey
self.spawnedby = spawnedby
self.seq = seq
self.state = state
self.message = message
self.usage = usage
self.stopreason = stopreason
}
private enum CodingKeys: String, CodingKey {
case runid = "runId"
case sessionkey = "sessionKey"
case spawnedby = "spawnedBy"
case seq
case state
case message
case usage
case stopreason = "stopReason"
}
}
public struct ChatAbortedEvent: Codable, Sendable {
public let runid: String
public let sessionkey: String
public let spawnedby: String?
public let seq: Int
public let state: String
public let message: AnyCodable?
public let stopreason: String?
public init(
runid: String,
sessionkey: String,
spawnedby: String?,
seq: Int,
state: String,
message: AnyCodable?,
stopreason: String?)
{
self.runid = runid
self.sessionkey = sessionkey
self.spawnedby = spawnedby
self.seq = seq
self.state = state
self.message = message
self.stopreason = stopreason
}
private enum CodingKeys: String, CodingKey {
case runid = "runId"
case sessionkey = "sessionKey"
case spawnedby = "spawnedBy"
case seq
case state
case message
case stopreason = "stopReason"
}
}
public struct ChatErrorEvent: Codable, Sendable {
public let runid: String
public let sessionkey: String
public let spawnedby: String?
public let seq: Int
public let state: String
public let message: AnyCodable?
public let errormessage: String?
public let errorkind: AnyCodable?
@@ -6233,7 +6387,7 @@ public struct ChatEvent: Codable, Sendable {
sessionkey: String,
spawnedby: String?,
seq: Int,
state: AnyCodable,
state: String,
message: AnyCodable?,
errormessage: String?,
errorkind: AnyCodable?,
@@ -6365,6 +6519,43 @@ public enum PluginsSessionActionResult: Codable, Sendable {
}
}
public enum ChatEvent: Codable, Sendable {
case delta(ChatDeltaEvent)
case final(ChatFinalEvent)
case aborted(ChatAbortedEvent)
case error(ChatErrorEvent)
private enum CodingKeys: String, CodingKey {
case discriminator = "state"
}
public init(from decoder: Decoder) throws {
let container = try decoder.container(keyedBy: CodingKeys.self)
let discriminator = try container.decode(String.self, forKey: .discriminator)
switch discriminator {
case "delta": self = try .delta(ChatDeltaEvent(from: decoder))
case "final": self = try .final(ChatFinalEvent(from: decoder))
case "aborted": self = try .aborted(ChatAbortedEvent(from: decoder))
case "error": self = try .error(ChatErrorEvent(from: decoder))
default:
throw DecodingError.dataCorruptedError(
forKey: .discriminator,
in: container,
debugDescription: "Unknown ChatEvent discriminator value"
)
}
}
public func encode(to encoder: Encoder) throws {
switch self {
case .delta(let value): try value.encode(to: encoder)
case .final(let value): try value.encode(to: encoder)
case .aborted(let value): try value.encode(to: encoder)
case .error(let value): try value.encode(to: encoder)
}
}
}
public enum GatewayFrame: Codable, Sendable {
case req(RequestFrame)
case res(ResponseFrame)

View File

@@ -0,0 +1,8 @@
extension WakeParams {
public init(
mode: AnyCodable,
text: String)
{
self.init(mode: mode, text: text, sessionkey: nil)
}
}

View File

@@ -55,6 +55,21 @@ import Testing
#expect(problem?.actionCommand == "openclaw devices approve req-123")
}
@Test func scopeMismatchMapsToPairingOrRepairProblem() {
let error = GatewayConnectAuthError(
message: "device token scope mismatch",
detailCode: GatewayConnectAuthDetailCode.authScopeMismatch.rawValue,
canRetryWithDeviceToken: false)
let problem = GatewayConnectionProblemMapper.map(error: error)
#expect(error.detail == .authScopeMismatch)
#expect(error.isNonRecoverable)
#expect(problem?.kind == .deviceTokenScopeMismatch)
#expect(problem?.needsPairingApproval == true)
#expect(problem?.needsCredentialUpdate == false)
}
@Test func cancelledTransportDoesNotReplaceStructuredPairingProblem() {
let pairing = GatewayConnectAuthError(
message: "pairing required",

View File

@@ -7,13 +7,16 @@ services:
required: false
environment:
HOME: /home/node
OPENCLAW_HOME: /home/node
TERM: xterm-256color
# Pin container-side workspace and config paths so host values written to
# Pin container-side state, workspace, and config paths so host values written to
# `.env` (used by Compose for the bind-mount source below) cannot leak
# into runtime code that resolves these env vars inside the container.
# Without this override, a macOS host path like /Users/<you>/.openclaw/...
# imported from .env caused first-reply `mkdir '/Users'` EACCES failures
# in Linux Docker (#77436).
OPENCLAW_STATE_DIR: /home/node/.openclaw
OPENCLAW_CONFIG_PATH: /home/node/.openclaw/openclaw.json
OPENCLAW_CONFIG_DIR: /home/node/.openclaw
OPENCLAW_WORKSPACE_DIR: /home/node/.openclaw/workspace
OPENCLAW_GATEWAY_TOKEN: ${OPENCLAW_GATEWAY_TOKEN:-}
@@ -38,6 +41,7 @@ services:
volumes:
- ${OPENCLAW_CONFIG_DIR:-${HOME:-/tmp}/.openclaw}:/home/node/.openclaw
- ${OPENCLAW_WORKSPACE_DIR:-${HOME:-/tmp}/.openclaw/workspace}:/home/node/.openclaw/workspace
- ${OPENCLAW_AUTH_PROFILE_SECRET_DIR:-${HOME:-/tmp}/.openclaw-auth-profile-secrets}:/home/node/.config/openclaw
## Uncomment the lines below to enable sandbox isolation
## (agents.defaults.sandbox). Requires Docker CLI in the image
## (build with --build-arg OPENCLAW_INSTALL_DOCKER_CLI=1) or use
@@ -97,9 +101,12 @@ services:
- no-new-privileges:true
environment:
HOME: /home/node
OPENCLAW_HOME: /home/node
TERM: xterm-256color
# Pin container-side workspace and config paths so host values written to
# Pin container-side state, workspace, and config paths so host values written to
# `.env` cannot leak into runtime code via the env_file import (#77436).
OPENCLAW_STATE_DIR: /home/node/.openclaw
OPENCLAW_CONFIG_PATH: /home/node/.openclaw/openclaw.json
OPENCLAW_CONFIG_DIR: /home/node/.openclaw
OPENCLAW_WORKSPACE_DIR: /home/node/.openclaw/workspace
OPENCLAW_GATEWAY_TOKEN: ${OPENCLAW_GATEWAY_TOKEN:-}
@@ -112,6 +119,7 @@ services:
volumes:
- ${OPENCLAW_CONFIG_DIR:-${HOME:-/tmp}/.openclaw}:/home/node/.openclaw
- ${OPENCLAW_WORKSPACE_DIR:-${HOME:-/tmp}/.openclaw/workspace}:/home/node/.openclaw/workspace
- ${OPENCLAW_AUTH_PROFILE_SECRET_DIR:-${HOME:-/tmp}/.openclaw-auth-profile-secrets}:/home/node/.config/openclaw
stdin_open: true
tty: true
init: true

View File

@@ -1,4 +1,4 @@
ebb8fa25af8be3a6c42a8bbf505f119819ee49b3c28a317ae04a244f740be381 config-baseline.json
647f7a12deed46b4a962848a17ed5666d24fc526b777feab62cf331d84ce957d config-baseline.core.json
f90c9d96ccc4c0c703d6c489f86d89fde208cd7f697b396aeee96ff3ee087956 config-baseline.channel.json
18f71e9d4a62fe68fbd5bf18d5833a4e380fc705ad641769e1cf05794286344c config-baseline.plugin.json
c311205806d0eaa3631788dc2c489ece999b70430021ff91b365ce7ccfcba23c config-baseline.json
2e27b71c9ed109767a227f5163917a4468a1969079fc3457a3df7fe74c1fa2b7 config-baseline.core.json
2aa997d48549bd321a478485126a4bd5065ba47333a80e7eb07a0ef6ad75b0a6 config-baseline.channel.json
0dac8944a0d51ae96f97e3809907f8a04d08413434a1a1190240f7e13bb11c4d config-baseline.plugin.json

View File

@@ -1,2 +1,2 @@
19455aee06dd33e2679cfcd8075b10cce806069667097fd7e717aa641c262e51 plugin-sdk-api-baseline.json
ea6e0b36ab14977bed8dcf64118e58a8e58a76f41860c32055a73bcd04612826 plugin-sdk-api-baseline.jsonl
e8c15cff96a0a869cfe3de29679d4296603a16bfa4676940845a484c23db8e56 plugin-sdk-api-baseline.json
a6cbb8dc21b3ed16e0abd23c60a817ddedd65f336427c9fa565a43ca5dcc9a85 plugin-sdk-api-baseline.jsonl

View File

@@ -11,10 +11,18 @@
"source": "Coming from BlueBubbles",
"target": "Coming from BlueBubbles"
},
{
"source": "BlueBubbles removal and the imsg iMessage path",
"target": "BlueBubbles removal and the imsg iMessage path"
},
{
"source": "BlueBubbles",
"target": "BlueBubbles"
},
{
"source": "Configuration reference - iMessage",
"target": "Configuration reference - iMessage"
},
{
"source": "Pairing",
"target": "配对"
@@ -643,6 +651,26 @@
"source": "Manage plugins",
"target": "管理插件"
},
{
"source": "Plugin inventory",
"target": "插件清单"
},
{
"source": "Plugin reference",
"target": "插件参考"
},
{
"source": "Community plugins",
"target": "社区插件"
},
{
"source": "ClawHub publishing",
"target": "ClawHub 发布"
},
{
"source": "Plugin dependency resolution",
"target": "插件依赖解析"
},
{
"source": "Plugin path ownership",
"target": "插件路径所有权"
@@ -859,6 +887,66 @@
"source": "/cli/config",
"target": "/cli/config"
},
{
"source": "Automation",
"target": "自动化"
},
{
"source": "Tools, skills, and plugins",
"target": "工具、技能和插件"
},
{
"source": "Capabilities",
"target": "能力"
},
{
"source": "Overview",
"target": "概览"
},
{
"source": "Tools, skills, and plugins overview",
"target": "工具、技能和插件概览"
},
{
"source": "Tools overview",
"target": "工具概览"
},
{
"source": "Automation overview",
"target": "自动化概览"
},
{
"source": "Sub-agents",
"target": "子智能体"
},
{
"source": "ACP agents",
"target": "ACP 智能体"
},
{
"source": "Tools and custom providers",
"target": "工具和自定义提供商"
},
{
"source": "Exec approvals",
"target": "Exec 审批"
},
{
"source": "Elevated exec",
"target": "提升权限的 Exec"
},
{
"source": "Sandbox vs tool policy vs elevated",
"target": "沙箱、工具策略和提升权限"
},
{
"source": "Per-agent sandbox and tool restrictions",
"target": "按 Agent 配置的沙箱和工具限制"
},
{
"source": "Agents",
"target": "智能体"
},
{
"source": "fs-safe Cleanup Plan",
"target": "fs-safe Cleanup Plan"
@@ -882,5 +970,9 @@
{
"source": "ACP agents setup",
"target": "ACP Agents 设置"
},
{
"source": "ds4 (local DeepSeek V4)",
"target": "ds4本地 DeepSeek V4"
}
]

View File

@@ -0,0 +1,79 @@
---
summary: "BlueBubbles support was removed from OpenClaw. Use the bundled iMessage plugin with imsg for new and migrated iMessage setups."
read_when:
- You used the old BlueBubbles channel and need to move to iMessage
- You are choosing the supported OpenClaw iMessage setup
- You need a short explanation of the BlueBubbles removal
title: "BlueBubbles removal and the imsg iMessage path"
---
# BlueBubbles removal and the imsg iMessage path
OpenClaw no longer ships the BlueBubbles channel. iMessage support now runs through the bundled `imessage` plugin, which starts [`imsg`](https://github.com/steipete/imsg) locally or through an SSH wrapper and talks JSON-RPC over stdin/stdout.
If your config still contains `channels.bluebubbles`, migrate it to `channels.imessage`. The legacy `/channels/bluebubbles` docs URL redirects to [Coming from BlueBubbles](/channels/imessage-from-bluebubbles), which has the full config translation table and cutover checklist.
## What changed
- There is no BlueBubbles HTTP server, webhook route, REST password, or BlueBubbles plugin runtime in the supported OpenClaw iMessage path.
- OpenClaw reads and watches Messages through `imsg` on the Mac where Messages.app is signed in.
- Basic send, receive, history, and media use the normal `imsg` surfaces and macOS permissions.
- Advanced actions such as threaded replies, tapbacks, edit, unsend, effects, read receipts, typing indicators, and group management require `imsg launch` with the private API bridge available.
- Linux and Windows gateways can still use iMessage by setting `channels.imessage.cliPath` to an SSH wrapper that runs `imsg` on the signed-in Mac.
## What to do
1. Install and verify `imsg` on the Messages Mac:
```bash
brew install steipete/tap/imsg
imsg --version
imsg chats --limit 3
imsg rpc --help
```
2. Grant Full Disk Access and Automation permissions to the process context that runs `imsg` and OpenClaw.
3. Translate the old config:
```json5
{
channels: {
imessage: {
enabled: true,
cliPath: "/opt/homebrew/bin/imsg",
dmPolicy: "pairing",
allowFrom: ["+15555550123"],
groupPolicy: "allowlist",
groupAllowFrom: ["+15555550123"],
groups: {
"*": { requireMention: true },
},
includeAttachments: true,
},
},
}
```
4. Restart the gateway and verify:
```bash
openclaw channels status --probe
```
5. Test DMs, groups, attachments, and any private API actions you depend on before deleting your old BlueBubbles server.
## Migration notes
- `channels.bluebubbles.serverUrl` and `channels.bluebubbles.password` have no iMessage equivalent.
- `channels.bluebubbles.allowFrom`, `groupAllowFrom`, `groups`, `includeAttachments`, attachment roots, media size limits, chunking, and action toggles have iMessage equivalents.
- `channels.imessage.includeAttachments` is still off by default. Set it explicitly if you expect inbound photos, voice memos, videos, or files to reach the agent.
- With `groupPolicy: "allowlist"`, copy the old `groups` block, including any `"*"` wildcard entry. Group sender allowlists and the group registry are separate gates.
- ACP bindings that matched `channel: "bluebubbles"` must be changed to `channel: "imessage"`.
- Old BlueBubbles session keys do not become iMessage session keys. Pairing approvals carry over by handle, but conversation history under BlueBubbles session keys does not.
## See also
- [Coming from BlueBubbles](/channels/imessage-from-bluebubbles)
- [iMessage](/channels/imessage)
- [Configuration reference - iMessage](/gateway/config-channels#imessage)

Binary file not shown.

After

Width:  |  Height:  |  Size: 122 KiB

View File

@@ -27,6 +27,7 @@ Cron is the Gateway's built-in scheduler. It persists jobs, wakes the agent at t
<Step title="Check your jobs">
```bash
openclaw cron list
openclaw cron get <job-id>
openclaw cron show <job-id>
```
</Step>
@@ -359,6 +360,9 @@ When `hooks.enabled=true` and `hooks.gmail.account` is set, the Gateway starts `
# List all jobs
openclaw cron list
# Get one stored job as JSON
openclaw cron get <jobId>
# Show one job, including resolved delivery route
openclaw cron show <jobId>
@@ -482,7 +486,7 @@ openclaw doctor
## Related
- [Automation & Tasks](/automation) — all automation mechanisms at a glance
- [Automation](/automation) — all automation mechanisms at a glance
- [Background Tasks](/automation/tasks) — task ledger for cron executions
- [Heartbeat](/gateway/heartbeat) — periodic main-session turns
- [Timezone](/concepts/timezone) — timezone configuration

View File

@@ -3,7 +3,7 @@ summary: "Redirect to /automation"
title: "Cron vs heartbeat"
---
The decision guide for cron vs heartbeat lives under [Automation and tasks](/automation).
The decision guide for cron vs heartbeat lives under [Automation](/automation).
## Related

View File

@@ -135,6 +135,8 @@ plugin hook `before_agent_finalize` instead. See [Plugin hooks](/plugins/hooks).
**Gateway lifecycle events**: `gateway:shutdown` includes `reason` and `restartExpectedMs` and fires when gateway shutdown begins. `gateway:pre-restart` includes the same context but only fires when shutdown is part of an expected restart and a finite `restartExpectedMs` value is supplied. During shutdown, each lifecycle hook wait is best-effort and bounded so shutdown continues if a handler stalls.
Between the `gateway:shutdown` (or `gateway:pre-restart`) event and the rest of the shutdown sequence, the gateway also fires a typed `session_end` plugin hook for every session that was still active when the process stopped. The event's `reason` is `shutdown` for a plain SIGTERM/SIGINT stop and `restart` when the close was scheduled as part of an expected restart. This drain is bounded so a slow `session_end` handler cannot block process exit, and sessions that have already been finalized through replace / reset / delete / compaction are skipped to avoid double-firing.
## Hook discovery
Hooks are discovered from these directories, in order of increasing override precedence:

View File

@@ -1,10 +1,11 @@
---
doc-schema-version: 1
summary: "Overview of automation mechanisms: tasks, cron, hooks, standing orders, and Task Flow"
read_when:
- Deciding how to automate work with OpenClaw
- Choosing between heartbeat, cron, commitments, hooks, and standing orders
- Looking for the right automation entry point
title: "Automation and tasks"
title: "Automation"
---
OpenClaw runs work in the background through tasks, scheduled jobs, inferred
@@ -108,7 +109,7 @@ See [Hooks](/automation/hooks).
### Heartbeat
Heartbeat is a periodic main-session turn (default every 30 minutes). It batches multiple checks (inbox, calendar, notifications) in one agent turn with full session context. Heartbeat turns do not create task records and do not extend daily/idle session reset freshness. Use `HEARTBEAT.md` for a small checklist, or a `tasks:` block when you want due-only periodic checks inside heartbeat itself. Empty heartbeat files skip as `empty-heartbeat-file`; due-only task mode skips as `no-tasks-due`. Heartbeats defer while cron work is active or queued, and `heartbeat.skipWhenBusy` can also defer them while subagent or nested lanes are busy.
Heartbeat is a periodic main-session turn (default every 30 minutes). It batches multiple checks (inbox, calendar, notifications) in one agent turn with full session context. Heartbeat turns do not create task records and do not extend daily/idle session reset freshness. Use `HEARTBEAT.md` for a small checklist, or a `tasks:` block when you want due-only periodic checks inside heartbeat itself. Empty heartbeat files skip as `empty-heartbeat-file`; due-only task mode skips as `no-tasks-due`. Heartbeats defer while cron work is active or queued, and `heartbeat.skipWhenBusy` can also defer an agent while that same agent's session-keyed subagent or nested lanes are busy.
See [Heartbeat](/gateway/heartbeat).

View File

@@ -243,7 +243,7 @@ Each program should have:
## Related
- [Automation and tasks](/automation): all automation mechanisms at a glance.
- [Automation](/automation): all automation mechanisms at a glance.
- [Cron jobs](/automation/cron-jobs): schedule enforcement for standing orders.
- [Hooks](/automation/hooks): event-driven scripts for agent lifecycle events.
- [Webhooks](/automation/cron-jobs#webhooks): inbound HTTP event triggers.

View File

@@ -9,7 +9,7 @@ sidebarTitle: "Background tasks"
---
<Note>
Looking for scheduling? See [Automation and tasks](/automation) for choosing the right mechanism. This page is the activity ledger for background work, not the scheduler.
Looking for scheduling? See [Automation](/automation) for choosing the right mechanism. This page is the activity ledger for background work, not the scheduler.
</Note>
Background tasks track work that runs **outside your main conversation session**: ACP runs, subagent spawns, isolated cron job executions, and CLI-initiated operations.
@@ -367,7 +367,7 @@ A sweeper runs every **60 seconds** and handles four things:
## Related
- [Automation & Tasks](/automation) - all automation mechanisms at a glance
- [Automation](/automation) - all automation mechanisms at a glance
- [CLI: Tasks](/cli/tasks) - CLI command reference
- [Heartbeat](/gateway/heartbeat) - periodic main-session turns
- [Scheduled Tasks](/automation/cron-jobs) - scheduling background work

View File

@@ -0,0 +1,131 @@
---
summary: "Bot-to-bot loop protection defaults and channel overrides"
read_when:
- Configuring bot-authored channel messages
- Tuning bot-to-bot loop protection
title: "Bot loop protection"
sidebarTitle: "Bot loop protection"
---
# Bot loop protection
OpenClaw can accept messages written by other bots on channels that support `allowBots`.
When that path is enabled, pair loop protection prevents two bot identities from
replying to each other indefinitely.
The guard is enforced by the core channel-turn kernel. Each supporting channel
maps its own inbound event into generic facts: account or scope, conversation id,
sender bot id, and receiver bot id. Core then tracks the participant pair in both
directions, applies a sliding-window budget, and suppresses the pair during a
cooldown after the budget is exceeded.
## Defaults
Pair loop protection is active when a channel lets bot-authored messages reach
dispatch. Built-in defaults are:
- `maxEventsPerWindow: 20` - a bot pair can exchange 20 events within the window
- `windowSeconds: 60` - sliding window length
- `cooldownSeconds: 60` - suppression time after the pair exceeds the budget
The guard does not affect normal human-authored messages, single-bot deployments,
self-message filtering, or one-shot bot replies that stay under the budget.
## Configure shared defaults
Set `channels.defaults.botLoopProtection` once to give every supporting channel
the same baseline. Channel and account overrides can still tune individual
surfaces.
```json5
{
channels: {
defaults: {
botLoopProtection: {
maxEventsPerWindow: 20,
windowSeconds: 60,
cooldownSeconds: 60,
},
},
},
}
```
Set `enabled: false` only when your channel policy intentionally allows
bot-to-bot conversations without automatic suppression.
## Override per channel or account
Supporting channels layer their own config over the shared default. Precedence is:
- `channels.<channel>.<room-or-space>.botLoopProtection`, when the channel supports per-conversation overrides
- `channels.<channel>.accounts.<account>.botLoopProtection`, when the channel supports accounts
- `channels.<channel>.botLoopProtection`, when the channel supports top-level defaults
- `channels.defaults.botLoopProtection`
- built-in defaults
```json5
{
channels: {
defaults: {
botLoopProtection: {
maxEventsPerWindow: 20,
},
},
discord: {
botLoopProtection: {
maxEventsPerWindow: 8,
},
accounts: {
molty: {
allowBots: "mentions",
botLoopProtection: {
maxEventsPerWindow: 5,
cooldownSeconds: 90,
},
},
},
},
slack: {
allowBots: "mentions",
botLoopProtection: {
maxEventsPerWindow: 8,
},
},
matrix: {
allowBots: "mentions",
groups: {
"!roomid:example.org": {
botLoopProtection: {
maxEventsPerWindow: 5,
},
},
},
},
googlechat: {
allowBots: true,
groups: {
"spaces/AAAA": {
botLoopProtection: {
maxEventsPerWindow: 5,
},
},
},
},
},
}
```
## Channel support
- Discord: native `author.bot` facts, keyed by Discord account, channel, and bot pair.
- Slack: native `bot_id` facts for accepted bot-authored messages, keyed by Slack account, channel, and bot pair.
- Matrix: configured Matrix bot accounts, keyed by Matrix account, room, and configured bot pair.
- Google Chat: native `sender.type=BOT` facts for accepted bot-authored messages, keyed by account, space, and bot pair.
Channels that do not expose a reliable inbound bot identity keep using their
normal self-message and access-policy filters. They should not opt into this
guard until they can identify both participants in the bot pair.
See [SDK runtime](/plugins/sdk-runtime#reusable-runtime-utilities) for plugin
implementation details.

View File

@@ -1179,6 +1179,12 @@ Auto-join example:
channelId: "234567890123456789",
},
],
allowedChannels: [
{
guildId: "123456789012345678",
channelId: "234567890123456789",
},
],
daveEncryption: true,
decryptionFailureTolerance: 24,
connectTimeoutMs: 30000,
@@ -1212,6 +1218,7 @@ Notes:
- Discord voice is opt-in for text-only configs; set `channels.discord.voice.enabled=true` (or keep an existing `channels.discord.voice` block) to enable `/vc` commands, the voice runtime, and the `GuildVoiceStates` gateway intent.
- `channels.discord.intents.voiceStates` can explicitly override voice-state intent subscription. Leave it unset for the intent to follow effective voice enablement.
- If `voice.autoJoin` has multiple entries for the same guild, OpenClaw joins the last configured channel for that guild.
- `voice.allowedChannels` is an optional residency allowlist. Leave it unset to allow `/vc join` into any authorized Discord voice channel. When set, `/vc join`, startup auto-join, and bot voice-state moves are restricted to the listed `{ guildId, channelId }` entries. Set it to an empty array to deny all Discord voice joins. If Discord moves the bot outside the allowlist, OpenClaw leaves that channel and rejoins the configured auto-join target when one is available.
- `voice.daveEncryption` and `voice.decryptionFailureTolerance` pass through to `@discordjs/voice` join options.
- `@discordjs/voice` defaults are `daveEncryption=true` and `decryptionFailureTolerance=24` if unset.
- OpenClaw defaults to the pure-JS `opusscript` decoder for Discord voice receive. The optional native `@discordjs/opus` package is ignored by the repo pnpm install policy so normal installs, Docker lanes, and unrelated tests do not compile a native addon. Dedicated voice-performance hosts can opt in with `OPENCLAW_DISCORD_OPUS_DECODER=native` after installing the native addon.
@@ -1562,10 +1569,39 @@ openclaw logs --follow
If you set `channels.discord.allowBots=true`, use strict mention and allowlist rules to avoid loop behavior.
Prefer `channels.discord.allowBots="mentions"` to only accept bot messages that mention the bot.
OpenClaw also ships shared [bot loop protection](/channels/bot-loop-protection). Whenever `allowBots` lets bot-authored messages reach dispatch, Discord maps the inbound event to `(account, channel, bot pair)` facts and the generic pair guard suppresses the pair after it crosses the configured event budget. The guard prevents runaway two-bot loops that previously had to be stopped by Discord rate limits; it does not affect single-bot deployments or one-shot bot replies that stay under the budget.
Default settings (active when `allowBots` is set):
- `maxEventsPerWindow: 20` -- bot pair can exchange 20 messages within the sliding window
- `windowSeconds: 60` -- sliding window length
- `cooldownSeconds: 60` -- once the budget trips, every additional bot-to-bot message in either direction is dropped for one minute
Configure the shared default once under `channels.defaults.botLoopProtection`, then override Discord when a legitimate workflow needs more headroom. Precedence is:
- `channels.discord.accounts.<account>.botLoopProtection`
- `channels.discord.botLoopProtection`
- `channels.defaults.botLoopProtection`
- built-in defaults
Discord uses the generic `maxEventsPerWindow`, `windowSeconds`, and `cooldownSeconds` keys.
```json5
{
channels: {
defaults: {
botLoopProtection: {
maxEventsPerWindow: 20,
windowSeconds: 60,
cooldownSeconds: 60,
},
},
discord: {
// Optional Discord-wide override. Account blocks override individual
// fields and inherit omitted fields from here.
botLoopProtection: {
maxEventsPerWindow: 4,
},
accounts: {
mantis: {
// Mantis listens to other bots only when they mention her.
@@ -1578,6 +1614,12 @@ openclaw logs --follow
// Lets Molty write "@Mantis" and send a real Discord mention.
Mantis: "MANTIS_DISCORD_USER_ID",
},
botLoopProtection: {
// Allow up to five messages per minute before suppressing the pair.
maxEventsPerWindow: 5,
windowSeconds: 60,
cooldownSeconds: 90,
},
},
},
},

View File

@@ -23,7 +23,7 @@ Requires OpenClaw 2026.4.25 or above. Run `openclaw --version` to check. Upgrade
```bash
openclaw channels login --channel feishu
```
Scan the QR code with your Feishu/Lark mobile app to create a Feishu/Lark bot automatically.
Choose manual setup to paste an App ID and App Secret from Feishu Open Platform, or choose QR setup to create a bot automatically. If the domestic Feishu mobile app does not react to the QR code, rerun setup and choose manual setup.
</Step>
<Step title="After setup completes, restart the gateway to apply the changes">
@@ -211,6 +211,13 @@ Feishu/Lark does not support native slash-command menus, so send these as plain
5. Ensure the gateway is running: `openclaw gateway status`
6. Check logs: `openclaw logs --follow`
### QR setup does not react in the Feishu mobile app
1. Rerun setup: `openclaw channels login --channel feishu`
2. Choose manual setup
3. In Feishu Open Platform, create a self-built app and copy its App ID and App Secret
4. Paste those credentials into the setup wizard
### App Secret leaked
1. Reset the App Secret in Feishu Open Platform / Lark Developer

View File

@@ -185,6 +185,7 @@ Use these identifiers for delivery and allowlists:
audience: "https://gateway.example.com/googlechat",
webhookPath: "/googlechat",
botUser: "users/1234567890", // optional; helps mention detection
allowBots: false,
dm: {
policy: "pairing",
allowFrom: ["users/1234567890"],
@@ -216,6 +217,7 @@ Notes:
- Message actions expose `send` for text and `upload-file` for explicit attachment sends. `upload-file` accepts `media` / `filePath` / `path` plus optional `message`, `filename`, and thread targeting.
- `typingIndicator` supports `none`, `message` (default), and `reaction` (reaction requires user OAuth).
- Attachments are downloaded through the Chat API and stored in the media pipeline (size capped by `mediaMaxMb`).
- Bot-authored Google Chat messages are ignored by default. If you intentionally set `allowBots: true`, accepted bot-authored messages use shared [bot loop protection](/channels/bot-loop-protection). Configure `channels.defaults.botLoopProtection`, then override with `channels.googlechat.botLoopProtection` or `channels.googlechat.groups.<space>.botLoopProtection` when one space needs a different budget.
Secrets reference details: [Secrets Management](/gateway/secrets).

View File

@@ -362,7 +362,7 @@ Replying to a bot message counts as an implicit mention when the channel support
Some channel configs support restricting which tools are available **inside a specific group/room/channel**.
- `tools`: allow/deny tools for the whole group.
- `toolsBySender`: per-sender overrides within the group. Use explicit key prefixes: `id:<senderId>`, `e164:<phone>`, `username:<handle>`, `name:<displayName>`, and `"*"` wildcard. Legacy unprefixed keys are still accepted and matched as `id:` only.
- `toolsBySender`: per-sender overrides within the group. Use explicit key prefixes: `channel:<channelId>:<senderId>`, `id:<senderId>`, `e164:<phone>`, `username:<handle>`, `name:<displayName>`, and `"*"` wildcard. Channel ids use canonical OpenClaw channel ids; aliases such as `teams` normalize to `msteams`. Legacy unprefixed keys are still accepted and matched as `id:` only.
Resolution order (most specific wins):

View File

@@ -11,6 +11,22 @@ The bundled `imessage` plugin now reaches the same private API surface as BlueBu
BlueBubbles support was removed. OpenClaw supports iMessage through `imsg` only. This guide is for migrating old `channels.bluebubbles` configs to `channels.imessage`; there is no other supported migration path.
<Note>
For the short announcement and operator summary, see [BlueBubbles removal and the imsg iMessage path](/announcements/bluebubbles-imessage).
</Note>
## Migration checklist
Use this checklist when you already know your old BlueBubbles config and want the shortest safe path:
1. Verify `imsg` directly on the Mac that runs Messages.app (`imsg chats`, `imsg history`, `imsg send`, and `imsg rpc --help`).
2. Copy behavior keys from `channels.bluebubbles` to `channels.imessage`: `dmPolicy`, `allowFrom`, `groupPolicy`, `groupAllowFrom`, `groups`, `includeAttachments`, `attachmentRoots`, `mediaMaxMb`, `textChunkLimit`, `coalesceSameSenderDms`, and `actions`.
3. Drop transport keys that no longer exist: `serverUrl`, `password`, webhook URLs, and BlueBubbles server setup.
4. If the Gateway is not running on the Messages Mac, set `channels.imessage.cliPath` to an SSH wrapper and set `remoteHost` for remote attachment fetches.
5. With the Gateway stopped, enable `channels.imessage`, then run `openclaw channels status --probe --channel imessage`.
6. Test one DM, one allowed group, attachments if enabled, and every private API action you expect the agent to use.
7. Delete the BlueBubbles server and old `channels.bluebubbles` config after the iMessage path is verified.
## When this migration makes sense
- You already run `imsg` on the same Mac (or one reachable over SSH) where Messages.app is signed in.
@@ -60,13 +76,13 @@ BlueBubbles support was removed. OpenClaw supports iMessage through `imsg` only.
`imsg launch` requires SIP to be disabled. Basic send, history, and watch work without `imsg launch`; advanced actions do not.
4. Verify the bridge through OpenClaw:
4. After you add an enabled `channels.imessage` config, verify the bridge through OpenClaw:
```bash
openclaw channels status --probe
```
You want `imessage.privateApi.available: true`. If it reports `false`, fix that first — see [Capability detection](/channels/imessage#private-api-actions).
You want `imessage.privateApi.available: true`. If it reports `false`, fix that first — see [Capability detection](/channels/imessage#private-api-actions). `channels status --probe` only probes configured, enabled accounts.
5. Snapshot your config:
@@ -143,7 +159,7 @@ If the gateway logs `imessage: dropping group message from chat_id=<id>` or the
## Step-by-step
1. Add an iMessage block alongside the existing BlueBubbles block. Keep the old block only as a copy source until the new path is verified:
1. Add an iMessage block alongside the existing BlueBubbles block. Keep it disabled while the Gateway is still routing BlueBubbles traffic:
```json5
{
@@ -153,7 +169,7 @@ If the gateway logs `imessage: dropping group message from chat_id=<id>` or the
// ... existing config ...
},
imessage: {
enabled: false, // turn on after the dry run below
enabled: false,
cliPath: "/opt/homebrew/bin/imsg",
dmPolicy: "pairing",
allowFrom: ["+15555550123"], // copy from bluebubbles.allowFrom
@@ -173,17 +189,17 @@ If the gateway logs `imessage: dropping group message from chat_id=<id>` or the
}
```
2. **Dry-run probe** — start the gateway and confirm iMessage reports healthy:
2. **Probe before traffic matters** — stop the Gateway, temporarily enable the iMessage block, and confirm iMessage reports healthy from the CLI:
```bash
openclaw gateway
openclaw channels status
openclaw channels status --probe # expect imessage.privateApi.available: true
openclaw gateway stop
# edit config: channels.imessage.enabled = true
openclaw channels status --probe --channel imessage # expect imessage.privateApi.available: true
```
Because `imessage.enabled` is still `false`, no inbound iMessage traffic is routed yet — but `--probe` exercises the bridge so you catch permission/install issues before the cutover.
`channels status --probe` only probes configured, enabled accounts. Do not restart the Gateway with both BlueBubbles and iMessage enabled unless you intentionally want both channel monitors running. If you are not cutting over immediately, set `channels.imessage.enabled` back to `false` before restarting the Gateway. Use the direct `imsg` commands in [Before you start](#before-you-start) to validate the Mac before enabling OpenClaw traffic.
3. **Cut over.** Remove the BlueBubbles config and enable iMessage in one config edit:
3. **Cut over.** Once the enabled iMessage account reports healthy, remove the BlueBubbles config and keep iMessage enabled:
```json5
{
@@ -236,6 +252,7 @@ The reply cache lives at `~/.openclaw/state/imessage/reply-cache.jsonl` (mode `0
## Related
- [BlueBubbles removal and the imsg iMessage path](/announcements/bluebubbles-imessage) — short announcement and operator summary.
- [iMessage](/channels/imessage) — full iMessage channel reference, including `imsg launch` setup and capability detection.
- `/channels/bluebubbles` — legacy URL that redirects to this migration guide.
- [Pairing](/channels/pairing) — DM authentication and pairing flow.

View File

@@ -13,7 +13,7 @@ For OpenClaw iMessage deployments, use `imsg` on a signed-in macOS Messages host
</Note>
<Warning>
BlueBubbles support was removed. Migrate `channels.bluebubbles` configs to `channels.imessage`; OpenClaw supports iMessage through `imsg` only.
BlueBubbles support was removed. Migrate `channels.bluebubbles` configs to `channels.imessage`; OpenClaw supports iMessage through `imsg` only. Start with [BlueBubbles removal and the imsg iMessage path](/announcements/bluebubbles-imessage) for the short announcement, or [Coming from BlueBubbles](/channels/imessage-from-bluebubbles) for the full migration table.
</Warning>
Status: native external CLI integration. Gateway spawns `imsg rpc` and communicates over JSON-RPC on stdio (no separate daemon/port). Advanced actions require `imsg launch` and a successful private API probe.
@@ -217,7 +217,7 @@ If SIP-disabled isn't acceptable for your threat model:
Allowlist field: `channels.imessage.allowFrom`.
Allowlist entries can be handles, static sender access groups (`accessGroup:<name>`), or chat targets (`chat_id:*`, `chat_guid:*`, `chat_identifier:*`).
Allowlist entries must identify senders: handles or static sender access groups (`accessGroup:<name>`). Use `channels.imessage.groupAllowFrom` for chat targets such as `chat_id:*`, `chat_guid:*`, or `chat_identifier:*`; use `channels.imessage.groups` for numeric `chat_id` registry keys.
</Tab>
@@ -232,7 +232,7 @@ If SIP-disabled isn't acceptable for your threat model:
`groupAllowFrom` entries can also reference static sender access groups (`accessGroup:<name>`).
Runtime fallback: if `groupAllowFrom` is unset, iMessage group sender checks fall back to `allowFrom` when available.
Runtime fallback: if `groupAllowFrom` is unset, iMessage group sender checks use `allowFrom`; set `groupAllowFrom` when DM and group admission should differ.
Runtime note: if `channels.imessage` is completely missing, runtime falls back to `groupPolicy="allowlist"` and logs a warning (even if `channels.defaults.groupPolicy` is set).
<Warning>
@@ -539,6 +539,19 @@ When `imsg launch` is running and `openclaw channels status --probe` reports `pr
Older `imsg` builds that pre-date the per-method capability list will gate off typing/read silently; OpenClaw logs a one-time warning per restart so the missing receipt is attributable.
</Accordion>
<Accordion title="Inbound tapbacks">
OpenClaw subscribes to iMessage tapbacks and routes accepted reactions as system events instead of normal message text, so a user tapback does not trigger an ordinary reply loop.
Notification mode is controlled by `channels.imessage.reactionNotifications`:
- `"own"` (default): notify only when users react to bot-authored messages.
- `"all"`: notify for all inbound tapbacks from authorized senders.
- `"off"`: ignore inbound tapbacks.
Per-account overrides use `channels.imessage.accounts.<id>.reactionNotifications`.
</Accordion>
</AccordionGroup>
## Config writes
@@ -780,6 +793,7 @@ openclaw channels status --probe --channel imessage
## Related
- [Channels Overview](/channels) — all supported channels
- [BlueBubbles removal and the imsg iMessage path](/announcements/bluebubbles-imessage) — announcement and migration summary
- [Coming from BlueBubbles](/channels/imessage-from-bluebubbles) — config translation table and step-by-step cutover
- [Pairing](/channels/pairing) — DM authentication and pairing flow
- [Groups](/channels/groups) — group chat behavior and mention gating

View File

@@ -16,8 +16,11 @@ Text is supported everywhere; media and reactions vary by channel.
- Slack multi-person DMs route as group chats, so group policy, mention
behavior, and group-session rules apply to MPIM conversations.
- WhatsApp setup is install-on-demand: onboarding can show the setup flow before
the plugin package is installed, and the Gateway loads the WhatsApp runtime
only when the channel is actually active.
the plugin package is installed, and the Gateway loads the external
ClawHub/npm plugin only when the channel is actually active.
- Channels that accept bot-authored inbound messages can use shared
[bot loop protection](/channels/bot-loop-protection) to prevent bot pairs from
replying to each other indefinitely.
## Supported channels

View File

@@ -266,6 +266,7 @@ Use `allowBots` when you intentionally want inter-agent Matrix traffic:
- `allowBots: true` accepts messages from other configured Matrix bot accounts in allowed rooms and DMs.
- `allowBots: "mentions"` accepts those messages only when they visibly mention this bot in rooms. DMs are still allowed.
- `groups.<room>.allowBots` overrides the account-level setting for one room.
- Accepted configured-bot messages use shared [bot loop protection](/channels/bot-loop-protection). Configure `channels.defaults.botLoopProtection`, then override with `channels.matrix.botLoopProtection` or `channels.matrix.groups.<room>.botLoopProtection` when one room needs a different budget.
- OpenClaw still ignores messages from the same Matrix user ID to avoid self-reply loops.
- Matrix does not expose a native bot flag here; OpenClaw treats "bot-authored" as "sent by another configured Matrix account on this OpenClaw gateway".

View File

@@ -700,7 +700,7 @@ Key settings (see `/gateway/configuration` for shared channel patterns):
- `channels.msteams.teams.<teamId>.channels.<conversationId>.tools`: per-channel tool policy overrides (`allow`/`deny`/`alsoAllow`).
- `channels.msteams.teams.<teamId>.channels.<conversationId>.toolsBySender`: per-channel per-sender tool policy overrides (`"*"` wildcard supported).
- `toolsBySender` keys should use explicit prefixes:
`id:`, `e164:`, `username:`, `name:` (legacy unprefixed keys still map to `id:` only).
`channel:`, `id:`, `e164:`, `username:`, `name:` (legacy unprefixed keys still map to `id:` only).
- `channels.msteams.actions.memberInfo`: enable or disable the Graph-backed member info action (default: enabled when Graph credentials are available).
- `channels.msteams.authType`: authentication type - `"secret"` (default) or `"federated"`.
- `channels.msteams.certificatePath`: path to PEM certificate file (federated + certificate auth).

View File

@@ -123,12 +123,10 @@ The setup code is a base64-encoded JSON payload that contains:
That bootstrap token carries the built-in pairing bootstrap profile:
- primary handed-off `node` token stays `scopes: []`
- any handed-off `operator` token stays bounded to the bootstrap allowlist:
`operator.approvals`, `operator.read`, `operator.talk.secrets`, `operator.write`
- bootstrap scope checks are role-prefixed, not one flat scope pool:
operator scope entries only satisfy operator requests, and non-operator roles
must still request scopes under their own role prefix
- the built-in setup profile allows only the `node` role
- after approval, the handed-off `node` token stays `scopes: []`
- the built-in setup-code flow does not hand off an `operator` token
- operator access requires a separate approved operator pairing or token flow
- later token rotation/revocation remains bounded by both the device's approved
role contract and the caller session's operator scopes

View File

@@ -915,11 +915,13 @@ Current Slack message actions include `send`, `upload-file`, `download-file`, `r
- `skills`
- `systemPrompt`
- `tools`, `toolsBySender`
- `toolsBySender` key format: `id:`, `e164:`, `username:`, `name:`, or `"*"` wildcard
- `toolsBySender` key format: `channel:`, `id:`, `e164:`, `username:`, `name:`, or `"*"` wildcard
(legacy unprefixed keys still map to `id:` only)
`allowBots` is conservative for channels and private channels: bot-authored room messages are accepted only when the sending bot is explicitly listed in that room's `users` allowlist, or when at least one explicit Slack owner ID from `channels.slack.allowFrom` is currently a room member. Wildcards and display-name owner entries do not satisfy owner presence. Owner presence uses Slack `conversations.members`; make sure the app has the matching read scope for the room type (`channels:read` for public channels, `groups:read` for private channels). If the member lookup fails, OpenClaw drops the bot-authored room message.
Accepted bot-authored Slack messages use shared [bot loop protection](/channels/bot-loop-protection). Configure `channels.defaults.botLoopProtection` for the default budget, then override with `channels.slack.botLoopProtection` or `channels.slack.channels.<id>.botLoopProtection` when a workspace or channel needs a different limit.
</Tab>
</Tabs>

View File

@@ -293,6 +293,7 @@ curl "https://api.telegram.org/bot<bot_token>/getUpdates"
- Group sessions are isolated by group ID. Forum topics append `:topic:<threadId>` to keep topics isolated.
- DM messages can carry `message_thread_id`; OpenClaw preserves the thread ID for replies but keeps DMs on the flat session by default. Configure `channels.telegram.dm.threadReplies: "inbound"`, `channels.telegram.direct.<chatId>.threadReplies: "inbound"`, `requireTopic: true`, or a matching topic config when you intentionally want DM topic session isolation.
- Long polling uses grammY runner with per-chat/per-thread sequencing. Overall runner sink concurrency uses `agents.defaults.maxConcurrent`.
- Multi-account startup bounds concurrent Telegram `getMe` probes so large bot fleets do not fan out every account probe at once.
- Long polling is guarded inside each gateway process so only one active poller can use a bot token at a time. If you still see `getUpdates` 409 conflicts, another OpenClaw gateway, script, or external poller is likely using the same token.
- Long-polling watchdog restarts trigger after 120 seconds without completed `getUpdates` liveness by default. Increase `channels.telegram.pollingStallThresholdMs` only if your deployment still sees false polling-stall restarts during long-running work. The value is in milliseconds and is allowed from `30000` to `600000`; per-account overrides are supported.
- Telegram Bot API has no read-receipt support (`sendReadReceipts` does not apply).
@@ -395,7 +396,7 @@ curl "https://api.telegram.org/bot<bot_token>/getUpdates"
Outbound text uses Telegram `parse_mode: "HTML"`.
- Markdown-ish text is rendered to Telegram-safe HTML.
- Raw model HTML is escaped to reduce Telegram parse failures.
- Supported Telegram HTML tags are preserved; unsupported HTML is escaped.
- If Telegram rejects parsed HTML, OpenClaw retries as plain text.
Link previews are enabled by default and can be disabled with `channels.telegram.linkPreview: false`.
@@ -457,7 +458,7 @@ curl "https://api.telegram.org/bot<bot_token>/getUpdates"
- `/pair approve` when there is only one pending request
- `/pair approve latest` for most recent
The setup code carries a short-lived bootstrap token. Built-in bootstrap handoff keeps the primary node token at `scopes: []`; any handed-off operator token stays bounded to `operator.approvals`, `operator.read`, `operator.talk.secrets`, and `operator.write`. Bootstrap scope checks are role-prefixed, so that operator allowlist only satisfies operator requests; non-operator roles still need scopes under their own role prefix.
The setup code carries a short-lived bootstrap token. Built-in setup-code bootstrap is node-only: the first connect creates a pending node request, and after approval the Gateway returns a durable node token with `scopes: []`. It does not return a handed-off operator token; operator access requires a separate approved operator pairing or token flow.
If a device retries with changed auth details (for example role/scopes/public key), the previous pending request is superseded and the new request uses a different `requestId`. Re-run `/pair pending` before approving.
@@ -526,6 +527,28 @@ curl "https://api.telegram.org/bot<bot_token>/getUpdates"
}
```
Mini App button example:
```json5
{
action: "send",
channel: "telegram",
to: "123456789",
message: "Open app:",
presentation: {
blocks: [
{
type: "buttons",
buttons: [{ label: "Launch", web_app: { url: "https://example.com/app" } }],
},
],
},
}
```
Telegram `web_app` buttons work only in private chats between a user and the
bot.
Callback clicks are passed to the agent as text:
`callback_data: <value>`
@@ -840,7 +863,7 @@ openclaw message poll --channel telegram --target -1001234567890:topic:42 \
- `--presentation` with `buttons` blocks for inline keyboards when `channels.telegram.capabilities.inlineButtons` allows it
- `--pin` or `--delivery '{"pin":true}'` to request pinned delivery when the bot can pin in that chat
- `--force-document` to send outbound images and GIFs as documents instead of compressed photo or animated-media uploads
- `--force-document` to send outbound images, GIFs, and videos as documents instead of compressed photo, animated-media, or video uploads
Action gating:

View File

@@ -14,27 +14,19 @@ Status: production-ready via WhatsApp Web (Baileys). Gateway owns linked session
- `openclaw channels login --channel whatsapp` also offers the install flow when
the plugin is not present yet.
- Dev channel + git checkout: defaults to the local plugin path.
- Stable/Beta: uses the npm package `@openclaw/whatsapp` on the current official
release tag.
- Stable/Beta: installs the official `@openclaw/whatsapp` plugin from ClawHub
first, with npm as the fallback.
- The WhatsApp runtime is distributed outside the core OpenClaw npm package so
WhatsApp-specific runtime dependencies stay with the external plugin.
Manual install stays available:
```bash
openclaw plugins install @openclaw/whatsapp
openclaw plugins install clawhub:@openclaw/whatsapp
```
Use the bare package to follow the current official release tag. Pin an exact
version only when you need a reproducible install.
On Windows, the WhatsApp plugin needs Git on `PATH` during npm install because
one of its Baileys/libsignal dependencies is fetched from a git URL. Install
Git for Windows, then restart the shell and rerun the install:
```powershell
winget install --id Git.Git -e
```
Portable Git also works if its `bin` directory is on `PATH`.
Use the bare npm package (`@openclaw/whatsapp`) only when you need the registry
fallback. Pin an exact version only when you need a reproducible install.
<CardGroup cols={3}>
<Card title="Pairing" icon="link" href="/channels/pairing">

View File

@@ -388,7 +388,7 @@ The scheduled live/E2E workflow runs the full release-path Docker suite daily.
## Plugin Prerelease
`Plugin Prerelease` is more expensive product/package coverage, so it is a separate workflow dispatched by `Full Release Validation` or by an explicit operator. Normal pull requests, `main` pushes, and standalone manual CI dispatches keep that suite off. It balances bundled plugin tests across eight extension workers; those extension shard jobs run up to two plugin config groups at a time with one Vitest worker per group and a larger Node heap so import-heavy plugin batches do not create extra CI jobs. The release-only Docker prerelease path batches targeted Docker lanes in small groups to avoid reserving dozens of runners for one-to-three-minute jobs.
`Plugin Prerelease` is more expensive product/package coverage, so it is a separate workflow dispatched by `Full Release Validation` or by an explicit operator. Normal pull requests, `main` pushes, and standalone manual CI dispatches keep that suite off. It balances bundled plugin tests across eight extension workers; those extension shard jobs run up to two plugin config groups at a time with one Vitest worker per group and a larger Node heap so import-heavy plugin batches do not create extra CI jobs. The release-only Docker prerelease path batches targeted Docker lanes in small groups to avoid reserving dozens of runners for one-to-three-minute jobs. The workflow also uploads an informational `plugin-inspector-advisory` artifact from `@openclaw/plugin-inspector`; inspector findings are triage input and do not change the blocking Plugin Prerelease gate.
## QA Lab

View File

@@ -43,6 +43,7 @@ Quick rule:
| --------------------------------------------------------------------- | ----------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| `initialize`, `newSession`, `prompt`, `cancel` | Implemented | Core bridge flow over stdio to Gateway chat/send + abort. |
| `listSessions`, slash commands | Implemented | Session list works against Gateway session state with bounded cursor pagination and `cwd` filtering where Gateway session rows carry workspace metadata; commands are advertised via `available_commands_update`. |
| Session lineage metadata | Implemented | Session listings and session info snapshots include OpenClaw parent and child lineage in `_meta` so ACP clients can render subagent graphs without private Gateway side channels. |
| `resumeSession`, `closeSession` | Implemented | Resume rebinds an ACP session to an existing Gateway session without replaying history. Close cancels active bridge work, resolves pending prompts as cancelled, and releases bridge session state. |
| `loadSession` | Partial | Rebinds the ACP session to a Gateway session key and replays ACP event-ledger history for bridge-created sessions. Older/no-ledger sessions fall back to stored user/assistant text. |
| Prompt content (`text`, embedded `resource`, images) | Partial | Text/resources are flattened into chat input; images become Gateway attachments. |

View File

@@ -32,7 +32,7 @@ openclaw channels logs --channel all
## Status / capabilities / resolve / logs
- `channels status`: `--probe`, `--timeout <ms>`, `--json`
- `channels status`: `--channel <name>`, `--probe`, `--timeout <ms>`, `--json`
- `channels capabilities`: `--channel <name>`, `--account <id>` (only with `--channel`), `--target <dest>`, `--timeout <ms>`, `--json`
- `channels resolve`: `<entries...>`, `--channel <name>`, `--account <id>`, `--kind <auto|user|group>`, `--json`
- `channels logs`: `--channel <name|all>`, `--lines <n>`, `--json`

View File

@@ -220,6 +220,7 @@ Manual run and inspection:
```bash
openclaw cron list
openclaw cron list --agent ops
openclaw cron get <job-id>
openclaw cron show <job-id>
openclaw cron run <job-id>
openclaw cron run <job-id> --due
@@ -228,6 +229,8 @@ openclaw cron runs --id <job-id> --limit 50
`openclaw cron list` shows all matching jobs by default. Pass `--agent <id>` to show only jobs whose effective normalized agent id matches; jobs without a stored agent id count as the configured default agent.
`openclaw cron get <job-id>` returns the stored job JSON directly. Use `cron show <job-id>` when you want the human-readable view with delivery-route preview.
`cron list --json` and `cron show <job-id> --json` include a top-level `status` field on each job, computed from `enabled`, `state.runningAtMs`, and `state.lastRunStatus`. Values: `disabled`, `running`, `ok`, `error`, `skipped`, or `idle`. This mirrors the human-readable status column so external tooling can read job state without re-deriving it.
`cron runs` entries include delivery diagnostics with the intended cron target, the resolved target, message-tool sends, fallback use, and delivered state.

View File

@@ -157,7 +157,7 @@ When you set `--url`, the CLI does not fall back to config or environment creden
## Token drift recovery checklist
Use this when Control UI or other clients keep failing with `AUTH_TOKEN_MISMATCH` or `AUTH_DEVICE_TOKEN_MISMATCH`.
Use this when Control UI or other clients keep failing with `AUTH_TOKEN_MISMATCH`, `AUTH_DEVICE_TOKEN_MISMATCH`, or `AUTH_SCOPE_MISMATCH`.
1. Confirm current gateway token source:
@@ -191,6 +191,7 @@ Notes:
- Normal reconnect auth precedence is explicit shared token/password first, then explicit `deviceToken`, then stored device token, then bootstrap token.
- Trusted `AUTH_TOKEN_MISMATCH` recovery can temporarily send both the shared token and the stored device token together for the one bounded retry.
- `AUTH_SCOPE_MISMATCH` means the device token was recognized but does not carry the requested scope set; fix the pairing/scope approval contract before changing shared gateway auth.
Related:

View File

@@ -57,7 +57,7 @@ Notes:
- On Linux, doctor warns when the user's crontab still runs legacy `~/.openclaw/bin/ensure-whatsapp.sh`; that script is no longer maintained and can log false WhatsApp gateway outages when cron lacks the systemd user-bus environment.
- When WhatsApp is enabled, doctor checks for a degraded Gateway event loop with local `openclaw-tui` clients still running. `doctor --fix` stops only verified local TUI clients so WhatsApp replies are not queued behind stale TUI refresh loops.
- Doctor rewrites legacy `openai-codex/*` model refs to canonical `openai/*` refs across primary models, fallbacks, heartbeat/subagent/compaction overrides, hooks, channel model overrides, and stale session route pins. `--fix` moves Codex intent onto provider/model-scoped `agentRuntime.id: "codex"` entries, preserves session auth-profile pins such as `openai-codex:...`, removes stale whole-agent/session runtime pins, and keeps repaired OpenAI agent refs on Codex auth routing instead of direct OpenAI API-key auth.
- Doctor cleans legacy plugin dependency staging state created by older OpenClaw versions. It also repairs missing downloadable plugins that are referenced by config, such as `plugins.entries`, configured channels, configured provider/search settings, or configured agent runtimes. During package updates, doctor skips package-manager plugin repair until the package swap is complete; rerun `openclaw doctor --fix` afterward if a configured plugin still needs recovery. If the download fails, doctor reports the install error and preserves the configured plugin entry for the next repair attempt.
- Doctor cleans legacy plugin dependency staging state created by older OpenClaw versions and relinks the host `openclaw` package for managed npm plugins that declare it as a peer dependency. It also repairs missing downloadable plugins that are referenced by config, such as `plugins.entries`, configured channels, configured provider/search settings, or configured agent runtimes. During package updates, doctor skips package-manager plugin repair until the package swap is complete; rerun `openclaw doctor --fix` afterward if a configured plugin still needs recovery. If the download fails, doctor reports the install error and preserves the configured plugin entry for the next repair attempt.
- Doctor repairs stale plugin config by removing missing plugin ids from `plugins.allow`/`plugins.deny`/`plugins.entries`, plus matching dangling channel config, heartbeat targets, and channel model overrides when plugin discovery is healthy.
- Doctor quarantines invalid plugin config by disabling the affected `plugins.entries.<id>` entry and removing its invalid `config` payload. Gateway startup already skips only that bad plugin so other plugins and channels can keep running.
- Set `OPENCLAW_SERVICE_REPAIR_POLICY=external` when another supervisor owns the gateway lifecycle. Doctor still reports gateway/service health and applies non-service repairs, but skips service install/start/restart/bootstrap and legacy service cleanup.

View File

@@ -520,15 +520,15 @@ openclaw gateway restart
Only gateways with Bonjour discovery enabled (default) advertise the beacon.
Wide-Area discovery records include (TXT):
Wide-area discovery records can include these TXT hints:
- `role` (gateway role hint)
- `transport` (transport hint, e.g. `gateway`)
- `gatewayPort` (WebSocket port, usually `18789`)
- `sshPort` (optional; clients default SSH targets to `22` when it is absent)
- `sshPort` (full discovery mode only; clients default SSH targets to `22` when it is absent)
- `tailnetDns` (MagicDNS hostname, when available)
- `gatewayTls` / `gatewayTlsSha256` (TLS enabled + cert fingerprint)
- `cliPath` (remote-install hint written to the wide-area zone)
- `cliPath` (full discovery mode only)
### `gateway discover`
@@ -553,7 +553,7 @@ openclaw gateway discover --json | jq '.beacons[].wsUrl'
<Note>
- The CLI scans `local.` plus the configured wide-area domain when one is enabled.
- `wsUrl` in JSON output is derived from the resolved service endpoint, not from TXT-only hints such as `lanHost` or `tailnetDns`.
- On `local.` mDNS, `sshPort` and `cliPath` are only broadcast when `discovery.mdns.mode` is `full`. Wide-area DNS-SD still writes `cliPath`; `sshPort` stays optional there too.
- On `local.` mDNS and wide-area DNS-SD, `sshPort` and `cliPath` are only published when `discovery.mdns.mode` is `full`.
</Note>

View File

@@ -256,6 +256,7 @@ openclaw [--dev] [--profile <name>] <command>
cron
status
list
get
add
edit
rm

View File

@@ -72,7 +72,7 @@ Name lookup:
- Optional: `--media`, `--presentation`, `--delivery`, `--pin`, `--reply-to`, `--thread-id`, `--gif-playback`, `--force-document`, `--silent`
- Shared presentation payloads: `--presentation` sends semantic blocks (`text`, `context`, `divider`, `buttons`, `select`) that core renders through the selected channel's declared capabilities. See [Message Presentation](/plugins/message-presentation).
- Generic delivery preferences: `--delivery` accepts delivery hints such as `{ "pin": true }`; `--pin` is shorthand for pinned delivery when the channel supports it.
- Telegram only: `--force-document` (send images and GIFs as documents to avoid Telegram compression)
- Telegram only: `--force-document` (send images, GIFs, and videos as documents to avoid Telegram compression)
- Telegram only: `--thread-id` (forum topic id)
- Slack only: `--thread-id` (thread timestamp; `--reply-to` uses the same field)
- Telegram + Discord: `--silent`
@@ -284,6 +284,16 @@ openclaw message send --channel telegram --target @mychat --message "Choose:" \
--presentation '{"blocks":[{"type":"buttons","buttons":[{"label":"Yes","value":"cmd:yes"},{"label":"No","value":"cmd:no"}]}]}'
```
Send a Telegram Mini App button through generic presentation:
```
openclaw message send --channel telegram --target 123456789 --message "Open app:" \
--presentation '{"blocks":[{"type":"buttons","buttons":[{"label":"Launch","web_app":{"url":"https://example.com/app"}}]}]}'
```
Telegram `web_app` buttons are supported only in private chats between a user
and the bot.
Send a Teams card through generic presentation:
```bash

View File

@@ -22,6 +22,7 @@ openclaw migrate claude --dry-run
openclaw migrate codex --dry-run
openclaw migrate codex --skill gog-vault77-google-workspace
openclaw migrate codex --plugin google-calendar --dry-run
openclaw migrate codex --plugin google-calendar --verify-plugin-apps --dry-run
openclaw migrate hermes --dry-run
openclaw migrate hermes
openclaw migrate apply codex --yes --skill gog-vault77-google-workspace
@@ -59,6 +60,9 @@ openclaw onboard --import-from hermes --import-source ~/.hermes
<ParamField path="--plugin <name>" type="string">
Select one Codex plugin install item by plugin name or item id. Repeat the flag to migrate multiple Codex plugins. When omitted, interactive Codex migrations show a native Codex plugin checkbox selector and non-interactive migrations keep all planned plugins. This only applies to source-installed `openai-curated` Codex plugins discovered by the Codex app-server inventory.
</ParamField>
<ParamField path="--verify-plugin-apps" type="boolean">
Codex only. Force a fresh source Codex app-server `app/list` traversal before planning native plugin activation. Off by default to keep migration planning fast.
</ParamField>
<ParamField path="--no-backup" type="boolean">
Skip the pre-apply backup. Requires `--force` when local OpenClaw state exists.
</ParamField>
@@ -119,13 +123,15 @@ inventory a specific Codex home.
Use this provider when moving to the OpenClaw Codex harness and you want to
promote useful personal Codex CLI assets deliberately. Local Codex app-server
launches use per-agent `CODEX_HOME` and `HOME` directories, so they do not read
your personal Codex CLI state by default.
launches use a per-agent `CODEX_HOME`, so they do not read your personal Codex
CLI state by default, while subprocesses still inherit the normal process
`HOME` unless the app-server launch explicitly overrides it.
Running `openclaw migrate codex` in an interactive terminal previews the full
plan, then opens checkbox selectors before the final apply confirmation. Skill
copy items are prompted first. Use `Toggle all on` or `Toggle all off` for bulk
selection; planned skills start checked, conflict skills start unchecked, and
selection. Press Space to toggle rows, or press Enter to activate the highlighted
row and continue. Planned skills start checked, conflict skills start unchecked, and
`Skip for now` skips skill copies for this run while still continuing to plugin
selection. When source-installed curated Codex plugins are migratable and
`--plugin` was not supplied, migration then prompts for native Codex plugin
@@ -156,29 +162,54 @@ openclaw migrate apply codex --yes --plugin google-calendar
- Personal AgentSkills under `$HOME/.agents/skills`, copied into the current
OpenClaw agent workspace when you want per-agent ownership.
- Source-installed `openai-curated` Codex plugins discovered through Codex
app-server `plugin/list`. Apply calls app-server `plugin/install` for each
selected plugin, even if the target app-server already reports that plugin as
installed and enabled. Migrated Codex plugins are usable only in sessions that
select the native Codex harness; they are not exposed to Pi, normal OpenAI
provider runs, ACP conversation bindings, or other harnesses.
app-server `plugin/list`. Planning reads `plugin/read` for each enabled
installed plugin. App-backed plugins require the source Codex app-server
account response to be a ChatGPT subscription account; non-ChatGPT or missing
account responses are skipped with `codex_subscription_required`. By default,
migration does not call source `app/list`, so app-backed plugins that pass the
account gate are planned without source app accessibility verification, and
account lookup transport failures skip with `codex_account_unavailable`. Pass
`--verify-plugin-apps` when you want migration to force a fresh source
`app/list` snapshot and require every owned app to be present, enabled, and
accessible before planning native activation. In that mode, account lookup
transport failures fall through to source app inventory verification. The
source app inventory snapshot is kept in memory for the current process; it
is not written to migration output or target config. Disabled plugins,
unreadable plugin details, subscription-gated source accounts, and, when
verification is requested, missing apps, disabled apps, inaccessible apps, or
source app inventory failures become manual skipped items with typed reasons
instead of target config entries.
Apply calls app-server `plugin/install` for each selected eligible plugin,
even if the target app-server already reports that plugin as installed and
enabled. Migrated Codex plugins are usable only in sessions that select the
native Codex harness; they are not exposed to Pi, normal OpenAI provider runs,
ACP conversation bindings, or other harnesses.
### Manual-review Codex state
Codex `config.toml`, native `hooks/hooks.json`, non-curated marketplaces, and
cached plugin bundles that are not source-installed curated plugins are not
activated automatically. They are copied or reported in the migration report for
Codex `config.toml`, native `hooks/hooks.json`, non-curated marketplaces, cached
plugin bundles that are not source-installed curated plugins, and source-installed
plugins that fail the source subscription gate are not activated automatically.
When `--verify-plugin-apps` is set, plugins that fail the source app-inventory
gate are also skipped. They are copied or reported in the migration report for
manual review.
For migrated source-installed curated plugins, apply writes:
- `plugins.entries.codex.enabled: true`
- `plugins.entries.codex.config.codexPlugins.enabled: true`
- `plugins.entries.codex.config.codexPlugins.allow_destructive_actions: false`
- `plugins.entries.codex.config.codexPlugins.allow_destructive_actions: true`
- one explicit plugin entry with `marketplaceName: "openai-curated"` and
`pluginName` for each selected plugin
Migration never writes `plugins["*"]` and never stores local marketplace cache
paths. Auth-required installs are reported on the affected plugin item with
paths. Source-side subscription failures are reported on manual items with typed
reasons such as `codex_subscription_required`, `codex_account_unavailable`,
`plugin_disabled`, or `plugin_read_unavailable`. With `--verify-plugin-apps`,
source app-inventory failures can also appear as `app_inaccessible`,
`app_disabled`, `app_missing`, or `app_inventory_unavailable`. Skipped plugins
are not written to target config.
Target-side auth-required installs are reported on the affected plugin item with
`status: "skipped"`, `reason: "auth_required"`, and sanitized app identifiers.
Their explicit config entries are written disabled until you reauthorize and
enable them. Other install failures are item-scoped `error` results.

View File

@@ -188,11 +188,17 @@ specific configured agent store. The parent `--agent` flag is honored by
`add`, `list`, `login`, `setup-token`, `paste-token`, and
`login-github-copilot`.
For OpenAI models, `--provider openai` defaults to ChatGPT/Codex account login.
Use `--method api-key` only when you want to add an OpenAI API-key profile,
usually as a backup for Codex subscription limits. The legacy
`--provider openai-codex` spelling still works for existing scripts.
Examples:
```bash
openclaw models auth login --provider openai-codex --set-default
openclaw models auth list --provider openai-codex
openclaw models auth login --provider openai --set-default
openclaw models auth login --provider openai --method api-key
openclaw models auth list --provider openai
```
Notes:

View File

@@ -131,9 +131,11 @@ is available, then fall back to `latest`.
<Accordion title="--dangerously-force-unsafe-install">
`--dangerously-force-unsafe-install` is a break-glass option for false positives in the built-in dangerous-code scanner. It allows the install to continue even when the built-in scanner reports `critical` findings, but it does **not** bypass plugin `before_install` hook policy blocks and does **not** bypass scan failures.
Install scans ignore common test files and directories such as `tests/`, `__tests__/`, `*.test.*`, and `*.spec.*` to avoid blocking packaged test mocks; declared plugin runtime entrypoints are still scanned even if they use one of those names.
This CLI flag applies to plugin install/update flows. Gateway-backed skill dependency installs use the matching `dangerouslyForceUnsafeInstall` request override, while `openclaw skills install` remains a separate ClawHub skill download/install flow.
If a plugin you published on ClawHub is blocked by a registry scan, use the publisher steps in [ClawHub](/clawhub/security).
If a plugin you published on ClawHub is hidden or blocked by a registry scan, use the publisher steps in [ClawHub publishing](/clawhub/publishing). `--dangerously-force-unsafe-install` only affects installs on your own machine; it does not ask ClawHub to rescan the plugin or make a blocked release public.
</Accordion>
<Accordion title="Hook packs and npm specs">
@@ -282,7 +284,7 @@ directory remains inert so normal packaged installs still use compiled dist.
For runtime hook debugging:
- `openclaw plugins inspect <id> --runtime --json` shows registered hooks and diagnostics from a module-loaded inspection pass. Runtime inspection never installs dependencies; use `openclaw doctor --fix` to clean legacy dependency state or recover missing downloadable plugins that are referenced by config.
- `openclaw gateway status --deep --require-rpc` confirms the reachable Gateway, service/process hints, config path, and RPC health.
- `openclaw gateway status --deep --require-rpc` confirms the reachable Gateway URL/profile, service/process hints, config path, and RPC health.
- Non-bundled conversation hooks (`llm_input`, `llm_output`, `before_model_resolve`, `before_agent_reply`, `before_agent_run`, `before_agent_finalize`, `agent_end`) require `plugins.entries.<id>.hooks.allowConversationAccess=true`.
Use `--link` to avoid copying a local directory (adds to `plugins.load.paths`):
@@ -339,7 +341,7 @@ Updates apply to tracked plugin installs in the managed plugin index and tracked
</Accordion>
<Accordion title="Beta channel updates">
`openclaw plugins update` reuses the tracked plugin spec unless you pass a new spec. `openclaw update` additionally knows the active OpenClaw update channel: on the beta channel, default-line npm and ClawHub plugin records try `@beta` first, then fall back to the recorded default/latest spec if no plugin beta release exists. Exact versions and explicit tags stay pinned to that selector.
`openclaw plugins update` reuses the tracked plugin spec unless you pass a new spec. `openclaw update` additionally knows the active OpenClaw update channel: on the beta channel, default-line npm and ClawHub plugin records try `@beta` first, then fall back to the recorded default/latest spec if no plugin beta release exists. That fallback is reported as a warning and does not fail the core update. Exact versions and explicit tags stay pinned to that selector.
</Accordion>
<Accordion title="Version checks and integrity drift">
@@ -384,7 +386,7 @@ The `--json` flag outputs a machine-readable report suitable for scripting and a
openclaw plugins doctor
```
`doctor` reports plugin load errors, manifest/discovery diagnostics, and compatibility notices. When everything is clean it prints `No plugin issues detected.`
`doctor` reports plugin load errors, manifest/discovery diagnostics, compatibility notices, and stale plugin config references such as missing plugin slots. When the install tree and plugin config are clean it prints `No plugin issues detected.` If stale config remains but the install tree is otherwise healthy, the summary says so instead of implying full plugin health.
If a configured plugin is present on disk but blocked by the loader's path-safety checks, config validation keeps the plugin entry and reports it as `present but blocked`. Fix the preceding blocked-plugin diagnostic, such as path ownership or world-writable permissions, instead of removing the `plugins.entries.<id>` or `plugins.allow` config.
@@ -402,7 +404,7 @@ The local plugin registry is OpenClaw's persisted cold read model for installed
Use `plugins registry` to inspect whether the persisted registry is present, current, or stale. Use `--refresh` to rebuild it from the persisted plugin index, config policy, and manifest/package metadata. This is a repair path, not a runtime activation path.
`openclaw doctor --fix` also repairs registry-adjacent managed npm drift: if an orphaned or recovered `@openclaw/*` package under the managed plugin npm root shadows a bundled plugin, doctor removes that stale package and rebuilds the registry so startup validates against the bundled manifest.
`openclaw doctor --fix` also repairs registry-adjacent managed npm drift: if an orphaned or recovered `@openclaw/*` package under the managed plugin npm root shadows a bundled plugin, doctor removes that stale package and rebuilds the registry so startup validates against the bundled manifest. Doctor also relinks the host `openclaw` package into managed npm plugins that declare `peerDependencies.openclaw`, so package-local runtime imports such as `openclaw/plugin-sdk/*` resolve after updates or npm repairs.
<Warning>
`OPENCLAW_DISABLE_PERSISTED_PLUGIN_REGISTRY=1` is a deprecated break-glass compatibility switch for registry read failures. Prefer `plugins registry --refresh` or `openclaw doctor --fix`; the env fallback is only for emergency startup recovery while the migration rolls out.

View File

@@ -35,9 +35,8 @@ openclaw qr --url wss://gateway.example/ws
- `--token` and `--password` are mutually exclusive.
- The setup code itself now carries an opaque short-lived `bootstrapToken`, not the shared gateway token/password.
- In the built-in node/operator bootstrap flow, the primary node token still lands with `scopes: []`.
- If bootstrap handoff also issues an operator token, it stays bounded to the bootstrap allowlist: `operator.approvals`, `operator.read`, `operator.talk.secrets`, `operator.write`.
- Bootstrap scope checks are role-prefixed. That operator allowlist only satisfies operator requests; non-operator roles still need scopes under their own role prefix.
- Built-in setup-code bootstrap is node-only. After approval, the primary node token lands with `scopes: []`.
- The built-in setup-code flow does not return a handed-off operator token; operator access requires a separate approved operator pairing or token flow.
- Mobile pairing fails closed for Tailscale/public `ws://` gateway URLs. Private LAN addresses and `.local` Bonjour hosts remain supported over `ws://`, but Tailscale/public mobile routes should use Tailscale Serve/Funnel or a `wss://` gateway URL.
- With `--remote`, OpenClaw requires either `gateway.remote.url` or
`gateway.tailscale.mode=serve|funnel`.

View File

@@ -31,6 +31,8 @@ Notes:
- Overview includes Gateway + node host service install/runtime status when available.
- Overview includes update channel + git SHA (for source checkouts).
- Update info surfaces in the Overview; if an update is available, status prints a hint to run `openclaw update` (see [Updating](/install/updating)).
- Model pricing refresh failures are shown as optional pricing warnings. They do
not mean the Gateway or channels are unhealthy.
- Read-only status surfaces (`status`, `status --json`, `status --all`) resolve supported SecretRefs for their targeted config paths when possible.
- If a supported channel SecretRef is configured but unavailable in the current command path, status stays read-only and reports degraded output instead of crashing. Human output shows warnings such as "configured token unavailable in this command path", and JSON output includes `secretDiagnostics`.
- When command-local SecretRef resolution succeeds, status prefers the resolved snapshot and clears transient "secret unavailable" channel markers from the final output.

View File

@@ -31,14 +31,28 @@ openclaw system presence
## `system event`
Enqueue a system event on the **main** session. The next heartbeat will inject
it as a `System:` line in the prompt. Use `--mode now` to trigger the heartbeat
immediately; `next-heartbeat` waits for the next scheduled tick.
Enqueue a system event on the **main** session by default. The next heartbeat
will inject it as a `System:` line in the prompt. Use `--mode now` to trigger
the heartbeat immediately; `next-heartbeat` waits for the next scheduled tick.
Pass `--session-key` to target a specific session (for example to relay an
async-task completion back to the channel that started it).
> **Timing exception with `--session-key`:** when `--session-key` is supplied,
> `--mode next-heartbeat` collapses to an immediate targeted wake instead of
> waiting for the next scheduled tick. Targeted wakes use heartbeat intent
> `immediate` so they bypass the runner's not-due gate that would otherwise
> defer (and effectively drop) an `event`-intent wake. If you want delayed
> delivery, omit `--session-key` so the event lands on the main session and
> rides the next regular heartbeat.
Flags:
- `--text <text>`: required system event text.
- `--mode <mode>`: `now` or `next-heartbeat` (default).
- `--session-key <sessionKey>`: optional; target a specific agent session
instead of the agent's main session. Keys that do not belong to the
resolved agent fall back to the agent's main session.
- `--json`: machine-readable output.
- `--url`, `--token`, `--timeout`, `--expect-final`: shared Gateway RPC flags.

View File

@@ -39,7 +39,8 @@ openclaw --update
- `--dry-run`: preview planned update actions (channel/tag/target/restart flow) without writing config, installing, syncing plugins, or restarting.
- `--json`: print machine-readable `UpdateRunResult` JSON, including
`postUpdate.plugins.warnings` when corrupt or unloadable managed plugins need
repair after the core update succeeds, and `postUpdate.plugins.integrityDrifts`
repair after the core update succeeds, beta-channel plugin fallback details
when a plugin has no beta release, and `postUpdate.plugins.integrityDrifts`
when npm plugin artifact drift is detected during post-update plugin sync.
- `--timeout <seconds>`: per-step timeout (default is 1800s).
- `--yes`: skip confirmation prompts (for example downgrade confirmation).
@@ -173,16 +174,20 @@ manually.
On the beta update channel, tracked npm and ClawHub plugin installs that follow
the default/latest line try a plugin `@beta` release first. If the plugin has no
beta release, OpenClaw falls back to the recorded default/latest spec. For npm
plugins, OpenClaw also falls back when the beta package exists but fails install
validation. Exact versions and explicit tags are not rewritten.
beta release, OpenClaw falls back to the recorded default/latest spec and reports
that as a warning. For npm plugins, OpenClaw also falls back when the beta
package exists but fails install validation. These plugin fallback warnings do
not make the core update fail. Exact versions and explicit tags are not
rewritten.
<Warning>
If an exact pinned npm plugin update resolves to an artifact whose integrity differs from the stored install record, `openclaw update` aborts that plugin artifact update instead of installing it. Reinstall or update the plugin explicitly only after verifying that you trust the new artifact.
</Warning>
<Note>
Post-update plugin sync failures that are scoped to a managed plugin are reported as warnings after the core update succeeds. The JSON result keeps the top-level update `status: "ok"` and reports `postUpdate.plugins.status: "warning"` with `openclaw doctor --fix` and `openclaw plugins inspect <id> --runtime --json` guidance. Unexpected updater or sync exceptions still fail the update result. Fix the plugin install or update error, then rerun `openclaw doctor --fix` or `openclaw update`.
Post-update plugin sync failures that are scoped to a managed plugin and that the sync path can route around (e.g. an unreachable npm registry for a non-essential plugin) are reported as warnings after the core update succeeds. The JSON result keeps the top-level update `status: "ok"` and reports `postUpdate.plugins.status: "warning"` with `openclaw doctor --fix` and `openclaw plugins inspect <id> --runtime --json` guidance. Unexpected updater or sync exceptions still fail the update result. Fix the plugin install or update error, then rerun `openclaw doctor --fix` or `openclaw update`.
After the per-plugin sync step, `openclaw update` runs a mandatory **post-core convergence** pass before the gateway is restarted: it repairs missing configured plugin payloads, validates each _active_ tracked install record on disk, and statically verifies its `package.json` is parseable (and any explicitly-declared `main` exists). Failures from this pass — and an invalid OpenClaw config snapshot — return `postUpdate.plugins.status: "error"` and flip the top-level update `status` to `"error"`, so `openclaw update` exits non-zero and the gateway is _not_ restarted with an unverified plugin set. The error includes structured `postUpdate.plugins.warnings[].guidance` lines pointing at `openclaw doctor --fix` and `openclaw plugins inspect <id> --runtime --json` for follow-up. Disabled plugin entries and records that are not trusted-source-linked official sync targets are skipped here, mirroring the `skipDisabledPlugins` policy used by the missing-payload check, so a stale disabled plugin record cannot block an otherwise valid update.
When the updated Gateway starts, plugin loading is verify-only: startup does not run package managers or mutate dependency trees. Package-manager `update.run` restarts bypass the normal idle deferral and restart cooldown after the package tree has been swapped, so the old process cannot keep lazy-loading removed chunks.

View File

@@ -46,7 +46,7 @@ wired end-to-end.
- Runs are serialized per session key (session lane) and optionally through a global lane.
- This prevents tool/session races and keeps session history consistent.
- Messaging channels can choose queue modes (collect/steer/followup) that feed this lane system.
- Messaging channels can choose queue modes (steer/followup/collect/interrupt) that feed this lane system.
See [Command Queue](/concepts/queue).
- Transcript writes are also protected by a session write lock on the session file. The lock is
process-aware and file-based, so it catches writers that bypass the in-process queue or come from

View File

@@ -84,17 +84,15 @@ Legacy session folders from other tools are not read.
## Steering while streaming
When queue mode is `steer`, inbound messages are injected into the current run.
Queued steering is delivered **after the current assistant turn finishes
executing its tool calls**, before the next LLM call. Pi drains all pending
steering messages together for `steer`; legacy `queue` drains one message per
model boundary. Steering no longer skips remaining tool calls from the current
assistant message.
Inbound prompts that arrive mid-run are steered into the current run by default.
Steering is delivered **after the current assistant turn finishes executing its
tool calls**, before the next LLM call, and no longer skips remaining tool calls
from the current assistant message.
When queue mode is `followup` or `collect`, inbound messages are held until the
current turn ends, then a new agent turn starts with the queued payloads. See
[Queue](/concepts/queue) and [Steering queue](/concepts/queue-steering) for mode
and boundary behavior.
`/queue steer` is the default active-run behavior. `/queue followup` and
`/queue collect` make messages wait for a later turn instead of steering.
`/queue interrupt` aborts the active run instead. See [Queue](/concepts/queue)
and [Steering queue](/concepts/queue-steering) for queue and boundary behavior.
Block streaming sends completed assistant blocks as soon as they finish; it is
**off by default** (`agents.defaults.blockStreamingDefault: "off"`).

View File

@@ -65,7 +65,7 @@ Markdown tables are not consistently supported across chat clients. Use
`markdown.tables` to control conversion per channel (and per account).
- `code`: render tables as code blocks (default for most channels).
- `bullets`: convert each row into bullet points (default for Signal + WhatsApp).
- `bullets`: convert each row into bullet points (default for Matrix, Signal, and WhatsApp).
- `off`: disable table parsing and conversion; raw table text passes through.
Config keys:

Some files were not shown because too many files have changed in this diff Show More