Concepts and configuration

CLI des modèles

Les références de modèle choisissent un fournisseur et un modèle. Elles ne choisissent généralement pas l’environnement d’exécution d’agent de bas niveau. Par exemple, openai/gpt-5.5 peut s’exécuter via le chemin normal du fournisseur OpenAI ou via l’environnement d’exécution app-server Codex, selon agents.defaults.agentRuntime.id. En mode d’exécution Codex, la référence openai/gpt-* n’implique pas une facturation par clé d’API ; l’authentification peut provenir d’un compte Codex ou du profil d’authentification openai-codex. Voir Environnements d’exécution d’agents.

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 secours

    agents.defaults.model.fallbacks (dans l’ordre).

  • Basculement de l’authentification du fournisseur

    Le basculement de l’authentification se produit dans un fournisseur avant de passer au modèle suivant.

  • Surfaces de modèle associées
    • agents.defaults.models est la liste d’autorisation/le catalogue des modèles qu’OpenClaw peut utiliser (ainsi que les alias).
    • agents.defaults.imageModel est utilisé uniquement lorsque le modèle principal ne peut pas accepter d’images.
    • agents.defaults.pdfModel est utilisé par l’outil pdf. S’il est omis, l’outil se rabat sur agents.defaults.imageModel, puis sur le modèle de session/par défaut résolu.
    • agents.defaults.imageGenerationModel est utilisé par la capacité partagée de génération d’images. S’il est omis, image_generate peut toujours déduire une valeur par défaut de fournisseur avec 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 ID de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé d’API de ce fournisseur.
    • agents.defaults.musicGenerationModel est utilisé par la capacité partagée de génération de musique. S’il est omis, music_generate peut toujours déduire une valeur par défaut de fournisseur avec 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 ID de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé d’API de ce fournisseur.
    • agents.defaults.videoGenerationModel est utilisé par la capacité partagée de génération de vidéos. S’il est omis, video_generate peut toujours déduire une valeur par défaut de fournisseur avec 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 ID de fournisseur. Si vous définissez un fournisseur/modèle spécifique, configurez aussi l’authentification/la clé d’API de ce fournisseur.
    • Les valeurs par défaut par agent peuvent remplacer agents.defaults.model via agents.list[].model plus les liaisons (voir Routage multi-agent).

    Source de sélection et comportement de secours

    Le même provider/model peut signifier différentes choses selon son origine :

    • Les valeurs par défaut configurées (agents.defaults.model.primary et les modèles principaux propres aux agents) sont le point de départ normal et utilisent agents.defaults.model.fallbacks.
    • Les sélections de secours 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 secours sans tester d’abord un modèle principal connu comme défaillant.
    • Les sélections de session utilisateur sont exactes. /model, le sélecteur de modèle, session_status(model=...) et sessions.patch stockent modelOverrideSource: "user" ; si ce fournisseur/modèle sélectionné est inaccessible, OpenClaw échoue de manière visible au lieu de basculer vers un autre modèle configuré.
    • Cron --model / charge utile model est un modèle principal par tâche. Il utilise toujours les solutions de secours configurées, sauf si la tâche fournit explicitement des fallbacks dans la charge utile (utilisez fallbacks: [] pour une exécution cron stricte).
    • Les sélecteurs CLI de modèle par défaut et de liste d’autorisation respectent models.mode: "replace" en listant les models.providers.*.models explicites au lieu de charger tout le catalogue intégré.
    • Le sélecteur de modèle de l’interface de contrôle demande au Gateway sa vue de modèle configurée : agents.defaults.models lorsqu’elle est présente, sinon les models.providers.*.models explicites ainsi que les fournisseurs ayant une authentification utilisable. Le catalogue intégré complet est réservé aux vues de navigation explicites telles que models.list avec view: "all" ou openclaw models list --all.

    Politique rapide de modèle

    • 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 des solutions de secours 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/moins puissants.

    Intégration (recommandé)

    Si vous ne voulez pas modifier la configuration à la main, lancez l’intégration :

    openclaw onboard
    

    Elle peut configurer le modèle et l’authentification pour les fournisseurs courants, notamment OpenAI Code (Codex) subscription (OAuth) et Anthropic (clé d’API ou CLI Claude).

    Clés de configuration (aperçu)

    • agents.defaults.model.primary et agents.defaults.model.fallbacks
    • agents.defaults.imageModel.primary et agents.defaults.imageModel.fallbacks
    • agents.defaults.pdfModel.primary et agents.defaults.pdfModel.fallbacks
    • agents.defaults.imageGenerationModel.primary et agents.defaults.imageGenerationModel.fallbacks
    • agents.defaults.videoGenerationModel.primary et agents.defaults.videoGenerationModel.fallbacks
    • agents.defaults.models (liste d’autorisation + alias + paramètres de fournisseur)
    • models.providers (fournisseurs personnalisés écrits dans models.json)

    Modifications sûres de la 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 --merge
    
    Rè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, afin que l’ajout de Codex, Ollama ou d’un autre fournisseur ne supprime pas les entrées de modèles non liées. Configure conserve un agents.defaults.model.primary existant 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 n’est 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 --merge
    

    Lorsque la commande rejetée comprenait un remplacement d’environnement d’exécution comme /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 Codex native, le modèle sélectionné reste openai/gpt-5.5 ; l’environnement d’exécution codex sélectionne le harnais et utilise l’authentification Codex séparément.

    Pour les modèles locaux/GGUF, stockez la référence complète préfixée par le fournisseur dans la liste d’autorisation, 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.

    Exemple de configuration de liste d’autorisation :

    {
      agent: {
        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 status
    
    Comportement du sélecteur
    • /model (et /model list) est un sélecteur compact et numéroté (famille de modèles + fournisseurs disponibles).
    • Sur Discord, /model et /models ouvrent un sélecteur interactif avec des menus déroulants de fournisseur et de modèle, ainsi qu’une étape Submit.
    • Sur Telegram, les sélections du sélecteur /models sont limitées à la session ; elles ne modifient pas la valeur par défaut persistante de l’agent dans openclaw.json.
    • /models add est obsolète et renvoie désormais un message d’obsolescence au lieu d’enregistrer des modèles depuis la conversation.
    • /model <#> sélectionne dans ce sélecteur.
    Persistance et changement à chaud
    • /model persiste 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 changement à chaud comme en attente et ne redémarre vers le nouveau modèle qu’à un point de nouvelle tentative propre.
    • Si l’activité d’outil ou la sortie de réponse a déjà commencé, le changement en attente peut rester en file jusqu’à une possibilité de nouvelle tentative ultérieure ou jusqu’au prochain tour utilisateur.
    • Une référence /model sé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 depuis agents.defaults.model.fallbacks. Cela diffère des valeurs par défaut configurées et des modèles principaux des tâches cron, qui peuvent toujours utiliser des chaînes de secours.
    • /model status est la vue détaillée (candidats d’authentification et, lorsqu’ils sont configurés, endpoint de fournisseur baseUrl + mode api).
    Analyse des références
    • Les références de modèle sont analysées en divisant sur le premier /. Utilisez provider/model lorsque 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 :
      1. correspondance d’alias
      2. correspondance unique de fournisseur configuré pour cet ID de modèle exact sans préfixe
      3. 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 rabat plutôt sur le premier fournisseur/modèle configuré afin d’éviter d’exposer une valeur par défaut périmée d’un fournisseur supprimé.

    Comportement/configuration complète des commandes : Commandes slash.

    Commandes CLI

    openclaw models list
    openclaw models status
    openclaw models set <provider/model>
    openclaw models set-image <provider/model>
    
    openclaw models aliases list
    openclaw models aliases add <alias> <provider/model>
    openclaw models aliases remove <alias>
    
    openclaw models fallbacks list
    openclaw models fallbacks add <provider/model>
    openclaw models fallbacks remove <provider/model>
    openclaw models fallbacks clear
    
    openclaw models image-fallbacks list
    openclaw models image-fallbacks add <provider/model>
    openclaw models image-fallbacks remove <provider/model>
    openclaw models image-fallbacks clear
    

    openclaw models (sans sous-commande) est un raccourci pour models status.

    models list

    Affiche par défaut les modèles configurés/dont l’authentification est disponible. Indicateurs utiles :

    --allboolean

    Catalogue complet. Inclut les lignes de catalogue statiques groupées appartenant aux fournisseurs avant la configuration de l’authentification, afin que les vues de découverte seule puissent afficher les modèles indisponibles tant que vous n’avez pas ajouté les identifiants de fournisseur correspondants.

    --localboolean

    Fournisseurs locaux uniquement.

    OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Ii0tcHJvdmlkZXIgPGlk " type="string"> Filtre par identifiant de fournisseur, par exemple moonshot. Les libellés d’affichage des sélecteurs interactifs ne sont pas acceptés.

    --plainboolean

    Un modèle par ligne.

    --jsonboolean

    Sortie lisible par machine.

    models status

    Affiche le modèle principal résolu, les modèles de secours, le modèle d’image et un aperçu de l’authentification des fournisseurs configurés. Affiche également l’état d’expiration OAuth pour les profils trouvés dans le magasin d’authentification (avertit dans les 24 h par défaut). --plain affiche uniquement le modèle principal résolu.

    Comportement d’authentification et de sondage
    • L’état OAuth est toujours affiché (et inclus dans la sortie --json). Si un fournisseur configuré n’a pas d’identifiants, models status affiche une section Authentification manquante.
    • JSON inclut auth.oauth (fenêtre d’avertissement + profils) et auth.providers (authentification effective par fournisseur, y compris les identifiants issus de l’environnement). auth.oauth concerne uniquement la santé des profils du magasin d’authentification ; les fournisseurs uniquement basés sur l’environnement n’y apparaissent pas.
    • Utilisez --check pour l’automatisation (code de sortie 1 en cas d’authentification manquante/expirée, 2 en cas d’expiration prochaine).
    • Utilisez --probe pour les vérifications d’authentification en direct ; les lignes de sondage peuvent provenir de profils d’authentification, d’identifiants d’environnement ou de models.json.
    • Si auth.order.<provider> explicite omet un profil stocké, le sondage signale excluded_by_auth_order au lieu de l’essayer. Si une authentification existe mais qu’aucun modèle sondable ne peut être résolu pour ce fournisseur, le sondage signale status: no_model.

    Exemple (Claude CLI) :

    claude auth login
    openclaw models status
    

    Analyse (modèles gratuits OpenRouter)

    openclaw models scan inspecte le catalogue de modèles gratuits d’OpenRouter et peut facultativement sonder les modèles pour la prise en charge des outils et des images.

    --no-probeboolean

    Ignorer les sondages en direct (métadonnées uniquement).

    "--min-params
    "--max-age-days
    "--provider
    "--max-candidates
    --set-defaultboolean

    Définir agents.defaults.model.primary sur la première sélection.

    --set-imageboolean

    Définir agents.defaults.imageModel.primary sur la première sélection d’image.

    Les résultats d’analyse sont classés par :

    1. Prise en charge des images
    2. Latence des outils
    3. Taille du contexte
    4. Nombre de paramètres

    Entrée :

    • Liste OpenRouter /models (filtre :free)
    • Les sondages en direct nécessitent une clé API OpenRouter issue des profils d’authentification ou de OPENROUTER_API_KEY (voir Variables d’environnement)
    • Filtres facultatifs : --max-age-days, --min-params, --provider, --max-candidates
    • Contrôles de requête/sondage : --timeout, --concurrency

    Lorsque les sondages en direct s’exécutent dans un TTY, vous pouvez sélectionner les modèles de secours de manière interactive. En mode non interactif, passez --yes pour accepter les valeurs par défaut. Les résultats limités aux métadonnées sont informatifs ; --set-default et --set-image nécessitent des sondages 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). 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 identifiants de fournisseur correspondants :

    • Un baseUrl non vide déjà présent dans le models.json de l’agent l’emporte.
    • Une apiKey non vide dans le models.json de 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 apiKey des fournisseurs gérés par SecretRef sont actualisées à partir des marqueurs source (ENV_VAR_NAME pour les refs d’environnement, secretref-managed pour les refs fichier/exec) au lieu de conserver les secrets résolus.
    • Les valeurs d’en-tête des fournisseurs gérés par SecretRef sont actualisées à partir des marqueurs source (secretref-env:ENV_VAR_NAME pour les refs d’environnement, secretref-managed pour les refs fichier/exec).
    • Une apiKey/un baseUrl d’agent vide ou manquant se rabat sur models.providers de la configuration.
    • Les autres champs de fournisseur sont actualisés depuis la configuration et les données de catalogue normalisées.

    Connexe