Concepts and configuration
CLI des modèles
Rotation des profils d’authentification, délais de récupération et interaction avec les solutions de repli.
Vue d’ensemble rapide des fournisseurs et exemples.
OpenClaw, Codex et autres runtimes de boucle d’agent.
Clés de configuration des modèles.
Les références de modèle choisissent un fournisseur et un modèle. Elles ne choisissent généralement pas le runtime d’agent de bas niveau. Les références d’agent OpenAI sont la principale exception : openai/gpt-5.5 s’exécute par défaut via le runtime Codex app-server sur le fournisseur OpenAI officiel. Les références Copilot par abonnement (github-copilot/*) peuvent en outre être activées dans le plugin runtime d’agent GitHub Copilot externe — ce chemin reste explicite (pas de repli auto). Les remplacements explicites de runtime relèvent de la politique fournisseur/modèle, pas de l’agent ou de la session entière. En mode runtime Codex, la référence openai/gpt-* n’implique pas une facturation par clé API ; l’authentification peut provenir d’un compte Codex ou d’un profil OAuth openai. Consultez Runtimes d’agent et runtime d’agent GitHub Copilot.
Fonctionnement de la sélection de modèle
OpenClaw sélectionne les modèles dans cet ordre :
Modèle principal
agents.defaults.model.primary (ou agents.defaults.model).
Solutions de repli
agents.defaults.model.fallbacks (dans l’ordre).
Basculement d’authentification du fournisseur
Le basculement d’authentification se produit à l’intérieur d’un fournisseur avant de passer au modèle suivant.
Surfaces de modèles associées
agents.defaults.modelsest la liste d’autorisation/le catalogue des modèles qu’OpenClaw peut utiliser (plus les alias). Utilisez des entréesprovider/*pour limiter les fournisseurs visibles tout en gardant la découverte des fournisseurs dynamique.agents.defaults.imageModelest utilisé uniquement lorsque le modèle principal ne peut pas accepter d’images.agents.defaults.pdfModelest utilisé par l’outilpdf. S’il est omis, l’outil se replie suragents.defaults.imageModel, puis sur le modèle résolu de session/par défaut.agents.defaults.imageGenerationModelest utilisé par la capacité partagée de génération d’images. S’il est omis,image_generatepeut toujours déduire une valeur par défaut de fournisseur couverte par l’authentification. Il essaie d’abord le fournisseur par défaut actuel, puis les autres fournisseurs de génération d’images enregistrés dans l’ordre des identifiants de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé API de ce fournisseur.agents.defaults.musicGenerationModelest utilisé par la capacité partagée de génération de musique. S’il est omis,music_generatepeut toujours déduire une valeur par défaut de fournisseur couverte par l’authentification. Il essaie d’abord le fournisseur par défaut actuel, puis les autres fournisseurs de génération de musique enregistrés dans l’ordre des identifiants de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé API de ce fournisseur.agents.defaults.videoGenerationModelest utilisé par la capacité partagée de génération de vidéos. S’il est omis,video_generatepeut toujours déduire une valeur par défaut de fournisseur couverte par l’authentification. Il essaie d’abord le fournisseur par défaut actuel, puis les autres fournisseurs de génération de vidéos enregistrés dans l’ordre des identifiants de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé API de ce fournisseur.- Les valeurs par défaut par agent peuvent remplacer
agents.defaults.modelviaagents.list[].modelplus des liaisons (voir Routage multi-agent).
Source de sélection et comportement de repli
Le même provider/model peut signifier différentes choses selon son origine :
- Les valeurs par défaut configurées (
agents.defaults.model.primaryet les modèles principaux propres aux agents) sont le point de départ normal et utilisentagents.defaults.model.fallbacks. - Les sélections de repli automatiques sont un état de récupération temporaire. Elles sont stockées avec
modelOverrideSource: "auto"afin que les tours suivants puissent continuer à utiliser la chaîne de repli sans sonder à chaque fois un modèle principal connu comme défaillant ; OpenClaw sonde périodiquement à nouveau le modèle principal d’origine, efface la sélection automatique lorsqu’il récupère et annonce les transitions de repli/récupération une seule fois par changement d’état. - Les sélections de session utilisateur sont exactes.
/model, le sélecteur de modèle,session_status(model=...)etsessions.patchstockentmodelOverrideSource: "user"; si le fournisseur/modèle sélectionné est inaccessible, OpenClaw échoue de manière visible au lieu de basculer vers un autre modèle configuré. - Modifier
agents.defaults.model.primaryne réécrit pas les sélections de session existantes. Si l’état indiqueThis session is pinned to X; config primary Y will apply to new/unpinned sessions., effacez la sélection de la session actuelle avec/model defaultafin qu’elle hérite à nouveau du modèle principal configuré. - Cron
--model/ charge utilemodelest un modèle principal par tâche. Il utilise toujours les solutions de repli configurées, sauf si la tâche fournit une charge utile explicitefallbacks(utilisezfallbacks: []pour une exécution cron stricte). - Les sélecteurs de modèle par défaut et de liste d’autorisation de la CLI respectent
models.mode: "replace"en listant lesmodels.providers.*.modelsexplicites au lieu de charger le catalogue intégré complet. - Le sélecteur de modèle de l’interface de contrôle demande au Gateway sa vue de modèle configurée :
agents.defaults.modelslorsqu’il est présent, y compris les entréesprovider/*couvrant tout un fournisseur, sinon lesmodels.providers.*.modelsexplicites plus les fournisseurs avec une authentification utilisable. Le catalogue intégré complet est réservé aux vues de navigation explicites telles quemodels.listavecview: "all"ouopenclaw models list --all.
Politique de modèle rapide
- Définissez votre modèle principal sur le modèle de dernière génération le plus puissant auquel vous avez accès.
- Utilisez les solutions de repli pour les tâches sensibles au coût/à la latence et les conversations à moindre enjeu.
- Pour les agents avec outils activés ou les entrées non fiables, évitez les niveaux de modèles plus anciens/plus faibles.
Intégration (recommandée)
Si vous ne voulez pas modifier la configuration à la main, lancez l’intégration :
openclaw onboardElle peut configurer le modèle et l’authentification pour les fournisseurs courants, y compris l’abonnement OpenAI Code (Codex) (OAuth) et Anthropic (clé API ou CLI Claude).
Clés de configuration (aperçu)
agents.defaults.model.primaryetagents.defaults.model.fallbacksagents.defaults.imageModel.primaryetagents.defaults.imageModel.fallbacksagents.defaults.pdfModel.primaryetagents.defaults.pdfModel.fallbacksagents.defaults.imageGenerationModel.primaryetagents.defaults.imageGenerationModel.fallbacksagents.defaults.videoGenerationModel.primaryetagents.defaults.videoGenerationModel.fallbacksagents.defaults.models(liste d’autorisation + alias + paramètres de fournisseur + entrées dynamiques de fournisseurprovider/*)models.providers(fournisseurs personnalisés écrits dansmodels.json)
Modifications sûres de liste d’autorisation
Utilisez des écritures additives lorsque vous mettez à jour agents.defaults.models à la main :
openclaw config set agents.defaults.models '{"openai/gpt-5.4":{}}' --strict-json --mergeRègles de protection contre l’écrasement
openclaw config set protège les cartes de modèles/fournisseurs contre les écrasements accidentels. Une affectation d’objet simple à agents.defaults.models, models.providers ou models.providers.<id>.models est rejetée lorsqu’elle supprimerait des entrées existantes. Utilisez --merge pour les changements additifs ; utilisez --replace uniquement lorsque la valeur fournie doit devenir la valeur cible complète.
La configuration interactive des fournisseurs et openclaw configure --section model fusionnent également les sélections limitées au fournisseur dans la liste d’autorisation existante, de sorte que l’ajout de Codex, Ollama ou d’un autre fournisseur ne supprime pas les entrées de modèles sans rapport. Configure préserve une valeur agents.defaults.model.primary existante lorsque l’authentification du fournisseur est réappliquée. Les commandes explicites de définition par défaut telles que openclaw models auth login --provider <id> --set-default et openclaw models set <model> remplacent toujours agents.defaults.model.primary.
« Le modèle n’est pas autorisé » (et pourquoi les réponses s’arrêtent)
Si agents.defaults.models est défini, il devient la liste d’autorisation pour /model et les remplacements de session. Lorsqu’un utilisateur sélectionne un modèle qui ne figure pas dans cette liste d’autorisation, OpenClaw renvoie :
Model "provider/model" is not allowed. Use /models to list providers, or /models <provider> to list models.Add it with: openclaw config set agents.defaults.models '{"provider/model":{}}' --strict-json --mergeLorsque la commande rejetée incluait un remplacement de runtime tel que /model openai/gpt-5.5 --runtime codex, corrigez d’abord la liste d’autorisation, puis réessayez la même commande /model ... --runtime .... Pour l’exécution native Codex, le modèle sélectionné reste openai/gpt-5.5 ; le runtime codex sélectionne le harnais et utilise l’authentification Codex séparément.
Pour les modèles locaux/GGUF, stockez dans la liste d’autorisation la référence complète préfixée par le fournisseur,
par exemple ollama/gemma4:26b, lmstudio/Gemma4-26b-a4-it-gguf, ou le
fournisseur/modèle exact affiché par openclaw models list --provider <provider>.
Les noms de fichiers locaux seuls ou les noms d’affichage ne suffisent pas lorsque la liste d’autorisation est
active.
Si vous voulez limiter les fournisseurs sans lister manuellement chaque modèle, ajoutez
des entrées provider/* à agents.defaults.models :
{ agents: { defaults: { models: { "openai/*": {}, "vllm/*": {}, }, }, },}Avec cette politique, /model, /models et les sélecteurs de modèle affichent le catalogue
découvert uniquement pour ces fournisseurs. Les nouveaux modèles des fournisseurs sélectionnés peuvent
apparaître sans modifier la liste d’autorisation. Les entrées exactes provider/model peuvent être mélangées
avec des entrées provider/* lorsque vous avez besoin d’un modèle spécifique d’un autre fournisseur.
Exemple de configuration de liste d’autorisation :
{ agents: { defaults: { model: { primary: "anthropic/claude-sonnet-4-6" }, models: { "anthropic/claude-sonnet-4-6": { alias: "Sonnet" }, "anthropic/claude-opus-4-6": { alias: "Opus" }, }, }, },}Changer de modèle dans la conversation (/model)
Vous pouvez changer de modèle pour la session actuelle sans redémarrer :
/model/model list/model 3/model openai/gpt-5.4/model default/model statusComportement du sélecteur
/model(et/model list) est un sélecteur compact, numéroté (famille de modèles + fournisseurs disponibles).- Sur Discord,
/modelet/modelsouvrent un sélecteur interactif avec des menus déroulants de fournisseur et de modèle, plus une étape Envoyer. - Sur Telegram, les sélections du sélecteur
/modelssont limitées à la session ; elles ne modifient pas la valeur par défaut persistante de l’agent dansopenclaw.json. /models addest obsolète et renvoie maintenant un message de dépréciation au lieu d’enregistrer des modèles depuis la conversation./model <#>sélectionne depuis ce sélecteur.
Persistance et basculement en direct
/modelconserve immédiatement la nouvelle sélection de session.- Si l’agent est inactif, la prochaine exécution utilise immédiatement le nouveau modèle.
- Si une exécution est déjà active, OpenClaw marque un basculement en direct comme en attente et ne redémarre sur le nouveau modèle qu’à un point de nouvelle tentative propre.
- Si l’activité des outils ou la sortie de réponse a déjà commencé, le basculement en attente peut rester en file jusqu’à une occasion de nouvelle tentative ultérieure ou jusqu’au prochain tour utilisateur.
/model defaultefface la sélection de session et rétablit le modèle par défaut configuré pour la session.- Une référence
/modelsélectionnée par l’utilisateur est stricte pour cette session : si le fournisseur/modèle sélectionné est inaccessible, la réponse échoue de manière visible au lieu de répondre silencieusement depuisagents.defaults.model.fallbacks. C’est différent des valeurs par défaut configurées et des modèles principaux des tâches cron, qui peuvent toujours utiliser des chaînes de repli. /model statusest la vue détaillée (candidats d’authentification et, lorsqu’il est configuré, point de terminaison fournisseurbaseUrl+ modeapi).
Analyse des références
- Les références de modèle sont analysées en séparant sur le premier
/. Utilisezprovider/modellorsque vous saisissez/model <ref>. - Si l’ID du modèle contient lui-même
/(style OpenRouter), vous devez inclure le préfixe du fournisseur (exemple :/model openrouter/moonshotai/kimi-k2). - Si vous omettez le fournisseur, OpenClaw résout l’entrée dans cet ordre :
- correspondance d’alias
- correspondance unique avec un fournisseur configuré pour cet ID de modèle exact sans préfixe
- repli obsolète vers le fournisseur par défaut configuré — si ce fournisseur n’expose plus le modèle par défaut configuré, OpenClaw se replie plutôt sur le premier fournisseur/modèle configuré afin d’éviter de faire apparaître une valeur par défaut obsolète d’un fournisseur supprimé.
Comportement/configuration complète des commandes : Commandes slash.
Commandes CLI
openclaw models listopenclaw models statusopenclaw models set <provider/model>openclaw models set-image <provider/model> openclaw models aliases listopenclaw models aliases add <alias> <provider/model>openclaw models aliases remove <alias> openclaw models fallbacks listopenclaw models fallbacks add <provider/model>openclaw models fallbacks remove <provider/model>openclaw models fallbacks clear openclaw models image-fallbacks listopenclaw models image-fallbacks add <provider/model>openclaw models image-fallbacks remove <provider/model>openclaw models image-fallbacks clearopenclaw models (sans sous-commande) est un raccourci pour models status.
models list
Affiche par défaut les modèles configurés/disponibles par authentification. Options utiles :
--allbooleanCatalogue complet. Inclut les lignes du catalogue statique intégré appartenant au fournisseur avant la configuration de l’authentification, afin que les vues de découverte seules puissent afficher les modèles indisponibles tant que vous n’avez pas ajouté les identifiants de fournisseur correspondants.
--localbooleanFournisseurs locaux uniquement.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Ii0tcHJvdmlkZXIgPGlk
" type="string">
Filtrer par ID de fournisseur, par exemple moonshot. Les libellés d’affichage des sélecteurs interactifs ne sont pas acceptés.
--plainbooleanUn modèle par ligne.
--jsonbooleanSortie lisible par machine.
models status
Affiche le modèle principal résolu, les replis, le modèle d’image et une vue d’ensemble de l’authentification des fournisseurs configurés. Il expose aussi l’état d’expiration OAuth des profils trouvés dans le magasin d’authentification (avertissement dans les 24 h par défaut). --plain affiche uniquement le modèle principal résolu.
Comportement d’authentification et de sonde
- L’état OAuth est toujours affiché (et inclus dans la sortie
--json). Si un fournisseur configuré n’a pas d’identifiants,models statusaffiche une section Authentification manquante. - JSON inclut
auth.oauth(fenêtre d’avertissement + profils) etauth.providers(authentification effective par fournisseur, y compris les identifiants fournis par l’environnement).auth.oauthconcerne uniquement la santé des profils du magasin d’authentification ; les fournisseurs uniquement basés sur l’environnement n’y apparaissent pas. - Utilisez
--checkpour l’automatisation (sortie1en cas d’authentification manquante/expirée,2en cas d’expiration prochaine). - Utilisez
--probepour les vérifications d’authentification en direct ; les lignes de sonde peuvent provenir de profils d’authentification, d’identifiants d’environnement ou demodels.json. - Si
auth.order.<provider>explicite omet un profil stocké, la sonde signaleexcluded_by_auth_orderau lieu de l’essayer. Si l’authentification existe mais qu’aucun modèle sondable ne peut être résolu pour ce fournisseur, la sonde signalestatus: no_model.
Exemple (CLI Claude) :
claude auth loginopenclaw models statusAnalyse (modèles gratuits OpenRouter)
openclaw models scan inspecte le catalogue de modèles gratuits d’OpenRouter et peut éventuellement sonder les modèles pour la prise en charge des outils et des images.
--no-probebooleanIgnorer les sondes en direct (métadonnées uniquement).
"--min-params"--max-age-days"--provider"--max-candidates--set-defaultbooleanDéfinir agents.defaults.model.primary sur la première sélection.
--set-imagebooleanDéfinir agents.defaults.imageModel.primary sur la première sélection d’image.
Les résultats d’analyse sont classés par :
- Prise en charge des images
- Latence des outils
- Taille du contexte
- Nombre de paramètres
Entrée :
- Liste OpenRouter
/models(filtre:free) - Les sondes en direct nécessitent une clé API OpenRouter depuis les profils d’authentification ou
OPENROUTER_API_KEY(voir Variables d’environnement) - Filtres facultatifs :
--max-age-days,--min-params,--provider,--max-candidates - Contrôles de requête/sonde :
--timeout,--concurrency
Lorsque les sondes en direct s’exécutent dans un TUI, vous pouvez sélectionner les replis de manière interactive. En mode non interactif, passez --yes pour accepter les valeurs par défaut. Les résultats de métadonnées seules sont informatifs ; --set-default et --set-image nécessitent des sondes en direct afin qu’OpenClaw ne configure pas un modèle OpenRouter sans clé inutilisable.
Registre des modèles (models.json)
Les fournisseurs personnalisés dans models.providers sont écrits dans models.json sous le répertoire de l’agent (par défaut ~/.openclaw/agents/<agentId>/agent/models.json). Les catalogues des Plugin de fournisseur sont stockés comme fragments de catalogue générés appartenant au Plugin sous l’état Plugin de l’agent et chargés automatiquement. Ce fichier est fusionné par défaut sauf si models.mode est défini sur replace.
Priorité du mode fusion
Priorité du mode fusion pour les ID de fournisseurs correspondants :
- Un
baseUrlnon vide déjà présent dans lemodels.jsonde l’agent l’emporte. - Un
apiKeynon vide dans lemodels.jsonde l’agent l’emporte uniquement lorsque ce fournisseur n’est pas géré par SecretRef dans le contexte actuel de configuration/profil d’authentification. - Les valeurs
apiKeydu fournisseur géré par SecretRef sont actualisées depuis les marqueurs source (ENV_VAR_NAMEpour les références d’environnement,secretref-managedpour les références de fichier/exec) au lieu de conserver les secrets résolus. - Les valeurs d’en-tête du fournisseur géré par SecretRef sont actualisées depuis les marqueurs source (
secretref-env:ENV_VAR_NAMEpour les références d’environnement,secretref-managedpour les références de fichier/exec). - Les
apiKey/baseUrlvides ou manquants de l’agent se replient surmodels.providersde la configuration. - Les autres champs de fournisseur sont actualisés depuis la configuration et les données de catalogue normalisées.
Connexe
- Runtimes d’agent — OpenClaw, Codex et autres runtimes de boucle d’agent
- Référence de configuration — clés de configuration de modèle
- Génération d’images — configuration du modèle d’image
- Basculement de modèle — chaînes de repli
- Fournisseurs de modèles — routage des fournisseurs et authentification
- Génération de musique — configuration du modèle de musique
- Génération de vidéos — configuration du modèle vidéo