home / skills / openclaw / skills / ez-cronjob
This skill helps you diagnose and fix cron job failures in Clawdbot/Moltbot, ensuring reliable delivery, correct timing, and resilient fallback behavior.
npx playbooks add skill openclaw/skills --skill ez-cronjobReview the files below or copy the command above to add this skill to your agents.
---
name: ez-cronjob
description: Fix common cron job failures in Clawdbot/Moltbot - message delivery issues, tool timeouts, timezone bugs, and model fallback problems.
author: Isaac Zarzuri
author-url: https://x.com/Yz7hmpm
version: 1.0.0
homepage: https://www.metacognitivo.com
repository: https://github.com/ProMadGenius/clawdbot-skills
metadata: {"agentskills":{"category":"troubleshooting","tags":["cron","scheduling","telegram","debugging","moltbot","clawdbot"]}}
---
# Cron Job Reliability Guide
A comprehensive guide to diagnosing and fixing cron job issues in Clawdbot/Moltbot. This skill documents common failure patterns and their solutions, learned through production debugging.
## When to Use This Skill
Use this skill when:
- Scheduled messages aren't being delivered
- Cron jobs show "error" status
- Messages arrive at wrong times (timezone issues)
- The agent times out when using the `cron` tool
- Fallback models ignore instructions and call tools unexpectedly
## Quick Reference
### The Golden Rule
**Always use these flags together for reliable delivery:**
```bash
clawdbot cron add \
--name "my-job" \
--cron "0 9 * * 1-5" \
--tz "America/New_York" \
--session isolated \
--message "[INSTRUCTION: DO NOT USE ANY TOOLS] Your prompt here" \
--deliver --channel telegram --to "CHAT_ID" \
--best-effort-deliver
```
### Essential Flags Explained
| Flag | Purpose | Why It Matters |
|------|---------|----------------|
| `--session isolated` | Creates dedicated session | Prevents message loss in busy conversations |
| `--tz "TIMEZONE"` | Sets explicit timezone | Avoids UTC confusion |
| `--deliver` | Sends to channel | Required for Telegram/WhatsApp |
| `--best-effort-deliver` | Don't fail on delivery error | Graceful degradation |
---
## Problem 1: Internal `cron` Tool Deadlock
### Symptoms
- Agent times out (10s) when calling `cron list` or `cron add`
- Error: "Tool execution timed out"
- Gateway logs show 80s+ response times
### Root Cause
The internal `cron` tool creates a deadlock between the agent process and gateway.
### Solution
**Never use the `cron` tool directly.** Use `exec` (or `bash`) instead:
```bash
# CORRECT - uses exec to bypass deadlock
exec: clawdbot cron list
exec: clawdbot cron add --name "reminder" --at "+5m" --message "Hello"
# INCORRECT - causes timeout
cron list # DO NOT USE
cron add ... # DO NOT USE
```
### For Agents
If you're an AI agent reading this: when the user asks you to manage cron jobs, **always use the exec/bash tool** to run `clawdbot cron` commands. Never invoke the `cron` tool directly.
---
## Problem 2: Messages Not Delivered
### Symptoms
- Job shows "ok" status but message never arrives
- Works in testing but fails on schedule
- Intermittent delivery
### Root Cause
Using `--session main` or `--system-event` causes messages to get lost when there's an active conversation in the main session.
### Solution
**Always use `--session isolated`:**
```bash
# CORRECT - isolated session, guaranteed delivery
clawdbot cron add \
--name "daily-standup" \
--cron "0 9 * * 1-5" \
--session isolated \
--deliver --channel telegram --to "-100XXXXXXXXXX"
# INCORRECT - messages can be lost
clawdbot cron add \
--name "daily-standup" \
--session main \
--system-event \
...
```
### Verification
After creating a job, test it:
```bash
# Run the job immediately to verify delivery
clawdbot cron run <job-id>
```
---
## Problem 3: Wrong Execution Time
### Symptoms
- Job runs 4-5 hours early or late
- Schedule shows correct time but execution is off
- Works correctly sometimes, fails other times
### Root Cause
Missing timezone specification defaults to UTC.
### Solution
**Always specify timezone explicitly:**
```bash
# CORRECT - explicit timezone
clawdbot cron add \
--cron "0 9 * * 1-5" \
--tz "America/New_York" \
...
# INCORRECT - defaults to UTC
clawdbot cron add \
--cron "0 9 * * 1-5" \
...
```
### Common Timezone IDs
| Region | Timezone ID |
|--------|-------------|
| US Eastern | `America/New_York` |
| US Pacific | `America/Los_Angeles` |
| UK | `Europe/London` |
| Central Europe | `Europe/Berlin` |
| India | `Asia/Kolkata` |
| Japan | `Asia/Tokyo` |
| Australia Eastern | `Australia/Sydney` |
| Brazil | `America/Sao_Paulo` |
| Bolivia | `America/La_Paz` |
---
## Problem 4: Fallback Models Ignore Instructions
### Symptoms
- Primary model works correctly
- When fallback activates, agent calls tools unexpectedly
- Agent tries to use `exec`, `read`, or other tools when it shouldn't
### Root Cause
Some fallback models (especially smaller/faster ones) don't follow system instructions as strictly as primary models.
### Solution
**Embed instructions directly in the message:**
```bash
# CORRECT - instruction embedded in message
clawdbot cron add \
--message "[INSTRUCTION: DO NOT USE ANY TOOLS. Respond with text only.]
Generate a motivational Monday message for the team."
# INCORRECT - relies only on system prompt
clawdbot cron add \
--message "Generate a motivational Monday message for the team."
```
### Robust Message Template
```text
[INSTRUCTION: DO NOT USE ANY TOOLS. Write your response directly.]
Your actual prompt here. Be specific about what you want.
```
---
## Problem 5: Job Stuck in Error State
### Symptoms
- Job status shows "error"
- Subsequent runs also fail
- No clear error message
### Diagnosis
```bash
# Check job details
clawdbot cron show <job-id>
# Check recent logs
tail -100 /tmp/clawdbot/clawdbot-$(date +%Y-%m-%d).log | grep -i cron
# Check gateway errors
tail -50 ~/.clawdbot/logs/gateway.err.log
```
### Common Causes and Fixes
| Cause | Fix |
|-------|-----|
| Model quota exceeded | Wait for quota reset or switch model |
| Invalid chat ID | Verify channel ID with `--to` |
| Bot removed from group | Re-add bot to Telegram group |
| Gateway not running | `clawdbot gateway restart` |
### Nuclear Option
If nothing works:
```bash
# Remove the problematic job
clawdbot cron rm <job-id>
# Restart gateway
clawdbot gateway restart
# Recreate with correct flags
clawdbot cron add ... (with all recommended flags)
```
---
## Debugging Commands
### View All Jobs
```bash
clawdbot cron list
```
### Inspect Specific Job
```bash
clawdbot cron show <job-id>
```
### Test Job Immediately
```bash
clawdbot cron run <job-id>
```
### Check Logs
```bash
# Today's logs filtered for cron
tail -200 /tmp/clawdbot/clawdbot-$(date +%Y-%m-%d).log | grep -i cron
# Gateway errors
tail -100 ~/.clawdbot/logs/gateway.err.log
# Watch logs in real-time
tail -f /tmp/clawdbot/clawdbot-$(date +%Y-%m-%d).log | grep --line-buffered cron
```
### Restart Gateway
```bash
clawdbot gateway restart
```
---
## Complete Working Examples
### Daily Standup Reminder (9 AM, Mon-Fri)
```bash
clawdbot cron add \
--name "daily-standup-9am" \
--cron "0 9 * * 1-5" \
--tz "America/New_York" \
--session isolated \
--message "[INSTRUCTION: DO NOT USE ANY TOOLS. Write directly.]
Good morning team! Time for our daily standup.
Please share:
1. What did you accomplish yesterday?
2. What are you working on today?
3. Any blockers?
@alice @bob" \
--deliver --channel telegram --to "-100XXXXXXXXXX" \
--best-effort-deliver
```
### One-Shot Reminder (20 minutes from now)
```bash
clawdbot cron add \
--name "quick-reminder" \
--at "+20m" \
--delete-after-run \
--session isolated \
--message "[INSTRUCTION: DO NOT USE ANY TOOLS.]
Reminder: Your meeting starts in 10 minutes!" \
--deliver --channel telegram --to "-100XXXXXXXXXX" \
--best-effort-deliver
```
### Weekly Report (Friday 5 PM)
```bash
clawdbot cron add \
--name "weekly-report-friday" \
--cron "0 17 * * 5" \
--tz "America/New_York" \
--session isolated \
--message "[INSTRUCTION: DO NOT USE ANY TOOLS.]
Happy Friday! Time to wrap up the week.
Please share your weekly highlights and any items carrying over to next week." \
--deliver --channel telegram --to "-100XXXXXXXXXX" \
--best-effort-deliver
```
---
## Checklist for New Cron Jobs
Before creating any cron job, verify:
- [ ] Using `exec: clawdbot cron add` (not the `cron` tool directly)
- [ ] `--session isolated` is set
- [ ] `--tz "YOUR_TIMEZONE"` is explicit
- [ ] `--deliver --channel CHANNEL --to "ID"` for message delivery
- [ ] `--best-effort-deliver` for graceful failures
- [ ] Message starts with `[INSTRUCTION: DO NOT USE ANY TOOLS]`
- [ ] Tested with `clawdbot cron run <id>` after creation
---
## Related Resources
- [Clawdbot Cron Documentation](https://docs.molt.bot/tools/cron)
- [Timezone Database](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones)
- [Cron Expression Generator](https://crontab.guru/)
---
*Skill authored by Isaac Zarzuri. Based on production debugging experience with Clawdbot/Moltbot.*
This skill fixes common cron job failures in Clawdbot/Moltbot: message delivery issues, tool deadlocks/timeouts, timezone mistakes, and fallback model misbehavior. It documents proven remedies, recommended flags, and quick verification steps to make scheduled jobs reliable. Use it to create, test, and recover cron jobs with predictable outcomes.
The skill inspects common failure patterns and prescribes exact command patterns and configuration flags that prevent them. It explains which internal tools to avoid (the `cron` tool), how to run commands via `exec` or `bash`, and how to embed instructions in messages so fallback models behave. It also includes diagnostics and log checks for stuck or error-state jobs.
Why must I not use the internal cron tool?
The internal cron tool can deadlock between the agent process and gateway, causing tool execution timeouts. Using exec or bash runs clawdbot cron externally and avoids that deadlock.
What flags are mandatory for reliable delivery?
Use --session isolated, --tz "Your/Timezone", --deliver plus --channel and --to, and --best-effort-deliver. Also embed a NO-TOOLS instruction at the start of the message.