Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
openclaw cron
Gérez les tâches Cron pour le planificateur du Gateway.
Sessions
--session accepte main, isolated, current ou session:<id>.
Session keys
Session keys
mainse lie à la session principale de l’agent.isolatedcrée une nouvelle transcription et un nouvel identifiant de session pour chaque exécution.currentse lie à la session active au moment de la création.session:<id>fixe une clé de session persistante explicite.
Isolated session semantics
Isolated session semantics
Les exécutions isolées réinitialisent le contexte de conversation ambiant. Le routage de canal et de groupe, la politique d’envoi/de mise en file, l’élévation, l’origine et la liaison d’exécution ACP sont réinitialisés pour la nouvelle exécution. Les préférences sûres et les remplacements explicites de modèle ou d’authentification sélectionnés par l’utilisateur peuvent être conservés entre les exécutions.
Livraison
openclaw cron list et openclaw cron show <job-id> prévisualisent la route de livraison résolue. Pour channel: "last", l’aperçu indique si la route a été résolue depuis la session principale ou actuelle, ou si elle échouera de manière fermée.
Les cibles préfixées par le fournisseur peuvent lever l’ambiguïté des canaux d’annonce non résolus. Par exemple, to: "telegram:123" sélectionne Telegram lorsque delivery.channel est omis ou vaut last. Seuls les préfixes annoncés par le Plugin chargé sont des sélecteurs de fournisseur. Si delivery.channel est explicite, le préfixe doit correspondre à ce canal ; channel: "whatsapp" avec to: "telegram:123" est rejeté. Les préfixes de service tels que imessage: et sms: restent une syntaxe de cible propre au canal.
Les tâches
cron add isolées utilisent par défaut la livraison --announce. Utilisez --no-deliver pour conserver la sortie en interne. --deliver reste un alias obsolète de --announce.Propriété de la livraison
La livraison de discussion Cron isolée est partagée entre l’agent et l’exécuteur :- L’agent peut envoyer directement avec l’outil
messagelorsqu’une route de discussion est disponible. announcelivre en repli la réponse finale uniquement lorsque l’agent n’a pas envoyé directement à la cible résolue.webhookpublie la charge utile terminée vers une URL.nonedésactive la livraison de repli par l’exécuteur.
--announce est la livraison de repli par l’exécuteur pour la réponse finale. --no-deliver désactive ce repli, mais ne supprime pas l’outil message de l’agent lorsqu’une route de discussion est disponible.
Les rappels créés depuis une discussion active conservent la cible de livraison de discussion en direct pour la livraison d’annonce de repli. Les clés de session internes peuvent être en minuscules ; ne les utilisez pas comme source de vérité pour les identifiants de fournisseur sensibles à la casse, tels que les identifiants de salons Matrix.
Livraison en cas d’échec
Les notifications d’échec sont résolues dans cet ordre :delivery.failureDestinationsur la tâche.cron.failureDestinationglobal.- La cible d’annonce principale de la tâche (lorsqu’aucune destination d’échec explicite n’est définie).
Les tâches de session principale ne peuvent utiliser
delivery.failureDestination que lorsque le mode de livraison principal est webhook. Les tâches isolées l’acceptent dans tous les modes.openclaw cron show et openclaw cron runs incluent une erreur propre à la phase, comme setup timed out before runner start ou stalled before first model call (last phase: context-engine). Pour les fournisseurs adossés à une CLI, le chien de garde pré-modèle reste actif jusqu’au démarrage du tour de CLI externe, de sorte que les blocages de recherche de session, de hook, d’authentification, de prompt et de configuration de CLI sont signalés comme des échecs Cron pré-modèle.
Planification
Tâches ponctuelles
--at <datetime> planifie une exécution ponctuelle. Les dates-heures sans décalage sont traitées comme UTC, sauf si vous passez aussi --tz <iana>, qui interprète l’heure murale dans le fuseau horaire donné.
Les tâches ponctuelles sont supprimées après succès par défaut. Utilisez
--keep-after-run pour les conserver.Tâches récurrentes
Les tâches récurrentes utilisent un délai de nouvelle tentative exponentiel après des erreurs consécutives : 30 s, 1 min, 5 min, 15 min, 60 min. La planification revient à la normale après l’exécution réussie suivante. Les exécutions ignorées sont suivies séparément des erreurs d’exécution. Elles n’affectent pas le délai de nouvelle tentative, maisopenclaw cron edit <job-id> --failure-alert-include-skipped peut inclure les alertes d’échec dans les notifications répétées d’exécutions ignorées.
Pour les tâches isolées qui ciblent un fournisseur de modèle local configuré, Cron exécute une prévalidation légère du fournisseur avant de démarrer le tour de l’agent. Les fournisseurs api: "ollama" en local loopback, réseau privé et .local sont sondés sur /api/tags ; les fournisseurs locaux compatibles OpenAI tels que vLLM, SGLang et LM Studio sont sondés sur /models. Si le point de terminaison est injoignable, l’exécution est enregistrée comme skipped et retentée lors d’une planification ultérieure ; les points de terminaison morts correspondants sont mis en cache pendant 5 minutes afin d’éviter que de nombreuses tâches ne martèlent le même serveur local.
Remarque : les définitions de tâches Cron résident dans jobs.json, tandis que l’état d’exécution en attente réside dans jobs-state.json. Si jobs.json est modifié en externe, le Gateway recharge les planifications modifiées et efface les créneaux en attente obsolètes ; les réécritures qui ne modifient que le formatage n’effacent pas le créneau en attente.
Exécutions manuelles
openclaw cron run retourne dès que l’exécution manuelle est mise en file. Les réponses réussies incluent { ok: true, enqueued: true, runId }. Utilisez openclaw cron runs --id <job-id> pour suivre le résultat final.
openclaw cron run <job-id> force l’exécution par défaut. Utilisez --due pour conserver l’ancien comportement « exécuter seulement si dû ».Modèles
cron add|edit --model <ref> sélectionne un modèle autorisé pour la tâche.
Cron --model est un principal de tâche, pas un remplacement /model de session de discussion. Cela signifie que :
- Les replis de modèle configurés s’appliquent toujours lorsque le modèle de tâche sélectionné échoue.
- La charge utile par tâche
fallbacksremplace la liste de replis configurée lorsqu’elle est présente. - Une liste de replis par tâche vide (
fallbacks: []dans la charge utile/l’API de la tâche) rend l’exécution Cron stricte. - Lorsqu’une tâche a
--modelmais qu’aucune liste de replis n’est configurée, OpenClaw transmet un remplacement de replis vide explicite afin que le modèle principal de l’agent ne soit pas ajouté comme cible de nouvelle tentative cachée.
Priorité du modèle Cron isolé
Cron isolé résout le modèle actif dans cet ordre :- Remplacement de hook Gmail.
--modelpar tâche.- Remplacement de modèle stocké dans la session Cron (lorsque l’utilisateur en a sélectionné un).
- Sélection du modèle de l’agent ou du modèle par défaut.
Mode rapide
Le mode rapide de Cron isolé suit la sélection de modèle en direct résolue. La configuration de modèleparams.fastMode s’applique par défaut, mais un remplacement fastMode stocké en session prime toujours sur la configuration.
Nouvelles tentatives après changement de modèle en direct
Si une exécution isolée lèveLiveSessionModelSwitchError, Cron persiste le fournisseur et le modèle basculés (ainsi que le remplacement de profil d’authentification basculé lorsqu’il est présent) pour l’exécution active avant de réessayer. La boucle externe de nouvelle tentative est limitée à deux nouvelles tentatives de bascule après la tentative initiale, puis abandonne au lieu de boucler indéfiniment.
Sortie d’exécution et refus
Suppression des accusés de réception obsolètes
Les tours Cron isolés suppriment les réponses obsolètes contenant uniquement un accusé de réception. Si le premier résultat n’est qu’une mise à jour de statut intermédiaire et qu’aucune exécution de sous-agent descendant n’est responsable de la réponse finale, Cron relance une fois le prompt pour obtenir le vrai résultat avant la livraison.Suppression du jeton silencieux
Si une exécution Cron isolée ne retourne que le jeton silencieux (NO_REPLY ou no_reply), Cron supprime à la fois la livraison sortante directe et le chemin de résumé en file de repli, de sorte que rien n’est publié dans la discussion.
Refus structurés
Les exécutions Cron isolées privilégient les métadonnées structurées de refus d’exécution provenant de l’exécution intégrée, puis se rabattent sur les marqueurs de refus connus dans la sortie finale, tels queSYSTEM_RUN_DENIED, INVALID_REQUEST et les formulations de refus liées à l’approbation.
cron list et l’historique d’exécution affichent la raison du refus au lieu de signaler une commande bloquée comme ok.
Rétention
La rétention et l’élagage sont contrôlés dans la configuration :cron.sessionRetention(par défaut24h) élague les sessions d’exécution isolées terminées.cron.runLog.maxBytesetcron.runLog.keepLinesélaguent~/.openclaw/cron/runs/<jobId>.jsonl.
Migration d’anciennes tâches
Si vous avez des tâches Cron antérieures au format actuel de livraison et de stockage, exécutez
openclaw doctor --fix. Doctor normalise les champs Cron hérités (jobId, schedule.cron, les champs de livraison de premier niveau, y compris l’ancien threadId, les alias de livraison provider de charge utile) et migre les tâches de repli Webhook simples notify: true vers une livraison Webhook explicite lorsque cron.webhook est configuré.Modifications courantes
Mettre à jour les paramètres de livraison sans modifier le message :--light-context s’applique uniquement aux tâches de tour d’agent isolées. Pour les exécutions Cron, le mode léger garde le contexte d’amorçage vide au lieu d’injecter l’ensemble complet d’amorçage de l’espace de travail.
Commandes d’administration courantes
Exécution manuelle et inspection :openclaw cron list affiche par défaut toutes les tâches correspondantes. Passez --agent <id> pour afficher uniquement les tâches dont l’identifiant d’agent normalisé effectif correspond ; les tâches sans identifiant d’agent stocké comptent comme l’agent par défaut configuré.
openclaw cron get <job-id> retourne directement le JSON de tâche stocké. Utilisez cron show <job-id> lorsque vous voulez la vue lisible par un humain avec aperçu de la route de livraison.
cron list --json et cron show <job-id> --json incluent un champ status de premier niveau sur chaque tâche, calculé à partir de enabled, state.runningAtMs et state.lastRunStatus. Valeurs : disabled, running, ok, error, skipped ou idle. Cela reflète la colonne de statut lisible par un humain, afin que les outils externes puissent lire l’état de la tâche sans le recalculer.
Les entrées cron runs incluent les diagnostics de livraison avec la cible Cron prévue, la cible résolue, les envois par l’outil de message, l’utilisation du repli et l’état livré.
Reciblage de l’agent et de la session :
openclaw cron add avertit lorsque --agent est omis sur les tâches de tour d’agent et se rabat sur l’agent par défaut (main). Passez --agent <id> au moment de la création pour fixer un agent spécifique.
Ajustements de livraison :