ez-cronjob
Fix common cron job failures in Clawdbot/Moltbot - message delivery issues, tool timeouts, timezone bugs, and model fallback problems.
Best use case
ez-cronjob is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Fix common cron job failures in Clawdbot/Moltbot - message delivery issues, tool timeouts, timezone bugs, and model fallback problems.
Teams using ez-cronjob should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/ez-cronjob/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How ez-cronjob Compares
| Feature / Agent | ez-cronjob | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Fix common cron job failures in Clawdbot/Moltbot - message delivery issues, tool timeouts, timezone bugs, and model fallback problems.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# 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.*
Related Skills
portfolio-watcher
Monitor stock/crypto holdings, get price alerts, track portfolio performance
portainer
Control Docker containers and stacks via Portainer API. List containers, start/stop/restart, view logs, and redeploy stacks from git.
portable-tools
Build cross-device tools without hardcoding paths or account names
polymarket
Trade prediction markets on Polymarket. Analyze odds, place bets, track positions, automate alerts, and maximize returns from event outcomes. Covers sports, politics, entertainment, and more.
polymarket-traiding-bot
No description provided.
polymarket-analysis
Analyze Polymarket prediction markets for trading edges. Pair Cost arbitrage, whale tracking, sentiment analysis, momentum signals, user profile tracking. No execution.
polymarket-agent
Autonomous prediction market agent - analyzes markets, researches news, and identifies trading opportunities
polymarket-5
Query Polymarket prediction markets. Use for questions about prediction markets, betting odds, market prices, event probabilities, or when user asks about Polymarket data.
polymarket-4
Query Polymarket prediction markets. Use for questions about prediction markets, betting odds, market prices, event probabilities, or when user asks about Polymarket data.
polymarket-3
Query Polymarket prediction market odds and events via CLI. Search for markets, get current prices, list events by category. Supports sports betting (NFL, NBA, soccer/EPL, Champions League), politics, crypto, elections, geopolitics. Real money markets = more accurate than polls. No API key required. Use when asked about odds, probabilities, predictions, or "what are the chances of X".
polymarket-2
Query Polymarket prediction markets - check odds, trending markets, search events, track prices.
pollinations
Pollinations.ai API for AI generation - text, images, videos, audio, and analysis. Use when user requests AI-powered generation (text completion, images, videos, audio, vision/analysis, transcription) or mentions Pollinations. Supports 25+ models (OpenAI, Claude, Gemini, Flux, Veo, etc.) with OpenAI-compatible chat endpoint and specialized generation endpoints.