ziomancer
a74091eb98
docs(mcp): add CHANGELOG entries and MCP transport/namespacing docs
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-30 07:22:36 +09:00
ziomancer
14f78debd5
fix(mcp): allow colon in tool names and dispose transport on failed connect
...
The transcript validator regex rejected namespaced MCP tool names
(e.g., vigil-harbor:memory_status) because colon wasn't in the
allowed character set. Tool call blocks were silently dropped during
session repair, breaking tool-call/result pairing.
Also closes a resource leak: if client.connect() throws after the
transport is instantiated, the transport is now explicitly closed.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-30 07:22:36 +09:00
ziomancer
414d7306d1
feat(mcp): add HTTP transport support and tool namespacing
...
MCP tools are now prefixed with their server name (e.g., vigil-harbor:memory_status)
to prevent collisions between tools from different MCP servers and built-in tools.
Adds SSE and StreamableHTTP transport support alongside existing stdio, enabling
connection to remote MCP servers via URL-based config with optional custom headers
and env var substitution. Includes config validation, session lifecycle management,
and 5 new tests for HTTP config edge cases.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-30 07:22:36 +09:00
Peter Steinberger
f8dc4305a5
refactor: share native approval delivery helpers
2026-03-30 07:16:33 +09:00
Mariano
5ef42fc856
Gateway: surface blocked ACP task outcomes ( #57203 )
2026-03-30 00:15:51 +02:00
Peter Steinberger
d82d6ba0c4
fix: align openai fast mode with priority processing
2026-03-29 23:14:52 +01:00
Peter Steinberger
27519cf061
refactor: centralize node identity resolution
2026-03-29 23:14:22 +01:00
Vincent Koc
ace876b087
fix(gateway): keep startup model warmup static
2026-03-30 07:12:52 +09:00
Vincent Koc
bd89e07baa
fix(agents): stop transient live-switch mismatches
2026-03-30 07:12:52 +09:00
Peter Steinberger
e01ca8cfc6
refactor(plugin-sdk): remove direct extension source leaks
2026-03-29 23:11:20 +01:00
Peter Steinberger
6d9a7224aa
refactor: unify approval command authorization
2026-03-30 07:06:29 +09:00
Peter Steinberger
6ca81f8ec7
test(gateway): decouple send coverage from telegram specifics
2026-03-29 22:59:32 +01:00
Peter Steinberger
168ab94eee
refactor(config): pin runtime snapshot and drop ttl cache
2026-03-29 22:57:31 +01:00
Peter Steinberger
3ec000b995
refactor: align same-chat approval routing
2026-03-30 06:52:28 +09:00
Peter Steinberger
f16c176a4c
fix: disambiguate legacy mac node identities
2026-03-29 22:47:15 +01:00
Peter Steinberger
2e0682d930
refactor: finish decoupling plugin sdk seams
2026-03-29 22:42:06 +01:00
Peter Steinberger
574d3c5213
fix: make same-chat approvals work across channels
2026-03-30 06:35:04 +09:00
Peter Steinberger
1ca01b738b
fix: stabilize exec approval approver routing
2026-03-30 06:25:03 +09:00
Peter Steinberger
216afe275e
test: harden packed manifest guardrails
2026-03-29 22:21:29 +01:00
Peter Steinberger
356adc98d5
test: align schema and redaction assertions
2026-03-29 22:21:29 +01:00
Peter Steinberger
e45cc3890b
refactor: unify sensitive URL config hints
2026-03-29 22:21:29 +01:00
Peter Steinberger
1318479a2c
refactor: extract MCP transport helpers
2026-03-29 22:21:29 +01:00
Peter Steinberger
9baa853797
test: isolate image read helper coverage
2026-03-29 22:10:37 +01:00
Peter Steinberger
421acd27e1
style: finalize exec formatter cleanup
2026-03-30 06:03:08 +09:00
Peter Steinberger
276ccd2583
fix(exec): default implicit target to auto
2026-03-30 06:03:08 +09:00
Peter Steinberger
d014f173f1
test: trim stale legacy coverage and repair mocks
2026-03-29 22:00:56 +01:00
Peter Steinberger
63e5c3349e
refactor(config): drop obsolete legacy config aliases
2026-03-29 22:00:56 +01:00
Peter Steinberger
aed87a608e
fix: stabilize bundled plugin ci lanes
2026-03-30 05:35:53 +09:00
Peter Steinberger
694bc082a8
fix: resolve acpx MCP secret inputs
2026-03-30 05:30:32 +09:00
Peter Steinberger
35233bae96
refactor: decouple bundled plugin sdk surfaces
2026-03-29 21:20:46 +01:00
Peter Steinberger
5d4c4bb850
fix(exec): restore runtime-aware implicit host default
2026-03-29 21:18:41 +01:00
Peter Steinberger
f5f8ba6d35
fix: harden bundle MCP session runtime cache ( #55090 ) (thanks @allan0509)
2026-03-30 05:10:32 +09:00
无忌
6477d783e8
Agents: cache bundle MCP runtime per session
2026-03-30 05:10:32 +09:00
Peter Steinberger
73477eee4c
fix: harden ACP plugin tools bridge ( #56867 ) (thanks @joe2643)
2026-03-30 05:09:59 +09:00
khhjoe
e24091413c
fix: add curly braces for oxlint curly rule; copy postinstall script before pnpm install in Dockerfile
2026-03-30 05:09:59 +09:00
khhjoe
a8c189f463
fix(mcp): serialize result.content instead of wrapper object; warn on missing static assets
2026-03-30 05:09:59 +09:00
khhjoe
415899984e
feat(mcp): add plugin tools MCP server for ACP sessions
...
Standalone MCP server that exposes OpenClaw plugin-registered tools
(e.g. memory-lancedb's memory_recall, memory_store, memory_forget)
to ACP sessions running Claude Code via acpx's MCP proxy mechanism.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com >
2026-03-30 05:09:59 +09:00
Peter Steinberger
3f5ed11266
fix: clear stalled model resolution lanes
2026-03-30 05:09:26 +09:00
Gustavo Madeira Santana
9b4f26e70a
Plugins/CLI: add descriptor-backed lazy root command registration ( #57165 )
...
Merged via squash.
Prepared head SHA: ad1dee32eb
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com >
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com >
Reviewed-by: @gumadeiras
2026-03-29 16:02:59 -04:00
Peter Steinberger
d330782ed1
fix(matrix): stop discovering runtime helper as plugin entry
2026-03-29 21:00:57 +01:00
Gustavo Madeira Santana
dc192d7b2f
Build: mirror Matrix crypto WASM runtime deps ( #57163 )
...
Merged via squash.
Prepared head SHA: b3aeb9d08a
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com >
Co-authored-by: gumadeiras <5599352+gumadeiras@users.noreply.github.com >
Reviewed-by: @gumadeiras
2026-03-29 15:57:28 -04:00
Peter Steinberger
82f04ced27
refactor(plugin-sdk): drop legacy provider compat subpaths
2026-03-29 20:55:53 +01:00
Peter Steinberger
cce6d3bbb7
fix: resolve CI type and lint regressions
2026-03-30 04:51:33 +09:00
Peter Steinberger
855878b4f0
fix: stabilize serial test suite
2026-03-30 04:46:04 +09:00
George Zhang
2607191d04
refactor(plugins): centralize before_install context shaping
2026-03-29 12:35:01 -07:00
George Zhang
b5d48d311c
test(plugins): cover before_install policy metadata
2026-03-29 12:35:01 -07:00
George Zhang
150faba8d1
plugins: enrich before_install policy context
2026-03-29 12:35:01 -07:00
George Zhang
ac3951d731
test(plugins): cover before_install install flows
2026-03-29 12:35:01 -07:00
George Zhang
7cd9957f62
plugins: add before_install hook for install scanners
2026-03-29 12:35:01 -07:00
Robin Waslander
77555d6c85
fix(infra): classify SQLite transient errors as non-fatal in unhandled rejection handler ( #57018 )
...
Add isTransientSqliteError() covering SQLITE_CANTOPEN, SQLITE_BUSY,
SQLITE_LOCKED, and SQLITE_IOERR via named codes, numeric errcodes
(node:sqlite), and message-string fallback. Combine with existing
network transient check so both families are treated as non-fatal
in the global unhandled rejection handler.
Prevents crash loop under launchd on macOS when SQLite files are
temporarily unavailable.
Fixes #34678
2026-03-29 21:29:38 +02:00