Exec-goedkeuringen zijn de vangrail van de companion app / node-host om een gesandboxte agent opdrachten op een echte host (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.
gateway of node) te laten uitvoeren. Een
veiligheidsvergrendeling: opdrachten zijn alleen toegestaan wanneer beleid + allowlist +
(optioneel) gebruikersgoedkeuring allemaal overeenstemmen. Exec-goedkeuringen stapelen bovenop
toolbeleid en elevated gating (tenzij elevated is ingesteld op full, wat
goedkeuringen overslaat).
Het effectieve beleid is het strengere van
tools.exec.* en de standaardwaarden voor goedkeuringen;
als een goedkeuringsveld wordt weggelaten, wordt de tools.exec-waarde
gebruikt. Host-exec gebruikt ook de lokale goedkeuringsstatus op die machine - een
host-lokale ask: "always" in ~/.openclaw/exec-approvals.json blijft
vragen, zelfs als sessie- of configuratiestandaarden ask: "on-miss" aanvragen.Het effectieve beleid inspecteren
| Opdracht | Wat het toont |
|---|---|
openclaw approvals get / --gateway / --node <id|name|ip> | Aangevraagd beleid, bronnen van hostbeleid en het effectieve resultaat. |
openclaw exec-policy show | Samengevoegde weergave voor de lokale machine. |
openclaw exec-policy set / preset | Synchroniseer het lokale aangevraagde beleid in één stap met het lokale hostgoedkeuringsbestand. |
host=node aanvraagt, rapporteert exec-policy show dat
bereik tijdens runtime als node-beheerd in plaats van te doen alsof het lokale
goedkeuringsbestand de bron van waarheid is.
Als de UI van de companion app niet beschikbaar is, wordt elk verzoek dat
normaal gesproken een prompt zou tonen, opgelost door de ask fallback (standaard: deny).
Waar het van toepassing is
Exec-goedkeuringen worden lokaal afgedwongen op de uitvoeringshost:- Gateway-host →
openclaw-proces op de Gateway-machine. - Node-host → node-runner (macOS companion app of headless node-host).
Vertrouwensmodel
- Gateway-geauthenticeerde aanroepers zijn vertrouwde operators voor die Gateway.
- Gekoppelde nodes breiden die vertrouwde operatorcapaciteit uit naar de node-host.
- Exec-goedkeuringen verminderen het risico op onbedoelde uitvoering, maar zijn geen autorisatiegrens per gebruiker of bestandssysteembeleid voor alleen-lezen.
- Na goedkeuring kan een opdracht bestanden wijzigen volgens de geselecteerde host- of sandboxbestandssysteemrechten.
- Goedgekeurde node-host-runs binden canonieke uitvoeringscontext: canonieke cwd, exacte argv, env-binding wanneer aanwezig, en vastgezette uitvoerbare padnaam wanneer van toepassing.
- Voor shellscripts en directe interpreter-/runtimebestandsaanroepen probeert OpenClaw ook één concreet lokaal bestandsoperand te binden. Als dat gebonden bestand na goedkeuring maar vóór uitvoering verandert, wordt de run geweigerd in plaats van gewijzigde inhoud uit te voeren.
- Bestandsbinding is bewust best-effort, geen volledig semantisch model van elk interpreter-/runtimeloaderpad. Als de goedkeuringsmodus niet precies één concreet lokaal bestand kan identificeren om te binden, weigert deze een door goedkeuring gedekte run te minten in plaats van volledige dekking te veinzen.
macOS-splitsing
- De node-hostservice stuurt
system.rundoor naar de macOS-app via lokale IPC. - De macOS-app dwingt goedkeuringen af en voert de opdracht uit in UI-context.
Instellingen en opslag
Goedkeuringen staan in een lokaal JSON-bestand op de uitvoeringshost:Beleidsknoppen
exec.security
deny- blokkeer alle host-exec-verzoeken.allowlist- sta alleen opdrachten op de allowlist toe.full- sta alles toe (equivalent aan elevated).
exec.ask
off- vraag nooit.on-miss- vraag alleen wanneer de allowlist niet overeenkomt.always- vraag bij elke opdracht. Duurzaam vertrouwen viaallow-alwaysonderdrukt prompts niet wanneer de effectieve ask-modusalwaysis.
askFallback
Resolutie wanneer een prompt vereist is maar er geen UI bereikbaar is.
deny- blokkeer.allowlist- sta alleen toe als de allowlist overeenkomt.full- sta toe.
tools.exec.strictInlineEval
Wanneer
true, behandelt OpenClaw inline code-eval-vormen als alleen-goedkeuring,
zelfs als de interpreter-binary zelf op de allowlist staat. Defense-in-depth
voor interpreterloaders die niet netjes naar één stabiel bestandsoperand
mappen.python -cnode -e,node --eval,node -pruby -eperl -e,perl -Ephp -rlua -eosascript -e
allow-always bewaart niet automatisch nieuwe allowlist-vermeldingen voor ze.
tools.exec.commandHighlighting
Regelt alleen de presentatie in exec-goedkeuringsprompts. Wanneer ingeschakeld,
kan OpenClaw parser-afgeleide opdrachtbereiken toevoegen zodat Web-goedkeuringsprompts
opdrachttokens kunnen markeren. Stel dit in op
true om
markering van opdrachttekst in te schakelen.security, ask, allowlist-matching,
strikt inline-eval-gedrag, doorsturen van goedkeuringen of opdrachtuitvoering.
Ze kan globaal worden ingesteld onder tools.exec.commandHighlighting of per
agent onder agents.list[].tools.exec.commandHighlighting.
YOLO-modus (geen goedkeuring)
Als je wilt dat host-exec zonder goedkeuringsprompts wordt uitgevoerd, moet je beide beleidslagen openen - het aangevraagde exec-beleid in de OpenClaw-configuratie (tools.exec.*) en het host-lokale goedkeuringsbeleid in
~/.openclaw/exec-approvals.json.
YOLO is het standaard hostgedrag tenzij je het expliciet aanscherpt:
| Laag | YOLO-instelling |
|---|---|
tools.exec.security | full op gateway/node |
tools.exec.ask | off |
Host askFallback | full |
--permission-mode bypassPermissions toe wanneer het aangevraagde exec-beleid van OpenClaw
YOLO is. Overschrijf dat backendgedrag met expliciete Claude-argumenten
onder agents.defaults.cliBackends.claude-cli.args / resumeArgs -
bijvoorbeeld --permission-mode default, acceptEdits of
bypassPermissions.
Als je een conservatievere setup wilt, zet dan een van beide lagen terug naar
allowlist / on-miss of deny.
Persistente Gateway-host-setup met “nooit vragen”
Lokale snelkoppeling
- Lokale
tools.exec.host/security/ask. - Lokale standaardwaarden in
~/.openclaw/exec-approvals.json.
openclaw approvals set --gateway of
openclaw approvals set --node <id|name|ip> om Gateway-host- of node-hostgoedkeuringen
op afstand te wijzigen.
Node-host
Pas voor een node-host in plaats daarvan hetzelfde goedkeuringsbestand toe op die node:Beperkingen voor alleen lokaal:
openclaw exec-policysynchroniseert geen node-goedkeuringen.openclaw exec-policy set --host nodewordt geweigerd.- Node-exec-goedkeuringen worden tijdens runtime opgehaald van de node, dus node-gerichte updates moeten
openclaw approvals --node ...gebruiken.
Snelkoppeling alleen voor de sessie
/exec security=full ask=offwijzigt alleen de huidige sessie./elevated fullis een break-glass-snelkoppeling die ook exec-goedkeuringen voor die sessie overslaat.
Allowlist (per agent)
Allowlists zijn per agent. Als er meerdere agents bestaan, wissel dan in de macOS-app welke agent je bewerkt. Patronen zijn glob-overeenkomsten. Patronen kunnen opgeloste binary-padglobs of kale opdrachtnaamglobs zijn. Kale namen matchen alleen opdrachten die viaPATH worden aangeroepen, dus rg kan matchen
met /opt/homebrew/bin/rg wanneer de opdracht rg is, maar niet met ./rg of
/tmp/rg. Gebruik een padglob wanneer je één specifieke binarylocatie wilt vertrouwen.
Verouderde agents.default-vermeldingen worden bij laden gemigreerd naar agents.main.
Shellketens zoals echo ok && pwd moeten nog steeds elk top-level segment
aan de allowlist-regels laten voldoen.
Voorbeelden:
rg~/Projects/**/bin/peekaboo~/.local/bin/*/opt/homebrew/bin/rg
Argumenten beperken met argPattern
VoegargPattern toe wanneer een allowlist-vermelding een binary en een
specifieke argumentvorm moet matchen. OpenClaw evalueert de reguliere expressie
tegen de geparseerde opdrachtargumenten, exclusief het uitvoerbare token
(argv[0]). Voor handmatig geschreven vermeldingen worden argumenten samengevoegd met één
spatie, dus veranker het patroon wanneer je een exacte match nodig hebt.
python3 safe.py toe; python3 other.py is een allowlist-mis. Als er ook een pad-only vermelding voor dezelfde binary aanwezig is, kunnen niet-overeenkomende
argumenten nog steeds terugvallen op die pad-only vermelding. Laat de pad-only
vermelding weg wanneer het doel is de binary te beperken tot de gedeclareerde argumenten.
Invoeren die door goedkeuringsflows zijn opgeslagen, kunnen een intern scheidingstekenformaat gebruiken voor
exacte argv-matching. Gebruik bij voorkeur de UI of goedkeuringsflow om die
invoeren opnieuw te genereren in plaats van de gecodeerde waarde handmatig te bewerken. Als OpenClaw
argv voor een commandosegment niet kan parsen, komen invoeren met argPattern niet overeen.
Elke allowlist-invoer ondersteunt:
| Veld | Betekenis |
|---|---|
pattern | Opgelost globpatroon voor binair pad of kaal globpatroon voor commandonaam |
argPattern | Optionele argv-regex; weggelaten invoeren zijn alleen padgebaseerd |
id | Stabiele UUID gebruikt voor UI-identiteit |
source | Bron van invoer, zoals allow-always |
commandText | Commandotekst vastgelegd toen een goedkeuringsflow de invoer maakte |
lastUsedAt | Tijdstempel van laatste gebruik |
lastUsedCommand | Laatste commando dat overeenkwam |
lastResolvedPath | Laatst opgeloste binaire pad |
Automatisch toestaan van Skills-CLI’s
Wanneer Automatisch toestaan van Skills-CLI’s is ingeschakeld, worden uitvoerbare bestanden waarnaar bekende skills verwijzen als toegestaan behandeld op Nodes (macOS-Node of headless Node-host). Dit gebruiktskills.bins via de Gateway-RPC om de
skill-binlijst op te halen. Schakel dit uit als je strikte handmatige allowlists wilt.
Veilige bins en doorsturen van goedkeuringen
Voor veilige bins (het stdin-only snelle pad), details over interpreter-binding en hoe je goedkeuringsprompts doorstuurt naar Slack/Discord/Telegram (of ze uitvoert als native goedkeuringsclients), zie Exec-goedkeuringen - geavanceerd.Control-UI bewerken
Gebruik de kaart Control UI → Nodes → Exec-goedkeuringen om standaardwaarden, per-agent-overschrijvingen en allowlists te bewerken. Kies een scope (Standaarden of een agent), pas het beleid aan, voeg allowlist-patronen toe of verwijder ze, en kies vervolgens Opslaan. De UI toont metadata van laatste gebruik per patroon, zodat je de lijst netjes kunt houden. De doelkiezer kiest Gateway (lokale goedkeuringen) of een Node. Nodes moetensystem.execApprovals.get/set adverteren (macOS-app of
headless Node-host). Als een Node nog geen exec-goedkeuringen adverteert,
bewerk dan direct de lokale ~/.openclaw/exec-approvals.json.
CLI: openclaw approvals ondersteunt bewerken van Gateway of Node - zie
Goedkeurings-CLI.
Goedkeuringsflow
Wanneer een prompt vereist is, broadcast de Gatewayexec.approval.requested naar operatorclients. De Control UI en macOS-
app lossen dit op via exec.approval.resolve, waarna de Gateway het
goedgekeurde verzoek doorstuurt naar de Node-host.
Voor host=node bevatten goedkeuringsverzoeken een canonieke systemRunPlan-
payload. De Gateway gebruikt dat plan als de gezaghebbende
commando-/cwd-/sessiecontext bij het doorsturen van goedgekeurde system.run-
verzoeken.
Dat is belangrijk voor asynchrone goedkeuringslatentie:
- Het Node-exec-pad bereidt vooraf één canoniek plan voor.
- Het goedkeuringsrecord slaat dat plan en de bindingsmetadata ervan op.
- Na goedkeuring hergebruikt de uiteindelijke doorgestuurde
system.run-aanroep het opgeslagen plan in plaats van latere wijzigingen van de aanroeper te vertrouwen. - Als de aanroeper
command,rawCommand,cwd,agentIdofsessionKeywijzigt nadat het goedkeuringsverzoek is gemaakt, wijst de Gateway de doorgestuurde uitvoering af als een goedkeuringsmismatch.
Systeemgebeurtenissen
De exec-levenscyclus wordt weergegeven als systeemberichten:Exec running(alleen als het commando de drempel voor de uitvoeringsmelding overschrijdt).Exec finished.Exec denied.
runId in deze
berichten voor eenvoudige correlatie.
Gedrag bij geweigerde goedkeuring
Wanneer een asynchrone exec-goedkeuring wordt geweigerd, voorkomt OpenClaw dat de agent uitvoer hergebruikt van een eerdere uitvoering van hetzelfde commando in de sessie. De weigeringsreden wordt doorgegeven met expliciete instructie dat er geen commando-uitvoer beschikbaar is, wat voorkomt dat de agent beweert dat er nieuwe uitvoer is of het geweigerde commando herhaalt met verouderde resultaten van een eerdere geslaagde uitvoering.Implicaties
fullis krachtig; geef waar mogelijk de voorkeur aan allowlists.askhoudt je betrokken terwijl snelle goedkeuringen mogelijk blijven.- Per-agent-allowlists voorkomen dat goedkeuringen van de ene agent naar andere lekken.
- Goedkeuringen gelden alleen voor host-exec-verzoeken van geautoriseerde afzenders. Ongeautoriseerde afzenders kunnen geen
/execuitvoeren. /exec security=fullis een gemak op sessieniveau voor geautoriseerde operators en slaat goedkeuringen bewust over. Om host-exec hard te blokkeren, stel je goedkeuringsbeveiliging in opdenyof weiger je deexec-tool via toolbeleid.
Gerelateerd
Exec-goedkeuringen - geavanceerd
Veilige bins, interpreter-binding en doorsturen van goedkeuringen naar chat.
Exec-tool
Tool voor uitvoering van shellcommando’s.
Verhoogde modus
Break-glass-pad dat ook goedkeuringen overslaat.
Sandboxing
Sandbox-modi en werkruimtetoegang.
Beveiliging
Beveiligingsmodel en hardening.
Sandbox versus toolbeleid versus verhoogd
Wanneer je welke controle gebruikt.
Skills
Door Skills ondersteund automatisch-toestaan-gedrag.