Passer au contenu principal

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.
Exécutez openclaw cron --help pour voir toute la surface de commande. Consultez Tâches Cron pour le guide conceptuel.

Sessions

--session accepte main, isolated, current ou session:<id>.
  • main se lie à la session principale de l’agent.
  • isolated crée une nouvelle transcription et un nouvel identifiant de session pour chaque exécution.
  • current se lie à la session active au moment de la création.
  • session:<id> fixe une clé de session persistante explicite.
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 message lorsqu’une route de discussion est disponible.
  • announce livre en repli la réponse finale uniquement lorsque l’agent n’a pas envoyé directement à la cible résolue.
  • webhook publie la charge utile terminée vers une URL.
  • none dé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 :
  1. delivery.failureDestination sur la tâche.
  2. cron.failureDestination global.
  3. 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.
Remarque : les exécutions Cron isolées traitent les échecs d’agent au niveau de l’exécution comme des erreurs de tâche même lorsqu’aucune charge utile de réponse n’est produite, de sorte que les échecs de modèle/fournisseur incrémentent quand même les compteurs d’erreurs et déclenchent les notifications d’échec. Si une exécution isolée expire avant la première requête au modèle, 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, mais openclaw 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.
Si le modèle n’est pas autorisé ou ne peut pas être résolu, Cron fait échouer l’exécution avec une erreur de validation explicite au lieu de se rabattre sur la sélection de modèle de l’agent de la tâche ou du modèle par défaut.
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 fallbacks remplace 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 --model mais 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 :
  1. Remplacement de hook Gmail.
  2. --model par tâche.
  3. Remplacement de modèle stocké dans la session Cron (lorsque l’utilisateur en a sélectionné un).
  4. 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èle params.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ève LiveSessionModelSwitchError, 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 que SYSTEM_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éfaut 24h) élague les sessions d’exécution isolées terminées.
  • cron.runLog.maxBytes et cron.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 :
openclaw cron edit <job-id> --announce --channel telegram --to "123456789"
Désactiver la livraison pour une tâche isolée :
openclaw cron edit <job-id> --no-deliver
Activer le contexte d’amorçage léger pour une tâche isolée :
openclaw cron edit <job-id> --light-context
Annoncer vers un canal spécifique :
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"
Annoncer vers un sujet de forum Telegram :
openclaw cron edit <job-id> --announce --channel telegram --to "-1001234567890" --thread-id 42
Créer une tâche isolée avec un contexte d’amorçage léger :
openclaw cron add \
  --name "Lightweight morning brief" \
  --cron "0 7 * * *" \
  --session isolated \
  --message "Summarize overnight updates." \
  --light-context \
  --no-deliver
--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
openclaw cron list --agent ops
openclaw cron get <job-id>
openclaw cron show <job-id>
openclaw cron run <job-id>
openclaw cron run <job-id> --due
openclaw cron runs --id <job-id> --limit 50
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 edit <job-id> --agent ops
openclaw cron edit <job-id> --clear-agent
openclaw cron edit <job-id> --session current
openclaw cron edit <job-id> --session "session:daily-brief"
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 :
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"
openclaw cron edit <job-id> --best-effort-deliver
openclaw cron edit <job-id> --no-best-effort-deliver
openclaw cron edit <job-id> --no-deliver

Connexe