Tâches planifiées
Cron est le planificateur intégré de la Gateway. Il persiste les tâches, réveille l’agent au bon moment et peut renvoyer le résultat vers un channel de discussion ou un point de terminaison webhook.
Quick start
Section intitulée « Quick start »Ajouter un rappel ponctuel
Fenêtre de terminal openclaw cron add \--name "Reminder" \--at "2026-02-01T16:00:00Z" \--session main \--system-event "Reminder: check the cron docs draft" \--wake now \--delete-after-runVérifier vos tâches
Fenêtre de terminal openclaw cron listopenclaw cron getopenclaw cron show
Voir l'historique d'exécution
Fenêtre de terminal openclaw cron runs --id
Fonctionnement de cron
Section intitulée « Fonctionnement de cron »- Cron s’exécute au sein du processus du Gateway (et non au sein du modèle).
- Les définitions des tâches sont persistantes dans
~/.openclaw/cron/jobs.json, donc les redémarrages ne font pas perdre les planifications. - L’état d’exécution au moment de l’exécution (runtime) persiste à côté dans
~/.openclaw/cron/jobs-state.json. Si vous suivez les définitions cron dans git, suivezjobs.jsonet mettezjobs-state.jsondans votre .gitignore. - Après la séparation, les anciennes versions de OpenClaw peuvent lire
jobs.jsonmais peuvent traiter les tâches comme nouvelles car les champs d’exécution résident désormais dansjobs-state.json. - Lorsque
jobs.jsonest modifié pendant que le Gateway est en cours d’exécution ou arrêté, OpenClaw compare les champs de planification modifiés avec les métadonnées des créneaux d’exécution en attente et efface les valeursnextRunAtMsobsolètes. Les reformats purs ou les réécritures ne changeant que l’ordre des clés préservent le créneau en attente. - Toutes les exécutions de cron créent des enregistrements de tâche d’arrière-plan.
- Au démarrage du Gateway, les travaux isolés de tour d’agent en retard sont replanifiés en dehors de la fenêtre de connexion au channel au lieu d’être rejoués immédiatement, afin que le démarrage de Discord/Telegram et la configuration des commandes natives restent réactifs après les redémarrages.
- Les travaux ponctuels (
--at) sont supprimés automatiquement après succès par défaut. - Les exécutions cron isolées tentent au mieux de fermer les onglets/processus de navigateur suivis pour leur session
cron:<jobId>lorsque l’exécution est terminée, afin que l’automatisation de navigateur détachée ne laisse pas de processus orphelins derrière elle. - Les exécutions cron isolées qui reçoivent la subvention étroite d’auto-nettoyage cron peuvent toujours lire le statut du planificateur, une liste auto-filtrée de leur travail actuel, et l’historique d’exécution de ce travail, afin que les vérifications de statut/heartbeat puissent inspecter leur propre planification sans obtenir un accès plus large à la mutation cron.
- Les exécutions cron isolées se protègent également contre les réponses d’accusé de réception périmées. Si le premier résultat n’est qu’une mise à jour de statut provisoire (
on it,pulling everything together, et indices similaires) et qu’aucune exécution de sous-agent descendant n’est encore responsable de la réponse finale, OpenClaw redemande une fois le résultat réel avant la livraison. - Les exécutions cron isolées utilisent des métadonnées structurées de refus d’exécution provenant de l’exécution intégrée, y compris les wrappers
UNAVAILABLEde l’hôte de nœud dont le message d’erreur imbriqué commence parSYSTEM_RUN_DENIEDouINVALID_REQUEST, afin qu’une commande bloquée ne soit pas signalée comme une exécution réussie (verte), tandis que le texte ordinaire de l’assistant n’est pas traité comme un refus. - Les exécutions cron isolées traitent également les échecs d’agent au niveau de l’exécution comme des erreurs de travail même lorsqu’aucune charge utile de réponse n’est produite, de sorte que les échecs de model/provider incrémentent les compteurs d’erreurs et déclenchent des notifications d’échec au lieu d’effacer le travail comme réussi.
- Lorsqu’une tâche isolée de type agent-turn atteint
timeoutSeconds, cron annule l’exécution de l’agent sous-jacente et lui accorde une courte fenêtre de nettoyage. Si l’exécution ne se vide pas, le nettoyage appartenant au Gateway force la suppression de la propriété de la session de cette exécution avant que cron n’enregistre l’expiration du délai, afin que le travail de chat en file d’attente ne reste pas bloqué derrière une session de traitement périmée. - Si un agent-turn isolé stalle avant le démarrage du lanceur ou avant le premier appel du model, cron enregistre un délai d’attente spécifique à la phase, tel que
setup timed out before runner startoustalled before first model call (last phase: context-engine). Ces chiens de garde couvrent les fournisseurs intégrés et les fournisseurs pris en charge par la CLI avant que leur processus externe CLI ne soit réellement démarré, et sont plafonnés indépendamment des longues valeurstimeoutSeconds, afin que les échecs de démarrage à froid, d’authentification ou de contexte apparaissent rapidement au lieu d’attendre le budget complet de la tâche.
Types de planification
Section intitulée « Types de planification »| Genre | Indicateur CLI | Description |
|---|---|---|
at | --at | Horodatage ponctuel (ISO 8601 ou relatif comme 20m) |
every | --every | Intervalle fixe |
cron | --cron | Expression cron à 5 ou 6 champs avec --tz optionnel |
Les horodatages sans fuseau horaire sont traités comme UTC. Ajoutez --tz America/New_York pour une planification locale à l’heure murale.
Les expressions récurrentes en haut de l’heure sont automatiquement étalées jusqu’à 5 minutes pour réduire les pics de charge. Utilisez --exact pour forcer une chronologie précise ou --stagger 30s pour une fenêtre explicite.
Le jour du mois et le jour de la semaine utilisent une logique OU
Section intitulée « Le jour du mois et le jour de la semaine utilisent une logique OU »Les expressions cron sont analysées par croner. Lorsque les champs jour-du-mois et jour-de-la-semaine ne sont pas des caractères génériques, croner correspond lorsque l’un ou l’autre des champs correspond — et non les deux. Il s’agit du comportement standard de Vixie cron.
# Intended: "9 AM on the 15th, only if it's a Monday"# Actual: "9 AM on every 15th, AND 9 AM on every Monday"0 9 15 * 1Cela se déclenche environ 5 à 6 fois par mois au lieu de 0 à 1 fois par mois. OpenClaw utilise ici le comportement OU par défaut de Croner. Pour exiger les deux conditions, utilisez le modificateur de jour-de-la-semaine + de Croner (0 9 15 * +1) ou planifiez sur un champ et protégez l’autre dans l’invite ou la commande de votre tâche.
Styles d’exécution
Section intitulée « Styles d’exécution »| Style | valeur --session | S’exécute dans | Idéal pour |
|---|---|---|---|
| Session principale | main | Voie de réveil cron dédiée | Rappels, événements système |
| Isolé | isolated | cron:<jobId> dédié | Rapports, tâches d’arrière-plan |
| Session actuelle | current | Lié au moment de la création | Travail récurrent sensible au contexte |
| Session personnalisée | session:custom-id | Session nommée persistante | Workflows qui s’appuient sur l’historique |
Session principale vs isolée vs personnalisée
Les tâches de session principale mettent en file d’attente un événement système dans une voie d’exécution détenue par cron et réveillent éventuellement le heartbeat (--wake now ou --wake next-heartbeat). Elles peuvent utiliser le dernier contexte de livraison de la session principale cible pour les réponses, mais elles n’ajoutent pas de tours cron de routine à la voie de discussion humaine et n’étendent pas la fraîcheur de réinitialisation quotidiale/inactive pour la session cible. Les tâches isolées exécutent un tour d’agent dédié avec une session fraîche. Les sessions personnalisées (session:xxx) conservent le contexte entre les exécutions, permettant des flux de travail tels que des stand-ups quotidiens qui s’appuient sur des résumés précédents.
Ce que signifie « nouvelle session » pour les tâches isolées
Pour les tâches isolées, « nouvelle session » signifie un nouvel identifiant de transcription/session pour chaque exécution. OpenClaw peut conserver des préférences sécurisées telles que les paramètres de réflexion/rapide/verbeux, les étiquettes et les remplacements explicites de modèle/d’authentification sélectionnés par l’utilisateur, mais il n’hérite pas du contexte de conversation ambiant d’une ligne cron plus ancienne : le routage channel/groupe, la stratégie d’envoi ou de file d’attente, l’élévation, l’origine ou la liaison d’exécution ACP. Utilisez current ou `session:
` lorsqu’une tâche récurrente doit délibérément s’appuyer sur le même contexte de conversation.
Nettoyage de l'exécution
Pour les tâches isolées, le démontage de l’exécution inclut désormais un nettoyage au mieux du navigateur pour cette session cron. Les échecs de nettoyage sont ignorés pour que le résultat cron réel l’emporte tout de même.
Les exécutions cron isolées suppriment également toutes les instances d’exécution MCP regroupées créées pour la tâche via le chemin de nettoyage de l’exécution partagé. Cela correspond à la manière dont les clients MCP de session principale et de session personnalisée sont démontés, afin que les tâches cron isolées ne fuient pas les processus enfants stdio ou les connexions MCP de longue durée entre les exécutions.
Livraison par sous-agent et Discord
Lorsque les exécutions cron isolées orchestrent des sous-agents, la livraison privilégie également la sortie finale du descendant par rapport au texte parent intermédiaire obsolète. Si les descendants sont toujours en cours d’exécution, OpenClaw supprime cette mise à jour parente partielle au lieu de l’annoncer.
Pour les cibles d’annonce Discord texte uniquement, OpenClaw envoie le texte final canonique de l’assistant une seule fois au lieu de relire à la fois les charges utiles de texte diffusées/intermédiaires et la réponse finale. Les médias et les charges utiles Discord structurées sont toujours livrés comme des charges utiles distinctes pour que les pièces jointes et les composants ne soient pas perdus.
Options de charge utile pour les tâches isolées
Section intitulée « Options de charge utile pour les tâches isolées »--model utilise le modèle autorisé sélectionné comme modèle principal de cette tâche. Ce n’est pas la même chose qu’un remplacement /model de session de chat : les chaînes de repli configurées s’appliquent toujours lorsque le modèle principal de la tâche échoue. Si le modèle demandé 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 revenir silencieusement au modèle agent/défaut de la tâche.
Les tâches cron peuvent également contenir une liste fallbacks au niveau du payload. Lorsqu’elle est présente, cette liste remplace la chaîne de repli configurée pour la tâche. Utilisez fallbacks: [] dans le payload de la tâche/API lorsque vous souhaitez une exécution cron stricte qui n’essaie que le modèle sélectionné. Si une tâche a --model mais ni payload ni replis configurés, OpenClaw transmet une substitution de repli vide explicite pour que le principal de l’agent ne soit pas ajouté comme cible de réessaie cachée supplémentaire.
La priorité de sélection du modèle pour les tâches isolées est :
- Remplacement du modèle par le hook Gmail (lorsque l’exécution provient de Gmail et que ce remplacement est autorisé)
- Payload
modelpar tâche - Remplacement du modèle de session cron stocké sélectionné par l’utilisateur
- Sélection du modèle agent/défaut
Le mode rapide suit également la sélection dynamique résolue. Si la configuration du modèle sélectionné possède params.fastMode, le cron isolé l’utilise par défaut. Une substitution de session fastMode stockée l’emporte toujours sur la configuration dans les deux sens.
Si une exécution isolée rencontre une transition en direct du modèle, cron réessaie avec le provider/model commuté et persiste cette sélection en direct pour l’exécution active avant de réessayer. Lorsque la transition emporte également un nouveau profil d’authentification, cron persiste également ce remplacement de profil d’authentification pour l’exécution active. Les tentatives sont limitées : après la tentative initiale plus 2 nouvelles tentatives de transition, cron abandonne au lieu de boucler indéfiniment.
Avant qu’une exécution cron isolée n’entre dans le runner de l’agent, OpenClaw vérifie les points de terminaison du fournisseur local accessibles pour les fournisseurs configurés api: "ollama" et api: "openai-completions" dont le baseUrl est bouclage (loopback), réseau privé, ou .local. Si ce point de terminaison est en panne, l’exécution est enregistrée comme skipped avec une erreur claire de fournisseur/modèle au lieu de lancer un appel de modèle. Le résultat du point de terminaison est mis en cache pendant 5 minutes, de sorte que de nombreuses tâches en attente utilisant le même serveur local Ollama, vLLM, SGLang ou LM Studio mort partagent une petite sonde unique au lieu de créer une tempête de requêtes. Les exécutions avec prévol de fournisseur ignoré n’incrémentent pas le délai d’attente pour erreur d’exécution ; activez failureAlert.includeSkipped lorsque vous souhaitez des notifications d’ignorage répétées.
Livraison et sortie
Section intitulée « Livraison et sortie »| Mode | Ce qu’il se passe |
|---|---|
announce | Livraison de secours du texte final vers la cible si l’agent n’a pas envoyé |
webhook | POST de la charge utile de l’événement terminé vers une URL |
none | Pas de livraison de secours du lanceur |
Utilisez --announce --channel telegram --to "-1001234567890" pour la livraison sur le channel. Pour les sujets de forum Telegram, utilisez -1001234567890:topic:123 ; les appelants directs RPC/config peuvent également passer delivery.threadId sous forme de chaîne ou de nombre. Les cibles Slack/Discord/Mattermost doivent utiliser des préfixes explicites (channel:<id>, user:<id>). Les ID de salle Matrix sont sensibles à la casse ; utilisez l’ID de salle exact ou le formulaire room:!room:server provenant de Matrix.
Lorsque la livraison par annonce utilise channel: "last" ou omet channel, une cible avec préfixe provider telle que telegram:123 peut sélectionner le channel avant que cron ne se rabatte sur l’historique de session ou sur un channel configuré unique. Seuls les préfixes annoncés par le plugin chargé sont des sélecteurs de provider. Si delivery.channel est explicite, le préfixe de la cible doit nommer le même provider ; par exemple, channel: "whatsapp" avec to: "telegram:123" est rejeté au lieu de laisser WhatsApp interpréter l’ID Telegram comme un numéro de téléphone. Les préfixes de type de cible et de service tels que channel:<id>, user:<id>, imessage:<handle> et sms:<number> restent une syntaxe de cible appartenant au channel, et non des sélecteurs de provider.
Pour les jobs isolés, la livraison par chat est partagée. Si une route de chat est disponible, l’agent peut utiliser l’tool message même lorsque le job utilise --no-deliver. Si l’agent envoie à la cible configurée/actuelle, OpenClaw ignore l’annonce de repli. Sinon, announce, webhook et none contrôlent uniquement ce que le runner fait avec la réponse finale après le tour de l’agent.
Lorsqu’un agent crée un rappel isolé à partir d’un chat actif, OpenClaw stocke la cible de livraison en direct préservée pour la route d’annonce de secours. Les clés de session internes peuvent être en minuscules ; les cibles de livraison du fournisseur ne sont pas reconstruites à partir de ces clés lorsque le contexte de chat actuel est disponible.
La diffusion implicite utilise les listes d’autorisation de canaux configurées pour valider et réacheminer les cibles obsolètes. Les approbations du magasin d’appariement DM ne sont pas des destinataires de secours pour l’automatisation ; définissez delivery.to ou configurez l’entrée de allowFrom du canal lorsqu’une tâche planifiée doit envoyer proactivement un message à un DM.
Les notifications d’échec suivent un chemin de destination distinct :
cron.failureDestinationdéfinit une valeur par défaut globale pour les notifications d’échec.job.delivery.failureDestinationremplace cette valeur pour chaque tâche.- Si aucun des deux n’est défini et que la tâche diffuse déjà via
announce, les notifications d’éch reviennent désormais à cette cible de diffusion principale. delivery.failureDestinationn’est pris en charge que sur les tâchessessionTarget="isolated", sauf si le mode de diffusion principal estwebhook.failureAlert.includeSkipped: trueactive pour une tâche ou une stratégie d’alerte cron globale les alertes répétées pour les exécutions ignorées. Les exécutions ignorées conservent un compteur consécutif distinct, elles n’affectent donc pas l’attente en cas d’erreur d’exécution.
Exemples CLI
Section intitulée « Exemples CLI »bash openclaw cron add \ --name "Calendar check" \ --at "20m" \ --session main \ --system-event "Next heartbeat: check calendar." \ --wake now
bash openclaw cron add \ --name "Morning brief" \ --cron "0 7 * * *" \ --tz "America/Los_Angeles" \ --session isolated \ --message "Summarize overnight updates." \ --announce \ --channel slack \ --to "channel:C1234567890"
bash openclaw cron add \ --name "Deep analysis" \ --cron "0 6 * * 1" \ --tz "America/Los_Angeles" \ --session isolated \ --message "Weekly deep analysis of project progress." \ --model "opus" \ --thinking high \ --announce
Webhooks
Section intitulée « Webhooks »Gateway peut exposer des points de terminaison de webhook HTTP pour des déclencheurs externes. Activer dans la configuration :
{ hooks: { enabled: true, token: "shared-secret", path: "/hooks", },}Authentification
Section intitulée « Authentification »Chaque requête doit inclure le jeton du hook via l’en-tête :
Authorization: Bearer <token>(recommandé)x-openclaw-token: <token>
Les jetons de chaîne de requête sont rejetés.
POST /hooks/wake
Mettre en file d’attente un événement système pour la session principale :
curl -X POST http://127.0.0.1:18789/hooks/wake \ -H 'Authorization: Bearer SECRET' \ -H 'Content-Type: application/json' \ -d '{"text":"New email received","mode":"now"}'Description de l’événement.
now ou next-heartbeat.
POST /hooks/agent
Exécuter un tour d’agent isolé :
curl -X POST http://127.0.0.1:18789/hooks/agent \ -H 'Authorization: Bearer SECRET' \ -H 'Content-Type: application/json' \ -d '{"message":"Summarize inbox","name":"Email","model":"openai/gpt-5.4"}'Champs : message (requis), name, agentId, wakeMode, deliver, channel, to, model, fallbacks, thinking, timeoutSeconds.
Crochets mappés (POST /hooks/<name>)
Les noms de crochets personnalisés sont résolus via hooks.mappings dans la configuration. Les mappages peuvent transformer des charges utiles arbitraires en actions wake ou agent avec des modèles ou des transformations de code.
Intégration Gmail PubSub
Section intitulée « Intégration Gmail PubSub »Connectez les déclencheurs de boîte de réception Gmail à OpenClaw via Google PubSub.
Configuration via Assistant (recommandé)
Section intitulée « Configuration via Assistant (recommandé) »Cela écrit la configuration hooks.gmailTailscale, active le préréglage Gmail et utilise Tailscale Funnel pour le point de terminaison de push.
Démarrage automatique de Gateway
Section intitulée « Démarrage automatique de Gateway »Lorsque hooks.enabled=true et hooks.gmail.accountGateway sont définis, la passerelle démarre gog gmail watch serve au démarrage et renouvelle automatiquement la surveillance. Définissez OPENCLAW_SKIP_GMAIL_WATCHER=1 pour refuser.
Configuration manuelle unique
Section intitulée « Configuration manuelle unique »GCPSélectionner le projet GCP
Sélectionnez le projet GCP qui possède le client OAuth utilisé par
gog:Fenêtre de terminal gcloud auth logingcloud config set projectgcloud services enable gmail.googleapis.com pubsub.googleapis.com
Créer le sujet et accorder l'accès push Gmail
Fenêtre de terminal gcloud pubsub topics create gog-gmail-watchgcloud pubsub topics add-iam-policy-binding gog-gmail-watch \--role=roles/pubsub.publisherDémarrer la surveillance
Fenêtre de terminal gog gmail watch start \--label INBOX \--topic projects//topics/gog-gmail-watch ```
Remplacement du modèle Gmail
Section intitulée « Remplacement du modèle Gmail »{ hooks: { gmail: { model: "openrouter/meta-llama/llama-3.3-70b-instruct:free", thinking: "off", }, },}Gestion des tâches
Section intitulée « Gestion des tâches »# List all jobsopenclaw cron list
# Get one stored job as JSONopenclaw cron get <jobId>
# Show one job, including resolved delivery routeopenclaw cron show <jobId>
# Edit a jobopenclaw cron edit <jobId> --message "Updated prompt" --model "opus"
# Force run a job nowopenclaw cron run <jobId>
# Force run a job now and wait for its terminal statusopenclaw cron run <jobId> --wait --wait-timeout 10m --poll-interval 2s
# Run only if dueopenclaw cron run <jobId> --due
# View run historyopenclaw cron runs --id <jobId> --limit 50
# View one exact runopenclaw cron runs --id <jobId> --run-id <runId>
# Delete a jobopenclaw cron remove <jobId>
# Agent selection (multi-agent setups)openclaw cron add --name "Ops sweep" --cron "0 6 * * *" --session isolated --message "Check ops queue" --agent opsopenclaw cron edit <jobId> --clear-agentopenclaw cron run <jobId> renvoie après avoir mis en file d’attente l’exécution manuelle. Utilisez --wait pour les hooks d’arrêt, les scripts de maintenance ou toute autre automatisation qui doit bloquer jusqu’à ce que l’exécution en file d’attente soit terminée. Le mode d’attente interroge l’élément runId exact renvoyé ; il renvoie 0 pour le statut ok et une valeur non nulle pour error, skipped ou un dépassement du délai d’attente.
Configuration
Section intitulée « Configuration »{ cron: { enabled: true, store: "~/.openclaw/cron/jobs.json", maxConcurrentRuns: 1, retry: { maxAttempts: 3, backoffMs: [60000, 120000, 300000], retryOn: ["rate_limit", "overloaded", "network", "server_error"], }, webhookToken: "replace-with-dedicated-webhook-token", sessionRetention: "24h", runLog: { maxBytes: "2mb", keepLines: 2000 }, },}maxConcurrentRuns limite à la fois la répartition cron planifiée et l’exécution des tours d’agent isolés. Les tours d’agent cron isolés utilisent en interne la voie d’exécution cron-nested dédiée de la file d’attente, donc augmenter cette valeur permet aux exécutions LLM cron indépendantes de progresser en parallèle au lieu de simplement démarrer leurs wrappers cron externes. La voie partagée nested non-cron n’est pas élargie par ce paramètre.
Le sidecar d’état d’exécution est dérivé de cron.store : un magasin .json tel que ~/clawd/cron/jobs.json utilise ~/clawd/cron/jobs-state.json, tandis qu’un chemin de magasin sans suffixe .json ajoute -state.json.
Si vous modifiez jobs.json à la main, laissez jobs-state.jsonOpenClaw hors du contrôle de source. OpenClaw utilise ce fichier annexe pour les emplacements en attente, les marqueurs actifs, les métadonnées de dernière exécution et l’identité de planification qui indique au planificateur lorsqu’une tâche modifiée en externe a besoin d’un nouveau nextRunAtMs.
Désactiver cron : cron.enabled: false ou OPENCLAW_SKIP_CRON=1.
Comportement de nouvelle tentative
Nouvelle tentative unique : les erreurs transitoires (limite de débit, surcharge, réseau, erreur serveur) sont réessayées jusqu’à 3 fois avec un backoff exponentiel. Les erreurs permanentes désactivent immédiatement.
Nouvelle tentative récurrente : backoff exponentiel (30 s à 60 min) entre les tentatives. Le backoff est réinitialisé après la prochaine exécution réussie.
Maintenance
cron.sessionRetention (par défaut 24h) nettoie les entrées de session d’exécution isolées. cron.runLog.maxBytes / cron.runLog.keepLines nettoient automatiquement les fichiers de journal d’exécution.
Dépannage
Section intitulée « Dépannage »Command ladder
Section intitulée « Command ladder »openclaw statusopenclaw gateway statusopenclaw cron statusopenclaw cron listopenclaw cron runs --id <jobId> --limit 20openclaw system heartbeat lastopenclaw logs --followopenclaw doctorCron not firing
- Vérifiez les env var
cron.enabledetOPENCLAW_SKIP_CRONGateway. - Confirmez que la Gateway fonctionne en continu.
- Pour les planifications
cron, vérifiez le fuseau horaire (--tz) par rapport au fuseau horaire de l’hôte. reason: not-duedans la sortie d’exécution signifie qu’une exécution manuelle a été vérifiée avec `openclaw cron run
—due` et que la tâche n’était pas encore attendue.
Cron a été déclenché mais aucune livraison
- Le mode de livraison
nonesignifie qu’aucun envoi de secours par le runner n’est attendu. L’agent peut toujours envoyer directement avec l’outilmessagelorsqu’une route de chat est disponible. - La cible de livraison manquante ou non valide (
channel/to) signifie que l’envoi sortant a été ignoré. - Pour Matrix, les tâches copiées ou héritées avec des ID de salle
delivery.toen minuscules peuvent échouer car les ID de salle Matrix sont sensibles à la casse. Modifiez la tâche avec la valeur exacte!room:serverouroom:!room:serverprovenant de Matrix. - Les erreurs d’authentification de channel (
unauthorized,Forbidden) signifient que la livraison a été bloquée par les informations d’identification. - Si l’exécution isolée ne renvoie que le jeton silencieux (
NO_REPLY/no_reply), OpenClaw supprime la livraison sortante directe et supprime également le chemin de résumé mis en file d’attente de secours, donc rien n’est renvoyé au chat. - Si l’agent doit envoyer un message à l’utilisateur lui-même, vérifiez que la tâche dispose d’une route utilisable (
channel: "last"avec un chat précédent, ou un channel/cible explicite).
Cron ou heartbeat semble empêcher le basculement /new-style
- La fraîcheur de la réinitialisation quotidienne et inactive n’est pas basée sur
updatedAt; voir Session management. - Les réveils Cron, les exécutions de heartbeat, les notifications d’exécution et la tenue de livres de la passerelle peuvent mettre à jour la ligne de session pour le routage/le statut, mais ils ne prolongent pas
sessionStartedAtoulastInteractionAt. - Pour les lignes héritées créées avant l’existence de ces champs, OpenClaw peut récupérer
sessionStartedAtà partir de l’en-tête de session JSONL de la transcription lorsque le fichier est toujours disponible. Les lignes inactives héritées sanslastInteractionAtutilisent cette heure de début récupérée comme leur base de référence inactive.
Pièges de fuseau horaire
- Cron sans
--tzutilise le fuseau horaire de l’hôte de la passerelle. - Les planifications
atsans fuseau horaire sont traitées comme UTC. - Heartbeat
activeHoursutilise la résolution de fuseau horaire configurée.
Connexes
Section intitulée « Connexes »- Automatisation — tous les mécanismes d’automatisation en un coup d’œil
- Tâches d’arrière-plan — registre des tâches pour les exécutions cron
- Heartbeat — tours périodiques de la session principale
- Fuseau horaire — configuration du fuseau horaire