Agent Client Protocol (ACP)-sessies laten OpenClaw externe coding-harnesses uitvoeren (bijvoorbeeld Pi, Claude Code, Cursor, Copilot, Droid, OpenClaw ACP, OpenCode, Gemini CLI en andere ondersteunde ACPX-harnesses) via een ACP-backendplugin. Elke ACP-sessiestart wordt gevolgd als een achtergrondtaak.Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
ACP is het pad voor externe harnesses, niet het standaard Codex-pad. De
native Codex-app-serverplugin beheert
/codex ...-besturing en de standaard
ingesloten runtime openai/gpt-* voor agentbeurten; ACP beheert
/acp ...-besturing en sessions_spawn({ runtime: "acp" })-sessies.Als je wilt dat Codex of Claude Code als externe MCP-client rechtstreeks
verbinding maakt met bestaande OpenClaw-kanaalgesprekken, gebruik dan
openclaw mcp serve in plaats van ACP.Welke pagina heb ik nodig?
| Je wilt… | Gebruik dit | Opmerkingen |
|---|---|---|
| Codex in het huidige gesprek koppelen of besturen | /codex bind, /codex threads | Native Codex-app-serverpad wanneer de codex-plugin is ingeschakeld; omvat gekoppelde chatantwoorden, doorsturen van afbeeldingen, model/fast/machtigingen, stoppen en steer-besturing. ACP is een expliciete fallback |
| Claude Code, Gemini CLI, expliciete Codex ACP of een andere externe harness via OpenClaw uitvoeren | Deze pagina | Chat-gekoppelde sessies, /acp spawn, sessions_spawn({ runtime: "acp" }), achtergrondtaken, runtimebesturing |
| Een OpenClaw Gateway-sessie als ACP-server aanbieden voor een editor of client | openclaw acp | Bridgemodus. IDE/client spreekt ACP met OpenClaw via stdio/WebSocket |
| Een lokale AI-CLI hergebruiken als tekst-only fallbackmodel | CLI-backends | Geen ACP. Geen OpenClaw-tools, geen ACP-besturing, geen harness-runtime |
Werkt dit standaard?
Ja, na installatie van de officiële ACP-runtimeplugin:extensions/acpx gebruiken na
pnpm install. Voer /acp doctor uit voor een gereedheidscontrole.
OpenClaw leert agents alleen over ACP-spawning wanneer ACP echt
bruikbaar is: ACP moet ingeschakeld zijn, dispatch mag niet uitgeschakeld
zijn, de huidige sessie mag niet door de sandbox geblokkeerd zijn en er moet
een runtimebackend geladen zijn. Als niet aan die voorwaarden wordt voldaan,
blijven ACP-plugin-Skills en ACP-begeleiding voor sessions_spawn verborgen,
zodat de agent geen niet-beschikbare backend voorstelt.
Valkuilen bij de eerste uitvoering
Valkuilen bij de eerste uitvoering
- Als
plugins.allowis ingesteld, is dit een beperkende plugin-inventaris en moet dezeacpxbevatten; anders wordt de geïnstalleerde ACP-backend opzettelijk geblokkeerd en meldt/acp doctorde ontbrekende allowlist-vermelding. - De Codex ACP-adapter wordt met de
acpx-plugin klaargezet en waar mogelijk lokaal gestart. - Codex ACP draait met een geïsoleerde
CODEX_HOME; OpenClaw kopieert alleen vertrouwde projectvermeldingen uit de host-Codex-configuratie en vertrouwt de actieve workspace, terwijl auth, meldingen en hooks in de hostconfiguratie blijven. - Andere doel-harnessadapters kunnen nog steeds op aanvraag met
npxworden opgehaald wanneer je ze voor het eerst gebruikt. - Leveranciersauthenticatie moet nog steeds op de host bestaan voor die harness.
- Als de host geen npm of netwerktoegang heeft, mislukken adapterfetches bij de eerste uitvoering totdat caches zijn voorverwarmd of de adapter op een andere manier is geïnstalleerd.
Runtimevereisten
Runtimevereisten
ACP start een echt extern harnessproces. OpenClaw beheert routering,
achtergrondtaakstatus, aflevering, koppelingen en beleid; de harness
beheert zijn providerlogin, modelcatalogus, bestandssysteemgedrag en
native tools.Controleer dit voordat je OpenClaw de schuld geeft:
/acp doctormeldt een ingeschakelde, gezonde backend.- De doel-id is toegestaan door
acp.allowedAgentswanneer die allowlist is ingesteld. - Het harnesscommando kan starten op de Gateway-host.
- Providerauthenticatie is aanwezig voor die harness (
claude,codex,gemini,opencode,droid, enz.). - Het geselecteerde model bestaat voor die harness - model-id’s zijn niet overdraagbaar tussen harnesses.
- De aangevraagde
cwdbestaat en is toegankelijk, of laatcwdweg en laat de backend zijn standaard gebruiken. - De machtigingsmodus past bij het werk. Niet-interactieve sessies kunnen niet op native machtigingsprompts klikken, dus schrijf-/exec-intensieve coding-runs hebben meestal een ACPX-machtigingsprofiel nodig dat headless kan doorgaan.
Ondersteunde harnessdoelen
Gebruik met deacpx-backend deze harness-id’s als /acp spawn <id>-
of sessions_spawn({ runtime: "acp", agentId: "<id>" })-doelen:
| Harness-id | Typische backend | Opmerkingen |
|---|---|---|
claude | Claude Code ACP-adapter | Vereist Claude Code-authenticatie op de host. |
codex | Codex ACP-adapter | Alleen expliciete ACP-fallback wanneer native /codex niet beschikbaar is of ACP is aangevraagd. |
copilot | GitHub Copilot ACP-adapter | Vereist Copilot CLI-/runtimeauthenticatie. |
cursor | Cursor CLI ACP (cursor-agent acp) | Overschrijf het acpx-commando als een lokale installatie een ander ACP-entrypoint aanbiedt. |
droid | Factory Droid CLI | Vereist Factory/Droid-authenticatie of FACTORY_API_KEY in de harnessomgeving. |
gemini | Gemini CLI ACP-adapter | Vereist Gemini CLI-authenticatie of API-keyconfiguratie. |
iflow | iFlow CLI | Beschikbaarheid van de adapter en modelbesturing hangen af van de geïnstalleerde CLI. |
kilocode | Kilo Code CLI | Beschikbaarheid van de adapter en modelbesturing hangen af van de geïnstalleerde CLI. |
kimi | Kimi/Moonshot CLI | Vereist Kimi/Moonshot-authenticatie op de host. |
kiro | Kiro CLI | Beschikbaarheid van de adapter en modelbesturing hangen af van de geïnstalleerde CLI. |
opencode | OpenCode ACP-adapter | Vereist OpenCode CLI-/providerauthenticatie. |
openclaw | OpenClaw Gateway-bridge via openclaw acp | Laat een ACP-bewuste harness terugpraten met een OpenClaw Gateway-sessie. |
pi | Pi/ingesloten OpenClaw-runtime | Gebruikt voor OpenClaw-native harness-experimenten. |
qwen | Qwen Code / Qwen CLI | Vereist Qwen-compatibele authenticatie op de host. |
acp.allowedAgents en eventuele
agents.list[].runtime.acp.agent-mapping vóór dispatch.
Operator-runbook
Snelle/acp-flow vanuit chat:
Starten
/acp spawn claude --bind here,
/acp spawn gemini --mode persistent --thread auto, of expliciet
/acp spawn codex --bind here.Levenscyclusdetails
Levenscyclusdetails
- Spawn maakt of hervat een ACP-runtimesessie, registreert ACP-metadata in de OpenClaw-sessieopslag en kan een achtergrondtaak maken wanneer de run door de parent wordt beheerd.
- Door de parent beheerde ACP-sessies worden behandeld als achtergrondwerk, zelfs wanneer de runtimesessie persistent is; voltooiing en aflevering over oppervlakken heen verlopen via de parent-taaknotifier in plaats van als een normale gebruikersgerichte chatsessie.
- Taakonderhoud sluit terminale of verweesde, door de parent beheerde one-shot ACP-sessies. Persistente ACP-sessies blijven behouden zolang er een actieve gesprekskoppeling bestaat; verouderde persistente sessies zonder actieve koppeling worden gesloten zodat ze niet stilzwijgend kunnen worden hervat nadat de eigenaarstaak klaar is of het taakrecord verdwenen is.
- Gekoppelde vervolgmberichten gaan rechtstreeks naar de ACP-sessie totdat de koppeling wordt gesloten, uit focus wordt gehaald, gereset of verlopen is.
- Gateway-commando’s blijven lokaal.
/acp ...,/statusen/unfocusworden nooit als normale prompttekst naar een gekoppelde ACP-harness verzonden. cancelbreekt de actieve beurt af wanneer de backend annulering ondersteunt; het verwijdert de koppeling of sessiemetadata niet.closebeëindigt de ACP-sessie vanuit het perspectief van OpenClaw en verwijdert de koppeling. Een harness kan nog steeds zijn eigen upstreamgeschiedenis behouden als deze hervatten ondersteunt.- De acpx-plugin ruimt door OpenClaw beheerde wrapper- en adapterprocesbomen op na
close, en ruimt verouderde door OpenClaw beheerde ACPX-orphans op tijdens het starten van de Gateway. - Inactieve runtimeworkers komen in aanmerking voor opruiming na
acp.runtime.ttlMinutes; opgeslagen sessiemetadata blijft beschikbaar voor/acp sessions.
Native Codex-routeringsregels
Native Codex-routeringsregels
Triggers in natuurlijke taal die moeten routeren naar de native Codex-
plugin wanneer deze is ingeschakeld:
- “Koppel dit Discord-kanaal aan Codex.”
- “Koppel deze chat aan Codex-thread
<id>.” - “Toon Codex-threads en koppel daarna deze.”
before_tool_call kunnen blokkeren,
after_tool_call kunnen observeren en Codex-PermissionRequest-gebeurtenissen
via OpenClaw-goedkeuringen kunnen routeren. Codex-Stop-hooks worden doorgestuurd naar
OpenClaw before_agent_finalize, waar plugins nog één extra
modelpass kunnen aanvragen voordat Codex zijn antwoord afrondt. De relay blijft
bewust conservatief: hij wijzigt geen Codex-native toolargumenten
en herschrijft geen Codex-threadrecords. Gebruik expliciete ACP alleen
wanneer je het ACP-runtime-/sessiemodel wilt. De grens van ingebedde Codex-ondersteuning
is gedocumenteerd in het
Codex harness v1-ondersteuningscontract.Spiekbriefje voor model-/provider-/runtimeselectie
Spiekbriefje voor model-/provider-/runtimeselectie
openai-codex/*- legacy Codex OAuth-/abonnementsmodelroute die door doctor wordt gerepareerd.openai/*- native Codex app-server ingebedde runtime voor OpenAI-agentbeurten./codex ...- native Codex-gespreksbesturing./acp ...ofruntime: "acp"- expliciete ACP/acpx-besturing.
ACP-routingtriggers in natuurlijke taal
ACP-routingtriggers in natuurlijke taal
Triggers die naar de ACP-runtime moeten routeren:
- “Voer dit uit als een eenmalige Claude Code ACP-sessie en vat het resultaat samen.”
- “Gebruik Gemini CLI voor deze taak in een thread en bewaar vervolgstappen daarna in dezelfde thread.”
- “Voer Codex via ACP uit in een achtergrondthread.”
runtime: "acp", lost de harness agentId op,
bindt aan het huidige gesprek of de huidige thread wanneer dat wordt ondersteund, en
routeert vervolgstappen naar die sessie tot sluiten/verlopen. Codex volgt
dit pad alleen wanneer ACP/acpx expliciet is of de native Codex-
plugin niet beschikbaar is voor de gevraagde bewerking.Voor sessions_spawn wordt runtime: "acp" alleen aangekondigd wanneer ACP
is ingeschakeld, de aanvrager niet in een sandbox zit en er een ACP-runtime-
backend is geladen. acp.dispatch.enabled=false pauzeert automatische
ACP-threaddispatch, maar verbergt of blokkeert expliciete
sessions_spawn({ runtime: "acp" })-aanroepen niet. Het richt zich op ACP-harness-id’s zoals codex,
claude, droid, gemini of opencode. Geef geen normale
OpenClaw-configuratie-agent-id uit agents_list door, tenzij die vermelding
expliciet is geconfigureerd met agents.list[].runtime.type="acp";
gebruik anders de standaard sub-agent-runtime. Wanneer een OpenClaw-agent
is geconfigureerd met runtime.type="acp", gebruikt OpenClaw
runtime.acp.agent als onderliggende harness-id.ACP versus sub-agents
Gebruik ACP wanneer je een externe harness-runtime wilt. Gebruik native Codex app-server voor Codex-gespreksbinding/-besturing wanneer decodex-
plugin is ingeschakeld. Gebruik sub-agents wanneer je door OpenClaw-native
gedelegeerde runs wilt.
| Gebied | ACP-sessie | Sub-agent-run |
|---|---|---|
| Runtime | ACP-backend-plugin (bijvoorbeeld acpx) | OpenClaw native sub-agent-runtime |
| Sessiesleutel | agent:<agentId>:acp:<uuid> | agent:<agentId>:subagent:<uuid> |
| Hoofdopdrachten | /acp ... | /subagents ... |
| Spawn-tool | sessions_spawn met runtime:"acp" | sessions_spawn (standaardruntime) |
Hoe ACP Claude Code uitvoert
Voor Claude Code via ACP is de stack:- OpenClaw ACP-sessiebesturingsvlak.
- Officiële
@openclaw/acpxruntime-plugin. - Claude ACP-adapter.
- Runtime-/sessiemachinerie aan Claude-zijde.
- Wil je
/acp spawn, bindbare sessies, runtimebesturing of persistent harness-werk? Gebruik ACP. - Wil je eenvoudige lokale tekstfallback via de ruwe CLI? Gebruik CLI-backends.
Gebonden sessies
Mentaal model
- Chatoppervlak - waar mensen blijven praten (Discord-kanaal, Telegram-topic, iMessage-chat).
- ACP-sessie - de duurzame Codex/Claude/Gemini-runtime-status waar OpenClaw naartoe routeert.
- Onderliggende thread/topic - een optioneel extra berichtenoppervlak dat alleen door
--thread ...wordt gemaakt. - Runtimewerkruimte - de bestandssysteemlocatie (
cwd, repo-checkout, backendwerkruimte) waar de harness draait. Onafhankelijk van het chatoppervlak.
Bindingen aan huidig gesprek
/acp spawn <harness> --bind here pint het huidige gesprek vast aan de
gespawnde ACP-sessie - geen onderliggende thread, hetzelfde chatoppervlak. OpenClaw blijft
transport, auth, veiligheid en aflevering beheren. Vervolgberichten in dat
gesprek routeren naar dezelfde sessie; /new en /reset resetten de
sessie op dezelfde plek; /acp close verwijdert de binding.
Voorbeelden:
Bindingsregels en exclusiviteit
Bindingsregels en exclusiviteit
--bind hereen--thread ...sluiten elkaar uit.--bind herewerkt alleen op kanalen die binding aan het huidige gesprek aankondigen; OpenClaw retourneert anders een duidelijke niet-ondersteund-melding. Bindingen blijven bestaan na herstarts van de Gateway.- Op Discord gated
spawnSessionshet maken van onderliggende threads voor--thread auto|here- niet--bind here. - Als je naar een andere ACP-agent spawnt zonder
--cwd, neemt OpenClaw standaard de werkruimte van de doelagent over. Ontbrekende overgenomen paden (ENOENT/ENOTDIR) vallen terug op de backendstandaard; andere toegangsfouten (bijv.EACCES) verschijnen als spawnfouten. - Gateway-beheeropdrachten blijven lokaal in gebonden gesprekken -
/acp ...-opdrachten worden door OpenClaw afgehandeld, zelfs wanneer normale vervolgtekst naar de gebonden ACP-sessie routeert;/statusen/unfocusblijven ook lokaal wanneer opdrachtafhandeling voor dat oppervlak is ingeschakeld.
Thread-gebonden sessies
Thread-gebonden sessies
Wanneer threadbindingen zijn ingeschakeld voor een kanaaladapter:
- OpenClaw bindt een thread aan een doel-ACP-sessie.
- Vervolgberichten in die thread routeren naar de gebonden ACP-sessie.
- ACP-uitvoer wordt teruggeleverd aan dezelfde thread.
- Unfocus/sluiten/archiveren/idle-timeout of verlopen door maximale leeftijd verwijdert de binding.
/acp close,/acp cancel,/acp status,/statusen/unfocuszijn Gateway-opdrachten, geen prompts voor de ACP-harness.
acp.enabled=trueacp.dispatch.enabledstaat standaard aan (zet opfalseom automatische ACP-threaddispatch te pauzeren; explicietesessions_spawn({ runtime: "acp" })-aanroepen blijven werken).- Spawns van thread-sessies voor kanaaladapters ingeschakeld (standaard:
true):- Discord:
channels.discord.threadBindings.spawnSessions=true - Telegram:
channels.telegram.threadBindings.spawnSessions=true
- Discord:
Kanalen met threadondersteuning
Kanalen met threadondersteuning
- Elke kanaaladapter die sessie-/threadbindingscapaciteit blootstelt.
- Huidige ingebouwde ondersteuning: Discord-threads/kanalen, Telegram-topics (forumtopics in groepen/supergroepen en DM-topics).
- Plugin-kanalen kunnen ondersteuning toevoegen via dezelfde bindingsinterface.
Persistente kanaalbindingen
Configureer voor niet-ephemere workflows persistente ACP-bindingen in top-levelbindings[]-vermeldingen.
Bindingsmodel
Markeert een persistente ACP-gespreksbinding.
Identificeert het doelgesprek. Vormen per kanaal:
- Discord-kanaal/thread:
match.channel="discord"+match.peer.id="<channelOrThreadId>" - Slack-kanaal/DM:
match.channel="slack"+match.peer.id="<channelId|channel:<channelId>|#<channelId>|userId|user:<userId>|slack:<userId>|<@userId>>". Geef de voorkeur aan stabiele Slack-id’s; kanaalbindingen matchen ook antwoorden binnen de threads van dat kanaal. - Telegram-forumtopic:
match.channel="telegram"+match.peer.id="<chatId>:topic:<topicId>" - iMessage-DM/groep:
match.channel="imessage"+match.peer.id="<handle|chat_id:*|chat_guid:*|chat_identifier:*>". Geef de voorkeur aanchat_id:*voor stabiele groepsbindingen.
De eigenaar-OpenClaw-agent-id.
Optionele ACP-override.
Optioneel operatorgericht label.
Optionele runtimewerkdirectory.
Optionele backend-override.
Runtimestandaarden per agent
Gebruikagents.list[].runtime om ACP-standaarden één keer per agent te definiëren:
agents.list[].runtime.type="acp"agents.list[].runtime.acp.agent(harness-id, bijv.codexofclaude)agents.list[].runtime.acp.backendagents.list[].runtime.acp.modeagents.list[].runtime.acp.cwd
bindings[].acp.*agents.list[].runtime.acp.*- Globale ACP-standaarden (bijv.
acp.backend)
Voorbeeld
Gedrag
- OpenClaw zorgt dat de geconfigureerde ACP-sessie bestaat vóór gebruik.
- Berichten in dat kanaal of onderwerp worden naar de geconfigureerde ACP-sessie gerouteerd.
- In gebonden gesprekken resetten
/newen/resetdezelfde ACP-sessiesleutel ter plaatse. - Tijdelijke runtimebindingen (bijvoorbeeld aangemaakt door thread-focusflows) blijven van toepassing waar aanwezig.
- Voor cross-agent ACP-spawns zonder expliciete
cwderft OpenClaw de werkruimte van de doelagent uit de agentconfiguratie. - Ontbrekende overgeërfde werkruimtepaden vallen terug op de standaard-cwd van de backend; niet-ontbrekende toegangsfouten verschijnen als spawnfouten.
ACP-sessies starten
Twee manieren om een ACP-sessie te starten:- From sessions_spawn
- From /acp command
Gebruik
runtime: "acp" om een ACP-sessie te starten vanuit een agentbeurt of
toolaanroep.runtime staat standaard op subagent, dus stel expliciet runtime: "acp" in
voor ACP-sessies. Als agentId wordt weggelaten, gebruikt OpenClaw
acp.defaultAgent wanneer dit is geconfigureerd. mode: "session" vereist
thread: true om een persistent gebonden gesprek te behouden.sessions_spawn-parameters
Initiële prompt die naar de ACP-sessie wordt gestuurd.
Moet
"acp" zijn voor ACP-sessies.ACP-doelharnas-id. Valt terug op
acp.defaultAgent als dit is ingesteld.Vraag een threadbindingsflow aan waar ondersteund.
"run" is eenmalig; "session" is persistent. Als thread: true en
mode wordt weggelaten, kan OpenClaw standaard kiezen voor persistent gedrag per
runtimepad. mode: "session" vereist thread: true.Aangevraagde werkmap voor de runtime (gevalideerd door backend-/runtimebeleid).
Als deze wordt weggelaten, erft de ACP-spawn de werkruimte van de doelagent
wanneer die is geconfigureerd; ontbrekende overgeërfde paden vallen terug op
backendstandaarden, terwijl echte toegangsfouten worden geretourneerd.
Operatorgericht label dat wordt gebruikt in sessie-/bannertekst.
Hervat een bestaande ACP-sessie in plaats van een nieuwe te maken. De
agent speelt zijn gespreksgeschiedenis opnieuw af via
session/load. Vereist
runtime: "acp"."parent" streamt voortgangssamenvattingen van de initiële ACP-run terug naar de
aanvragende sessie als systeemgebeurtenissen. Geaccepteerde reacties omvatten
streamLogPath, dat verwijst naar een sessiegebonden JSONL-log
(<sessionId>.acp-stream.jsonl) dat je kunt volgen voor volledige relaygeschiedenis.Breekt de ACP-childbeurt af na N seconden.
0 houdt de beurt op het
pad zonder time-out van de Gateway. Dezelfde waarde wordt toegepast op de Gateway-run
en ACP-runtime, zodat vastgelopen harnassen of harnassen zonder quota
de baan van de ouderagent niet onbeperkt bezet houden.Expliciete modeloverride voor de ACP-childsessie. Codex ACP-spawns
normaliseren OpenClaw Codex-referenties zoals
openai-codex/gpt-5.4 naar Codex
ACP-opstartconfiguratie vóór session/new; slashvormen zoals
openai-codex/gpt-5.4/high stellen ook de redeneerinspanning van Codex ACP in.
Andere harnassen moeten ACP models adverteren en
session/set_model ondersteunen; anders faalt OpenClaw/acpx duidelijk in plaats van
stil terug te vallen op de standaard van de doelagent.Expliciete denk-/redeneerinspanning. Voor Codex ACP wordt
minimal gekoppeld aan
lage inspanning, worden low/medium/high/xhigh direct gekoppeld, en laat off
de opstartoverride voor redeneerinspanning weg.Bind- en threadmodi voor spawn
- --bind here|off
- --thread auto|here|off
| Modus | Gedrag |
|---|---|
here | Bind het huidige actieve gesprek ter plaatse; faal als er geen actief is. |
off | Maak geen binding voor het huidige gesprek. |
--bind hereis het eenvoudigste operatorpad voor “maak dit kanaal of deze chat door Codex ondersteund.”--bind heremaakt geen childthread.--bind hereis alleen beschikbaar op kanalen die ondersteuning voor binding van het huidige gesprek bieden.--binden--threadkunnen niet worden gecombineerd in dezelfde/acp spawn-aanroep.
Leveringsmodel
ACP-sessies kunnen interactieve werkruimten zijn of achtergrondwerk dat door de ouder wordt beheerd. Het leveringspad hangt af van die vorm.Interactive ACP sessions
Interactive ACP sessions
Interactieve sessies zijn bedoeld om te blijven praten op een zichtbaar chatoppervlak:
/acp spawn ... --bind herebindt het huidige gesprek aan de ACP-sessie./acp spawn ... --thread ...bindt een kanaalthread/-onderwerp aan de ACP-sessie.- Persistent geconfigureerde
bindings[].type="acp"routeren overeenkomende gesprekken naar dezelfde ACP-sessie.
- Normale gebonden vervolgberichten worden verzonden als prompttekst, plus bijlagen alleen wanneer het harnas/de backend ze ondersteunt.
/acp-beheeropdrachten en lokale Gateway-opdrachten worden onderschept vóór ACP-dispatch.- Door de runtime gegenereerde voltooiingsgebeurtenissen worden per doel gematerialiseerd. OpenClaw-agenten krijgen de interne runtime-contextenvelop van OpenClaw; externe ACP-harnassen krijgen een gewone prompt met het childresultaat en de instructie. De ruwe
<<<BEGIN_OPENCLAW_INTERNAL_CONTEXT>>>-envelop mag nooit naar externe harnassen worden gestuurd of als ACP-gebruikerstranscripttekst worden bewaard. - ACP-transcriptitems gebruiken de voor de gebruiker zichtbare triggertekst of de gewone voltooiingsprompt. Interne gebeurtenismetadata blijven waar mogelijk gestructureerd in OpenClaw en worden niet behandeld als door de gebruiker geschreven chatinhoud.
Parent-owned one-shot ACP sessions
Parent-owned one-shot ACP sessions
Eenmalige ACP-sessies die door een andere agentrun worden gespawnd, zijn achtergrondchildren,
vergelijkbaar met subagents:
- De ouder vraagt om werk met
sessions_spawn({ runtime: "acp", mode: "run" }). - De child draait in zijn eigen ACP-harnassessie.
- Childbeurten draaien op dezelfde achtergrondbaan die wordt gebruikt door native subagent-spawns, zodat een traag ACP-harnas geen niet-gerelateerd hoofdssessiewerk blokkeert.
- Voltooiing wordt teruggerapporteerd via het aankondigingspad voor taakvoltooiing. OpenClaw zet interne voltooiingsmetadata om naar een gewone ACP-prompt voordat deze naar een extern harnas wordt gestuurd, zodat harnassen geen runtime-contextmarkeringen zien die alleen voor OpenClaw zijn.
- De ouder herschrijft het childresultaat in een normale assistentstem wanneer een gebruikersgerichte reactie nuttig is.
sessions_send and A2A delivery
sessions_send and A2A delivery
sessions_send kan na spawn op een andere sessie richten. Voor normale
peersessies gebruikt OpenClaw een agent-naar-agent (A2A)-vervolgpad
nadat het bericht is geïnjecteerd:- Wacht op het antwoord van de doelsessie.
- Laat aanvrager en doel optioneel een begrensd aantal vervolgbeurten uitwisselen.
- Vraag het doel om een aankondigingsbericht te produceren.
- Lever die aankondiging aan het zichtbare kanaal of de thread.
tools.sessions.visibility-instellingen.OpenClaw slaat het A2A-vervolg alleen over wanneer de aanvrager de
ouder is van zijn eigen door de ouder beheerde eenmalige ACP-child. In dat geval kan
A2A boven op taakvoltooiing de ouder wakker maken met het
resultaat van de child, het antwoord van de ouder terugsturen naar de child, en
een ouder/child-echoloop maken. Het sessions_send-resultaat meldt
delivery.status="skipped" voor dat eigen-childgeval, omdat het
voltooiingspad al verantwoordelijk is voor het resultaat.Resume an existing session
Resume an existing session
Gebruik Veelvoorkomende gebruikssituaties:
resumeSessionId om een eerdere ACP-sessie voort te zetten in plaats van
opnieuw te beginnen. De agent speelt zijn gespreksgeschiedenis opnieuw af via
session/load, zodat hij verdergaat met de volledige context van wat eraan voorafging.- Draag een Codex-sessie over van je laptop naar je telefoon - zeg je agent dat hij moet verdergaan waar je was gebleven.
- Zet een codeersessie voort die je interactief in de CLI bent gestart, nu headless via je agent.
- Pak werk weer op dat werd onderbroken door een Gateway-herstart of idle time-out.
resumeSessionIdgeldt alleen wanneerruntime: "acp"; de standaard subagent-runtime negeert dit veld dat alleen voor ACP is.streamTogeldt alleen wanneerruntime: "acp"; de standaard subagent-runtime negeert dit veld dat alleen voor ACP is.resumeSessionIdis een hostlokale ACP-/harnas-hervat-id, geen OpenClaw-kanaalsessiesleutel; OpenClaw controleert nog steeds ACP-spawnbeleid en doelagentbeleid vóór dispatch, terwijl de ACP-backend of het harnas eigenaar is van autorisatie voor het laden van die upstream-id.resumeSessionIdherstelt de upstream ACP-gespreksgeschiedenis;threadenmodezijn nog steeds normaal van toepassing op de nieuwe OpenClaw-sessie die je maakt, dusmode: "session"vereist nog steedsthread: true.- De doelagent moet
session/loadondersteunen (Codex en Claude Code doen dat). - Als de sessie-id niet wordt gevonden, faalt de spawn met een duidelijke fout - geen stille fallback naar een nieuwe sessie.
Post-deploy smoke test
Post-deploy smoke test
Voer na een Gateway-deploy een live end-to-endcontrole uit in plaats van
te vertrouwen op unittests:
- Controleer de gedeployde Gateway-versie en commit op de doelhost.
- Open een tijdelijke ACPX-brugsessie naar een live agent.
- Vraag die agent om
sessions_spawnaan te roepen metruntime: "acp",agentId: "codex",mode: "run"en taakReply with exactly LIVE-ACP-SPAWN-OK. - Controleer
accepted=yes, een echtechildSessionKeyen geen validatorfout. - Ruim de tijdelijke brugsessie op.
mode: "run" en sla streamTo: "parent" over -
aan threads gebonden mode: "session" en stream-relaypaden zijn aparte,
rijkere integratiepasses.Sandboxcompatibiliteit
ACP-sessies draaien momenteel op de hostruntime, niet binnen de OpenClaw-sandbox. Huidige beperkingen:- Als de aanvragende sessie in een sandbox draait, worden ACP-spawns geblokkeerd voor zowel
sessions_spawn({ runtime: "acp" })als/acp spawn. sessions_spawnmetruntime: "acp"ondersteuntsandbox: "require"niet.
Resolutie van sessiedoel
De meeste/acp-acties accepteren een optioneel sessiedoel (session-key,
session-id of session-label).
Resolutievolgorde:
- Expliciet doelargument (of
--sessionvoor/acp steer)- probeert sleutel
- daarna UUID-vormige sessie-id
- daarna label
- Huidige threadbinding (als dit gesprek/deze thread aan een ACP-sessie is gebonden).
- Terugval naar huidige aanvragende sessie.
Unable to resolve session target: ...).
ACP-besturing
| Opdracht | Wat het doet | Voorbeeld |
|---|---|---|
/acp spawn | Maak ACP-sessie aan; optionele huidige binding of threadbinding. | /acp spawn codex --bind here --cwd /repo |
/acp cancel | Annuleer lopende beurt voor doelsessie. | /acp cancel agent:codex:acp:<uuid> |
/acp steer | Stuur stuurinstructie naar draaiende sessie. | /acp steer --session support inbox prioritize failing tests |
/acp close | Sluit sessie en maak threaddoelen los. | /acp close |
/acp status | Toon backend, modus, status, runtime-opties, mogelijkheden. | /acp status |
/acp set-mode | Stel runtimemodus in voor doelsessie. | /acp set-mode plan |
/acp set | Schrijf generieke runtimeconfiguratieoptie. | /acp set model openai/gpt-5.4 |
/acp cwd | Stel override voor runtimewerkmap in. | /acp cwd /Users/user/Projects/repo |
/acp permissions | Stel profiel voor goedkeuringsbeleid in. | /acp permissions strict |
/acp timeout | Stel runtimetime-out in (seconden). | /acp timeout 120 |
/acp model | Stel override voor runtimemodel in. | /acp model anthropic/claude-opus-4-6 |
/acp reset-options | Verwijder overrides voor sessieruntimeopties. | /acp reset-options |
/acp sessions | Toon recente ACP-sessies uit de opslag. | /acp sessions |
/acp doctor | Backendgezondheid, mogelijkheden, uitvoerbare oplossingen. | /acp doctor |
/acp install | Druk deterministische installatie- en inschakelstappen af. | /acp install |
/acp status toont de effectieve runtime-opties plus runtime- en
backendniveau-sessie-identifiers. Fouten voor niet-ondersteunde besturing
verschijnen duidelijk wanneer een backend een mogelijkheid mist. /acp sessions leest de
opslag voor de huidige gebonden of aanvragende sessie; doeltokens
(session-key, session-id of session-label) worden opgelost via
Gateway-sessieontdekking, inclusief aangepaste per-agent session.store-
roots.
Toewijzing van runtime-opties
/acp heeft handige opdrachten en een generieke setter. Equivalente
bewerkingen:
| Opdracht | Wijst toe aan | Opmerkingen |
|---|---|---|
/acp model <id> | runtimeconfiguratiesleutel model | Voor Codex ACP normaliseert OpenClaw openai-codex/<model> naar de adaptermodel-id en wijst slash-redeneersuffixen zoals openai-codex/gpt-5.4/high toe aan reasoning_effort. |
/acp set thinking <level> | canonieke optie thinking | OpenClaw stuurt het door de backend geadverteerde equivalent wanneer aanwezig, met voorkeur voor thinking, daarna effort, reasoning_effort of thought_level. Voor Codex ACP wijst de adapter waarden toe aan reasoning_effort. |
/acp permissions <profile> | canonieke optie permissionProfile | OpenClaw stuurt het door de backend geadverteerde equivalent wanneer aanwezig, zoals approval_policy, permission_profile, permissions of permission_mode. |
/acp timeout <seconds> | canonieke optie timeoutSeconds | OpenClaw stuurt het door de backend geadverteerde equivalent wanneer aanwezig, zoals timeout of timeout_seconds. |
/acp cwd <path> | runtime-cwd-override | Directe update. |
/acp set <key> <value> | generiek | key=cwd gebruikt het cwd-overridepad. |
/acp reset-options | wist alle runtime-overrides | - |
acpx-harness, Plugin-installatie en machtigingen
Voor acpx-harnessconfiguratie (Claude Code / Codex / Gemini CLI- aliassen), de MCP-bruggen plugin-tools en OpenClaw-tools, en ACP- machtigingsmodi, zie ACP-agents - installatie.Probleemoplossing
| Symptoom | Waarschijnlijke oorzaak | Oplossing |
|---|---|---|
ACP runtime backend is not configured | Backend-Plugin ontbreekt, is uitgeschakeld of wordt geblokkeerd door plugins.allow. | Installeer en schakel de backend-Plugin in, neem acpx op in plugins.allow wanneer die allowlist is ingesteld, en voer daarna /acp doctor uit. |
ACP is disabled by policy (acp.enabled=false) | ACP is globaal uitgeschakeld. | Stel acp.enabled=true in. |
ACP dispatch is disabled by policy (acp.dispatch.enabled=false) | Automatische dispatch vanuit normale threadberichten is uitgeschakeld. | Stel acp.dispatch.enabled=true in om automatische threadroutering te hervatten; expliciete sessions_spawn({ runtime: "acp" })-aanroepen blijven werken. |
ACP agent "<id>" is not allowed by policy | Agent staat niet in de allowlist. | Gebruik een toegestane agentId of werk acp.allowedAgents bij. |
/acp doctor meldt dat de backend niet klaar is direct na het opstarten | Backend-Plugin ontbreekt, is uitgeschakeld, wordt geblokkeerd door allow/deny-beleid, of het geconfigureerde uitvoerbare bestand is niet beschikbaar. | Installeer/schakel de backend-Plugin in, voer /acp doctor opnieuw uit en inspecteer de backendinstallatie of beleidsfout als deze ongezond blijft. |
| Harnessopdracht niet gevonden | Adapter-CLI is niet geïnstalleerd, de externe Plugin ontbreekt, of de eerste npx-fetch is mislukt voor een niet-Codex-adapter. | Voer /acp doctor uit, installeer/warm de adapter vooraf op de Gateway-host op, of configureer de acpx-agentopdracht expliciet. |
| Model-niet-gevonden vanuit de harness | Model-id is geldig voor een andere provider/harness, maar niet voor dit ACP-doel. | Gebruik een model dat door die harness wordt vermeld, configureer het model in de harness, of laat de override weg. |
| Vendor-authenticatiefout vanuit de harness | OpenClaw is gezond, maar de doel-CLI/provider is niet aangemeld. | Meld je aan of geef de vereiste providersleutel op in de Gateway-hostomgeving. |
Unable to resolve session target: ... | Ongeldig sleutel-/id-/labeltoken. | Voer /acp sessions uit, kopieer de exacte sleutel/het exacte label en probeer het opnieuw. |
--bind here requires running /acp spawn inside an active ... conversation | --bind here gebruikt zonder een actief bindbaar gesprek. | Ga naar de doelchat/het doelkanaal en probeer het opnieuw, of gebruik een ongebonden spawn. |
Conversation bindings are unavailable for <channel>. | Adapter mist de ACP-bindingsmogelijkheid voor het huidige gesprek. | Gebruik /acp spawn ... --thread ... waar ondersteund, configureer bindings[] op topniveau, of ga naar een ondersteund kanaal. |
--thread here requires running /acp spawn inside an active ... thread | --thread here gebruikt buiten een threadcontext. | Ga naar de doelthread of gebruik --thread auto/off. |
Only <user-id> can rebind this channel/conversation/thread. | Een andere gebruiker is eigenaar van het actieve bindingsdoel. | Bind opnieuw als eigenaar of gebruik een ander gesprek of een andere thread. |
Thread bindings are unavailable for <channel>. | Adapter mist threadbindingsmogelijkheid. | Gebruik --thread off of ga naar een ondersteunde adapter/kanaal. |
Sandboxed sessions cannot spawn ACP sessions ... | ACP-runtime draait aan de hostzijde; de aanvragende sessie is gesandboxed. | Gebruik runtime="subagent" vanuit gesandboxde sessies, of voer ACP-spawn uit vanuit een niet-gesandboxde sessie. |
sessions_spawn sandbox="require" is unsupported for runtime="acp" ... | sandbox="require" aangevraagd voor ACP-runtime. | Gebruik runtime="subagent" voor vereiste sandboxing, of gebruik ACP met sandbox="inherit" vanuit een niet-gesandboxde sessie. |
Cannot apply --model ... did not advertise model support | De doelharness biedt geen generieke ACP-modelwisseling. | Gebruik een harness die ACP models/session/set_model adverteert, gebruik Codex ACP-modelrefs, of configureer het model direct in de harness als die een eigen opstartvlag heeft. |
| Ontbrekende ACP-metadata voor gebonden sessie | Verouderde/verwijderde ACP-sessiemetadata. | Maak opnieuw aan met /acp spawn, en bind/focus daarna de thread opnieuw. |
AcpRuntimeError: Permission prompt unavailable in non-interactive mode | permissionMode blokkeert schrijven/uitvoeren in een niet-interactieve ACP-sessie. | Stel plugins.entries.acpx.config.permissionMode in op approve-all en herstart de Gateway. Zie Permissieconfiguratie. |
| ACP-sessie faalt vroeg met weinig output | Permissieprompts worden geblokkeerd door permissionMode/nonInteractivePermissions. | Controleer Gateway-logs op AcpRuntimeError. Stel voor volledige permissies permissionMode=approve-all in; stel voor gracieuze degradatie nonInteractivePermissions=deny in. |
| ACP-sessie blijft voor onbepaalde tijd hangen na voltooiing van het werk | Harnessproces is voltooid, maar ACP-sessie heeft geen voltooiing gemeld. | Werk OpenClaw bij; de huidige acpx-cleanup ruimt door OpenClaw beheerde verouderde wrapper- en adapterprocessen op bij sluiten en bij het opstarten van de Gateway. |
Harness ziet <<<BEGIN_OPENCLAW_INTERNAL_CONTEXT>>> | Interne eventenvelope is over de ACP-grens gelekt. | Werk OpenClaw bij en voer de voltooiingsflow opnieuw uit; externe harnesses zouden alleen platte voltooiingsprompts moeten ontvangen. |