Schedule Claude Code jobs with a TUI or headless mode. Sometimes systemd is just overkill. Pronounced "Klon" like the guitar pedal.
In all seriousness, the purpose of this tool is to quickly prototype workflows, or for something that is going to run on your dev desktop (like pulling/fixing bugs and submitting PRs). Please don't use it for a production pipeline! If you want to build something that you can rely on, please use systemd or Kinesis/Glue/Lambda (or I guess cron if you are old school like that). I am not responsible for any 3am pages when this falls over ;)
pip install claun-tui# Launch TUI (default)
claun
# Launch TUI with pre-filled command
claun -c "Review our metrics from the past hour for anomalies"
# Run in headless mode
claun -H -c "Update bug list from Linear MCP and fix" -m 60
# See what would run without executing
claun --dry-run -c "test command"- Simple TUI: Single-page interface with all controls visible - no menu diving
- Headless mode: Run as a background service with terminal output
- Flexible scheduling: Days of week, hour ranges, minute intervals
- Job timeout: Configurable timeout kills stuck processes (default: 120s)
- Claude flags: Pass any flags to claude (like
--resumefor session persistence) - Simple logging: Automatic log files with browseable history
Launch with claun to get an interactive interface with:
- Command input field
- Optional Claude flags (e.g.,
--resume <session-id>or--model sonnet) - Timeout setting (seconds, 0 to disable)
- Day-of-week toggles (M T W T F S S)
- Minute interval selector (1, 5, 15, or 60 minutes)
- Big countdown clock to next run
- Pause/Resume control
- Live output log
Keyboard shortcuts:
q- Quitp- Pause/Resumer- Run nowc- Clear log
Run without TUI for background/automated use:
# Every 15 minutes (default)
claun -H -c "Check for issues"
# Hourly during work hours
claun -H -c "Status update" --hours "9am-5pm" -m 60
# Weekdays only
claun -H -c "Daily standup" --weekdays -m 60Jobs have a default timeout of 120 seconds. If a job exceeds the timeout, the process is killed and the next cycle proceeds normally.
# Set a 5-minute timeout
claun -c "Big refactor" --timeout 300
# Disable timeout entirely
claun -c "Long-running task" --timeout 0
# Run once with a short timeout
claun --once -c "Quick check" --timeout 30In the TUI, the timeout is editable via the "Timeout" input field. The timeout_seconds field is also saved/loaded from .claun.json config files.
To resume a previous Claude Code session, use the --flags option to pass --resume:
# First, note your session ID from a previous run
# Then resume it:
claun -c "Continue working on the feature" -f "--resume abc123-def456"
# In the TUI, enter in the "Claude Flags" field:
# --resume abc123-def456You can also pass other claude flags:
# Use a specific model
claun -c "Pull and fix bugs from the Linear MCP, run /code-simplifier and push PRs" -f "--model opus"
# Enable web search
claun -c "What is the score of the Niners/Seahawks game?" -f "--allowedTools WebSearch"
# Combine multiple flags
claun -c "Fix the next bug on the bug list" -f "--resume abc123 --model sonnet"Options:
-c, --command TEXT Claude Code command to run
-f, --flags TEXT Extra flags for claude (e.g., '--resume abc123')
-H, --headless Run in headless mode (no TUI)
-d, --days TEXT Days to run (mon,tue,wed,thu,fri,sat,sun)
--weekdays Run only on weekdays (mon-fri)
--weekends Run only on weekends (sat-sun)
--hours TEXT Hour range (e.g., '9-17' or '9am-5pm')
-m, --minutes [1|5|15|60] Minute interval
-t, --timeout INTEGER Timeout in seconds per job (default: 120, 0 to disable)
-l, --log-path PATH Directory for log files
--log-id TEXT Optional ID prefix for log filenames
-P, --paused Start in paused state
--once Run once immediately and exit
--dry-run Show schedule without executing
-v, --version Show version
# List recent logs in current directory
claun logs
# List logs from specific path
claun logs --path /var/log/claun
# Limit to 10 most recent
claun logs -n 10Logs are saved as: [log_id_]claun_YYYYMMDD_HHMMSS_microseconds.txt
Examples:
claun_20260112_143022_123456.txtmyproject_claun_20260112_143022_789012.txt(with --log-id)
GPL-3.0

