Claun
Use claun to run Claude Code jobs on timers. Sometimes systemd is just overkill.
Install / Use
/learn @nsmith/ClaunQuality Score
Category
Development & EngineeringSupported Platforms
README
claun
Note: Claude Code now has a similar feature! You should probably just use /loop!

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 ;)
Installation
pip install claun-tui
Quick Start
# 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"
Features
- 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
TUI Mode
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
Headless Mode
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 60
Job Timeout
Jobs 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 30
In the TUI, the timeout is editable via the "Timeout" input field. The timeout_seconds field is also saved/loaded from .claun.json config files.
Session Persistence
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-def456
You 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"
CLI Options
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
Subcommands
Browse Logs
# 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 10
Log Files
Logs are saved as: [log_id_]claun_YYYYMMDD_HHMMSS_microseconds.txt
Examples:
claun_20260112_143022_123456.txtmyproject_claun_20260112_143022_789012.txt(with --log-id)
License
GPL-3.0
