Backends CLI (runtime de repli)
OpenClaw peut exécuter des CLI d’IA locaux comme solution de repli en texte seul lorsque les fournisseurs d’API sont indisponibles, limités en débit ou temporairement défaillants. Cette approche est volontairement prudente :- Les outils OpenClaw ne sont pas injectés directement, mais les backends avec
bundleMcp: truepeuvent recevoir des outils Gateway via un pont MCP en local loopback. - Streaming JSONL pour les CLI qui le prennent en charge.
- Les sessions sont prises en charge (pour que les tours de suivi restent cohérents).
- Les images peuvent être transmises si le CLI accepte des chemins d’image.
Démarrage rapide pour débutants
Vous pouvez utiliser Codex CLI sans aucune configuration (le Plugin OpenAI intégré enregistre un backend par défaut) :PATH est minimal, ajoutez simplement le
chemin de commande :
agents.defaults.cliBackends.
Utilisation comme solution de repli
Ajoutez un backend CLI à votre liste de repli afin qu’il ne s’exécute que lorsque les modèles principaux échouent :- Si vous utilisez
agents.defaults.models(liste d’autorisation), vous devez aussi y inclure vos modèles de backend CLI. - Si le fournisseur principal échoue (authentification, limites de débit, délais d’expiration), OpenClaw essaiera ensuite le backend CLI.
Vue d’ensemble de la configuration
Tous les backends CLI se trouvent sous :codex-cli, my-cli).
L’id du fournisseur devient la partie gauche de votre référence de modèle :
Exemple de configuration
Fonctionnement
- Sélectionne un backend en fonction du préfixe du fournisseur (
codex-cli/...). - Construit un prompt système à l’aide du même prompt OpenClaw + contexte d’espace de travail.
- Exécute le CLI avec un id de session (si pris en charge) afin que l’historique reste cohérent.
- Analyse la sortie (JSON ou texte brut) et renvoie le texte final.
- Persiste les ids de session par backend, afin que les suivis réutilisent la même session CLI.
Le backend intégré Anthropic
claude-cli est de nouveau pris en charge. Le personnel d’Anthropic
nous a indiqué que l’utilisation de Claude CLI dans le style OpenClaw est de nouveau autorisée, donc OpenClaw considère
l’utilisation de claude -p comme approuvée pour cette intégration, sauf si Anthropic publie
une nouvelle politique.codex-cli transmet le prompt système d’OpenClaw via
la surcharge de configuration model_instructions_file de Codex (-c model_instructions_file="..."). Codex n’expose pas de drapeau de style Claude
--append-system-prompt, donc OpenClaw écrit le prompt assemblé dans un
fichier temporaire pour chaque nouvelle session Codex CLI.
Le backend intégré Anthropic claude-cli reçoit l’instantané des Skills OpenClaw
de deux façons : le catalogue compact de Skills OpenClaw dans le prompt système ajouté, et
un Plugin Claude Code temporaire transmis avec --plugin-dir. Le Plugin ne contient
que les Skills éligibles pour cet agent/cette session, afin que le résolveur de Skills natif de Claude Code
voie le même ensemble filtré que celui qu’OpenClaw annoncerait autrement dans
le prompt. Les surcharges de variables d’environnement/de clé API des Skills sont toujours appliquées par OpenClaw à l’environnement
du processus enfant pendant l’exécution.
Sessions
- Si le CLI prend en charge les sessions, définissez
sessionArg(par ex.--session-id) ousessionArgs(espace réservé{sessionId}) lorsque l’id doit être inséré dans plusieurs drapeaux. - Si le CLI utilise une sous-commande de reprise avec des drapeaux différents, définissez
resumeArgs(remplaceargslors de la reprise) et éventuellementresumeOutput(pour les reprises non JSON). sessionMode:always: toujours envoyer un id de session (nouvel UUID si aucun n’est stocké).existing: envoyer un id de session uniquement si un id a déjà été stocké.none: ne jamais envoyer d’id de session.
serialize: trueconserve l’ordre des exécutions sur la même voie.- La plupart des CLI sérialisent sur une voie de fournisseur.
- OpenClaw abandonne la réutilisation de session CLI stockée lorsque l’état d’authentification du backend change, y compris lors d’une reconnexion, d’une rotation de jeton ou d’un changement d’identifiant de profil d’authentification.
Images (transmission directe)
Si votre CLI accepte des chemins d’image, définissezimageArg :
imageArg est défini, ces
chemins sont transmis comme arguments du CLI. Si imageArg est absent, OpenClaw ajoute les
chemins de fichiers au prompt (injection de chemin), ce qui suffit pour les CLI qui chargent automatiquement
les fichiers locaux à partir de simples chemins.
Entrées / sorties
output: "json"(par défaut) essaie d’analyser le JSON et d’en extraire le texte + l’id de session.- Pour la sortie JSON de Gemini CLI, OpenClaw lit le texte de réponse depuis
responseet l’usage depuisstatslorsqueusageest absent ou vide. output: "jsonl"analyse les flux JSONL (par exemple Codex CLI--json) et extrait le message final de l’agent ainsi que les identifiants de session lorsqu’ils sont présents.output: "text"traite stdout comme la réponse finale.
input: "arg"(par défaut) transmet le prompt comme dernier argument du CLI.input: "stdin"envoie le prompt via stdin.- Si le prompt est très long et que
maxPromptArgCharsest défini, stdin est utilisé.
Valeurs par défaut (possédées par le Plugin)
Le Plugin OpenAI intégré enregistre également une valeur par défaut pourcodex-cli :
command: "codex"args: ["exec","--json","--color","never","--sandbox","workspace-write","--skip-git-repo-check"]resumeArgs: ["exec","resume","{sessionId}","-c","sandbox_mode=\"workspace-write\"","--skip-git-repo-check"]output: "jsonl"resumeOutput: "text"modelArg: "--model"imageArg: "--image"sessionMode: "existing"
google-gemini-cli :
command: "gemini"args: ["--output-format", "json", "--prompt", "{prompt}"]resumeArgs: ["--resume", "{sessionId}", "--output-format", "json", "--prompt", "{prompt}"]imageArg: "@"imagePathScope: "workspace"modelArg: "--model"sessionMode: "existing"sessionIdFields: ["session_id", "sessionId"]
gemini dans PATH (brew install gemini-cli ou
npm install -g @google/gemini-cli).
Remarques sur le JSON de Gemini CLI :
- Le texte de réponse est lu depuis le champ JSON
response. - L’usage revient à
statslorsqueusageest absent ou vide. stats.cachedest normalisé encacheReadOpenClaw.- Si
stats.inputest absent, OpenClaw dérive les jetons d’entrée à partir destats.input_tokens - stats.cached.
command absolu).
Valeurs par défaut possédées par le Plugin
Les valeurs par défaut des backends CLI font désormais partie de la surface du Plugin :- Les Plugins les enregistrent avec
api.registerCliBackend(...). - Le
iddu backend devient le préfixe du fournisseur dans les références de modèle. - La configuration utilisateur dans
agents.defaults.cliBackends.<id>surcharge toujours la valeur par défaut du Plugin. - Le nettoyage de configuration spécifique au backend reste possédé par le Plugin via le hook optionnel
normalizeConfig.
input réécrit le prompt système et le prompt utilisateur transmis au CLI. output
réécrit les deltas assistant streamés et le texte final analysé avant qu’OpenClaw ne gère
ses propres marqueurs de contrôle et la livraison au canal.
Pour les CLI qui émettent du JSONL compatible avec le stream-json de Claude Code, définissez
jsonlDialect: "claude-stream-json" dans la configuration de ce backend.
Overlays bundle MCP
Les backends CLI ne reçoivent pas directement les appels d’outils OpenClaw, mais un backend peut choisir d’utiliser un overlay de configuration MCP généré avecbundleMcp: true.
Comportement intégré actuel :
claude-cli: fichier de configuration MCP strict générécodex-cli: surcharges de configuration en ligne pourmcp_serversgoogle-gemini-cli: fichier de paramètres système Gemini généré
- lance un serveur MCP HTTP en local loopback qui expose les outils Gateway au processus CLI
- authentifie le pont avec un jeton par session (
OPENCLAW_MCP_TOKEN) - limite l’accès aux outils à la session, au compte et au contexte de canal actuels
- charge les serveurs bundle-MCP activés pour l’espace de travail actuel
- les fusionne avec toute forme existante de configuration/paramètres MCP du backend
- réécrit la configuration de lancement en utilisant le mode d’intégration possédé par le backend depuis l’extension propriétaire
Limites
- Pas d’appels directs aux outils OpenClaw. OpenClaw n’injecte pas d’appels d’outils dans
le protocole du backend CLI. Les backends ne voient les outils Gateway que lorsqu’ils choisissent
d’utiliser
bundleMcp: true. - Le streaming est spécifique au backend. Certains backends diffusent du JSONL en flux ; d’autres mettent en tampon jusqu’à la fin.
- Les sorties structurées dépendent du format JSON du CLI.
- Les sessions Codex CLI reprennent via une sortie texte (sans JSONL), ce qui est moins
structuré que l’exécution initiale
--json. Les sessions OpenClaw continuent de fonctionner normalement.
Dépannage
- CLI introuvable : définissez
commandsur un chemin complet. - Nom de modèle incorrect : utilisez
modelAliasespour mapperprovider/model→ modèle CLI. - Pas de continuité de session : assurez-vous que
sessionArgest défini et quesessionModen’est pasnone(Codex CLI ne peut actuellement pas reprendre avec une sortie JSON). - Images ignorées : définissez
imageArg(et vérifiez que le CLI prend en charge les chemins de fichiers).