Peter Steinberger
bb46b79d3c
refactor: internalize OpenClaw agent runtime ( #85341 )
...
* refactor: extract agent core package
Introduce packages/agent-core as the OpenClaw-owned home for reusable agent loop, harness, session, prompt, and runtime dependency contracts.
* refactor: extract shared llm runtime
Move provider model registries, stream wrappers, OAuth helpers, and LLM utilities into src/llm with plugin-sdk barrels instead of depending on the old embedded runtime layout.
* refactor: remove pi runtime internals
Rename remaining Pi-shaped agent surfaces to OpenClaw agent runtime names, delete obsolete Pi docs and package graph checks, and add the third-party notice for incorporated code.
* refactor: tighten agent session runtime
Make agent-core/runtime dependencies explicit, consolidate compaction and session transcript helpers, and move model/session helpers behind OpenClaw-owned contracts.
* refactor: remove static model and pi auth paths
Drop static model catalogs and Pi auth bridges, move model/provider facts to manifest-owned runtime contracts, and harden internal embedded-agent utilities.
* refactor: remove legacy provider compat paths
* docs: remove agent parity notes
* fix: skip provider wildcard metadata parsing
* refactor: share session extension sdk loading
* refactor: inline acpx proxy error formatter
* refactor: fold edit recovery into edit tool
* fix: accept extension batch separator
* test: align startup provider plugin expectations
* fix: restore provider-scoped release discovery
* test: align static asset packaging expectations
* fix: run static provider catalogs during scoped discovery
* fix: add provider entry catalogs for scoped live discovery
* fix: load lightweight provider catalog entries
* fix: refresh provider-scoped plugin metadata
* fix: keep provider catalog entries on release live path
* fix: keep static manifest models in release live checks
* fix: harden release model discovery
* fix: reduce OpenAI live cache probe reasoning
* fix: disable OpenAI cache probe reasoning
* ci: extend OpenAI gateway live timeout
* fix: extend live gateway model budget
* fix: stabilize release validation regressions
* fix: honor provider aliases in model rows
* fix: stabilize release validation lanes
* fix: stabilize release memory qa
* ci: stabilize release validation lanes
* ci: prefer ipv4 for live docker node calls
* fix: restore shared tool-call stream wrapper
* ci: remove legacy pi test shard alias
* fix: clean up embedded agent test drift
* fix: stabilize runtime alias status
* fix: clean up embedded agent ci drift
* fix: restore release ci invariants
* fix: clean up post-rebase runtime drift
* fix: restore release ci checks
* fix: restore release ci after rebase
* fix: remove stale pi runtime path
* test: align compaction runtime expectations
* test: update plugin prerelease expectations
* fix: handle claude live tool approvals
* fix: stabilize release validation gates
* fix: finish agent runtime import
* test: finish post-rebase agent runtime mocks
* fix: keep codex compaction native
* fix: stabilize codex app-server hook tests
* test: isolate codex diagnostic active run
* test: remove codex diagnostic completion race
# Conflicts:
# extensions/codex/src/app-server/run-attempt.test.ts
* ci: fix full release manifest performance run id
* refactor: narrow llm plugin sdk boundary
* chore: drop generated google boundary stamps
* fix: repair rebase fallout
* fix: clean up rebased runtime references
* fix: decode codex jwt payloads as base64url
* fix: preserve shipped pi runtime alias
* fix: add scoped sdk virtual modules
* fix: decode llm codex oauth jwt as base64url
* fix: avoid stale vertex adc negative cache
* fix: harden tool arg decoding and codeql path
* fix: keep vertex adc negative checks live
* refactor: consolidate codex jwt and edit helpers
* fix: await codex oauth node runtime imports
* fix: preserve sdk tool and notice contracts
* fix: preserve shipped compat config boundaries
* fix: align codex oauth callback host
* fix: terminate agent-core loop streams on failure
* fix: keep codex oauth callback alive during fallback
* ci: include session tools in critical codeql scans
* fix: keep Cloudflare Anthropic provider auth header
* docs: redirect legacy pi runtime pages
* fix: honor bundled web provider compat discovery
* fix: protect session output spill files
* fix: keep legacy agent dir env blocked
* fix: contain auto-discovered skill symlinks
* fix: harden agent core sdk proxy surfaces
* fix: restore approval reaction sdk compat
* fix: keep live docker runs bounded
* fix: keep codex oauth redirect host aligned
* fix: resolve post-rebase agent runtime drift
* fix: redact anthropic oauth parse failures
* fix: preserve responses strict tool shaping
* fix: repair agent runtime rebase cleanup
* docs: redirect retired parity pages
* fix: bound auto-discovered resources to roots
* fix: repair post-rebase agent test drift
* fix: preserve bundled provider allowlist migration
* fix: preserve manifest-owned provider aliases
* fix: declare photon image dependency
* fix: keep provider headers out of proxy body
* fix: preserve shipped env aliases
* fix: refresh control ui i18n generated state
* fix: quote read fallback paths
* fix: preview edits through configured backend
* test: satisfy core test typecheck
* fix: preserve ZAI usage auth fallback
* test: repair codex diagnostic test
* fix: repair agent runtime rebase drift
* test: finish embedded runner import rename
* fix: repair agent runtime rebase integrations
* test: align compaction oauth fallback expectations
* fix: allow sdk-auth session models
* fix: update doctor tool schema import
* fix: preserve bedrock plugin region
* fix: stream harmony-like prose immediately
* ci: include session runtime in codeql shards
* fix: repair latest rebase integrations
* fix: honor explicit codex websocket transport
* fix: keep openai-compatible credentials provider-scoped
* fix: refresh sdk api baseline after rebase
* fix: route cli runtime aliases through openclaw harness
* test: rename stale harness mock expectation
* test: rename embedded agent overflow calls
* test: clean embedded auth test wording
* test: use openclaw stream types in deepinfra cache test
* fix: refresh sdk api baseline on latest main
* fix: honor bundled discovery compat allowlists
* fix: refresh sdk api baseline after latest rebase
* fix: remove stale rebase imports
* test: rename stale model catalog mock
* test: mock renamed doctor runtime modules
* fix: map canonical kimi env auth
* fix: use internal model registry in bench script
* fix: migrate deepinfra provider catalog entry
* fix: enforce builtin tool suppression
* fix: route compaction auth and proxy payloads safely
* refactor: prune unused llm registry leftovers
* test: update codex hooks session import
* test: fix model picker ci coverage
* test: align model picker auth mock types
2026-05-27 19:24:04 +01:00
Peter Steinberger
99b27cde64
perf(sessions): reduce store clone allocations
2026-05-27 19:20:17 +01:00
Peter Steinberger
f40275ce26
test(agents): make live subagent steering explicit
2026-05-27 14:17:22 -04:00
Peter Steinberger
dfe49ae2f4
test(matrix): quarantine live block-streaming scenario
2026-05-27 14:15:49 -04:00
Dallin Romney
cff8e4383c
expand default diffs languages ( #87372 )
2026-05-27 11:14:16 -07:00
Dallin Romney
2c95752c1e
fix(diffs): align language pack host floor ( #87370 )
2026-05-27 11:13:50 -07:00
Vincent Koc
140cede2e2
fix(qa): make matrix block streaming deterministic
2026-05-27 20:11:37 +02:00
Peter Steinberger
c0f16460d7
ci(release): smoke Docker runtime templates in full validation
2026-05-27 19:08:56 +01:00
Vincent Koc
11ca150a1b
fix(testing): bound plugin gauntlet relay logs
2026-05-27 20:04:56 +02:00
Peter Steinberger
a4d33fd81b
docs: clarify container model auth
2026-05-27 19:04:04 +01:00
Peter Steinberger
b01c6d4eaa
test(matrix): force block-streaming marker separation
2026-05-27 13:58:42 -04:00
Peter Steinberger
97eba607b5
perf(gateway): skip concrete jiti alias rewrites
2026-05-27 18:58:12 +01:00
Peter Steinberger
659b5dce79
fix(docker): package runtime workspace templates
2026-05-27 18:54:22 +01:00
Vincent Koc
8e8445905f
fix(release): stream cross-os served artifacts
2026-05-27 19:51:51 +02:00
Agustin Rivera
62550710bf
fix(msteams): block untrusted Teams service URLs ( #87334 )
2026-05-27 10:48:39 -07:00
Andi Liao
085228c961
fix(auth): document paste-token stdin setup ( #63050 )
...
Document that automation should pipe `models auth paste-token` credentials over stdin instead of passing token material in argv, keeping the existing secret-handling path explicit in the CLI docs.
Also include accepted auth-profile credential types in invalid-profile warning logs so malformed local auth stores are easier to repair.
Fixes #63042 .
Thanks @liaoandi.
2026-05-27 18:44:44 +01:00
Shadow
1806b152a9
fix: add ClawHub plugin display names ( #87354 )
2026-05-27 12:37:35 -05:00
Vincent Koc
c571652487
fix(e2e): stream live plugin transcripts
2026-05-27 19:36:43 +02:00
Peter Steinberger
c3b7e91f26
docs: clarify device token admin gate
2026-05-27 18:35:27 +01:00
Ben Badejo
7691a8a9a3
docs(codex): clarify computer use setup ( #87313 )
...
Clarify the Codex Computer Use docs around inferred opt-in, read-only status checks, and marketplace root versus marketplace JSON path setup.
The docs now match current source-backed behavior: autoInstall opts Computer Use in, status does not mutate plugin setup, and marketplacePath is for a local marketplace JSON file while source registers a marketplace root.
Verification:
- pnpm docs:list
- GitHub CI check-docs passed
- Real behavior proof passed via maintainer proof override for this docs-only PR
Thanks @bdjben.
Co-authored-by: Benjamin Badejo <ben@benbadejo.com >
Co-authored-by: Sally O'Malley <somalley@redhat.com >
2026-05-27 18:35:21 +01:00
Peter Steinberger
fe91ada730
fix: reflect lazy plugin runtime surfaces
2026-05-27 18:35:04 +01:00
Peter Steinberger
1577e8f10e
fix(diffs): avoid extension build-script boundary import
2026-05-27 13:33:58 -04:00
Peter Steinberger
05b23e9b7e
refactor(codex): extract app-server notification state
2026-05-27 18:31:06 +01:00
Vincent Koc
b182b71d74
fix(e2e): align prerelease and google live guards
2026-05-27 19:30:27 +02:00
Peter Steinberger
04880ab250
fix(gateway): avoid viewer asset watch loops
2026-05-27 18:29:42 +01:00
Vincent Koc
e93cf52782
fix(e2e): stream release scenario log checks
2026-05-27 19:23:11 +02:00
Peter Steinberger
f80f47d408
fix(status): show configured fast-status channels
2026-05-27 13:22:03 -04:00
Vincent Koc
32d9caf662
test(matrix): clarify block streaming QA prompt
2026-05-27 19:14:54 +02:00
Peter Steinberger
d84cbfa50e
perf(gateway): cache manifest model catalog rows
2026-05-27 18:12:47 +01:00
Peter Steinberger
a4c2e7f5cf
refactor(codex): split app-server attempt seams
2026-05-27 18:11:16 +01:00
Vincent Koc
1a34c4833e
fix(e2e): stream OpenAI web search request logs
2026-05-27 19:09:32 +02:00
Dallin Romney
d638611684
feat: split diffs language pack
...
Split the diffs viewer Shiki language pack into an external publishable plugin.
The diffs plugin keeps the default curated syntax set, while the new @openclaw/diffs-language-pack package carries the extended Shiki languages for npm and ClawHub distribution. The install metadata includes the external ClawHub spec, and the curated C# alias set keeps both c# and cs supported without the language pack.
Co-authored-by: Dallin Romney <dallinromney@gmail.com >
2026-05-27 18:08:40 +01:00
Peter Steinberger
5f7e21e26a
fix(cli): reject malformed timeout values
2026-05-27 13:06:17 -04:00
Peter Steinberger
de5971eedc
fix(onboard): preserve rerun config migrations
...
Fix non-interactive and wizard onboarding reruns so existing agent lists and bindings are preserved unless the user explicitly resets config.
Isolate legacy `plugins.installs` migration into its own write so the config size-drop allowance cannot mask unrelated config loss, while preserving new or repaired install records for the final plugin-index commit. Also keep shrinkwrap generation pinned to pnpm-locked transitive patch versions only when the dependency edge still allows that version, and isolate the tooling Vitest shard that mutates process state.
Fixes #84692 .
Replaces #84748 .
Co-authored-by: yetval <yetvald@gmail.com >
2026-05-27 18:05:07 +01:00
Vincent Koc
11dfef201f
fix(e2e): keep doctor loader mock current
2026-05-27 18:57:13 +02:00
Shadow
930d9f63ad
docs: expand install deployment cards
2026-05-27 11:54:12 -05:00
Vincent Koc
5c20ff93e0
fix(e2e): isolate kitchen sink log scans
2026-05-27 18:45:11 +02:00
Peter Steinberger
ca7b6be7cf
perf(gateway): cache auto-enabled plugin config
2026-05-27 17:42:34 +01:00
Vincent Koc
c285766d62
fix(ci): merge nested shrinkwrap override pins
2026-05-27 18:37:00 +02:00
Vincent Koc
8ee767baa7
fix(ci): pin aged lru cache lock entry
2026-05-27 18:17:09 +02:00
Vincent Koc
d2a1f62d23
fix(matrix): keep fallback tool warnings mention-inert
2026-05-27 18:07:24 +02:00
Vincent Koc
98a9a523e6
fix(ci): preserve forked shrinkwrap pins
2026-05-27 18:07:24 +02:00
Vincent Koc
162a79b170
fix(e2e): bound agent turn assertion logs
2026-05-27 18:04:43 +02:00
Peter Steinberger
97a8c09b0a
perf(gateway): slim current metadata identity cache
2026-05-27 16:54:57 +01:00
Peter Steinberger
7aaca4a8a6
chore(release): prepare 2026.5.27
2026-05-27 16:53:50 +01:00
Vincent Koc
46f5905498
fix(e2e): zero log tail buffers
2026-05-27 17:48:56 +02:00
Onur Solmaz
b7a5bcba78
fix(memory): salvage qmd search JSON after nonzero exit ( #87225 )
...
Merged via squash.
Prepared head SHA: 964617b224
Co-authored-by: osolmaz <2453968+osolmaz@users.noreply.github.com >
Co-authored-by: osolmaz <2453968+osolmaz@users.noreply.github.com >
Reviewed-by: @osolmaz
2026-05-27 23:44:43 +08:00
Pavan Kumar Gondhi
0314d67d87
Harden hostname normalization for repeated trailing dots [AI] ( #87305 )
...
* fix: canonicalize trailing hostname dots
* test: reuse shared hostname normalization
* docs: add changelog entry for PR merge
2026-05-27 21:08:29 +05:30
Vincent Koc
12dc398267
fix(e2e): harden kitchen sink log tailing
2026-05-27 17:35:51 +02:00
Pavan Kumar Gondhi
8e41c118fa
fix: block side-effecting command wrappers [AI] ( #87292 )
...
* fix: block side-effecting command wrappers
* docs: add changelog entry for PR merge
2026-05-27 20:56:53 +05:30