Gives Claude direct control over a local task scheduler with 21 tools for creating workers, building multi-step chains, and reading execution logs. You can ask Claude to schedule a nightly backup script, wire up email reports through Gmail, or diagnose why a task keeps failing by pulling error logs from the last ten runs. Built on APScheduler and Flask with a web dashboard at localhost:5000, backed by SQLite and Redis. Supports Python, batch, and shell scripts with cron scheduling, parallel execution stages, per-worker environment variables, and templated tasks like folder watchers and uptime monitors. Auto-registers itself in Claude Desktop's MCP config on first launch. Useful when you want conversational control over local automation without clicking through a dashboard.
Claude's hands for local automation — with a web dashboard for the humans who watch it.
Conductor gives Claude direct, persistent control of a local task runner. Tell Claude what you want automated; it creates the scheduled workers, builds multi-step pipelines, wires up email reports, fires test runs, and reads back the logs when something fails — all through conversation. A web dashboard at 127.0.0.1:5000 runs alongside it for humans who want to peek at status, click pause, or hand-edit a worker.
Originally built to automate warehouse reporting workflows (the daily ShipExec metrics pull) and now general-purpose: any Python / batch / shell script, any schedule, any chain.
MCP layer lives here: conductor-mcp — the thin server that exposes Conductor's REST API as Claude tools. It's bundled and auto-registered on install, so most users won't need to touch it directly.

Conductor registers itself as an MCP server in Claude Desktop on first launch. After restarting Claude Desktop once, Claude has 21 tools for full control:
Example conversation:
You: Run my metrics script every night at 8:30 PM and email me the report
Claude: I'll set that up using the Run + Email template. (creates the worker, configures the schedule, wires up Gmail, fires it to test) Done — worker "Daily Metrics Report" is live. Check your email for the test run.
You: That uptime check keeps failing. What's going on?
Claude: (pulls the last 10 runs, reads the error logs) The site returned a 503 three times in the last hour. The SSL certificate expired yesterday. Here's the full error from the last run...
You: Chain my backup script and cleanup script together. Run backup first, then cleanup after it finishes. Every day at 2 AM.
Claude: *(creates a chain with stage 0 = backup, stage 1 = cleanup, cron schedule "0 2 * * ") Chain "Nightly Maintenance" created with 2 steps. Backup runs first, cleanup runs after it succeeds.
How it works:
09:00, 14:30), intervals (2h 30m), or cron expressions (0 9 * * 1-5 with plain-English preview)..py), batch (.bat, .cmd), and shell (.sh) scripts. Selenium and GUI scripts run in a visible terminal window via new_console.KEY=VALUE pairs into subprocess environments.



Download and run Conductor_Setup.exe from the latest release.
%AppData%\Conductor — no admin/UAC requiredwinget install Redis.Redis — macOS: brew install redis — Ubuntu: sudo apt install redis-server)git clone https://github.com/jarmstrong158/conductor.git
cd conductor
pip install -r requirements.txt
python launch.py
The dashboard opens at http://127.0.0.1:5000. Press Ctrl+C to stop.
.\build.bat
Forces a full rebuild:
.\build.bat --rebuild
Output: Output\Conductor_Setup.exe. Requires Inno Setup.
.py)Scripts run as subprocesses:
if __name__ == "__main__":
print("Task executed!")
.bat, .sh, .cmd)Executed as subprocesses. The worker's output directory (if set) is used as the working directory.
| Type | Format | Example |
|---|---|---|
| Fixed | HH:MM or HH:MM,HH:MM | 09:00, 14:30, 17:00 |
| Interval | Xh Ym | 2h 30m, 1h, 45m |
| Cron | 5-field crontab | 0 9 * * 1-5 (weekdays at 9am) |
Chains run multiple scripts in sequence. Each step has a stage number — steps with the same stage run in parallel, stages execute in order. Stop on failure halts the chain when any step fails.
Stage 0: backup.py ──┐
Stage 0: cleanup.py ──┤ (both run at once)
↓
Stage 1: report.py (runs after both finish)
| Template | What it does | Email capability |
|---|---|---|
| Folder Backup | Copy folder, keep N backups | Summary email |
| File Cleanup | Delete old files by pattern | Summary email |
| Folder Watcher | Move/email files by extension | Per-rule: move, email, or both |
| Uptime Check | Monitor URL, log status | Alert email on DOWN |
| Open URL | Open URL in browser | — |
| Run + Email | Run script, email output file | Sends output as attachment |
All generated scripts use Python stdlib only.
conductor/
├── launch.py # Entry point — Flask, browser, tray, MCP registration
├── app.py # Flask backend + APScheduler + SQLite + Redis
├── server.py # MCP server for Claude Desktop
├── CLAUDE.md # Context file for Claude Code / Desktop
├── static/
│ └── index.html # Frontend — HTML + CSS + JS (no frameworks)
├── tasks/
│ └── example_task.py
├── templates/
│ └── generated/ # Auto-generated template scripts
├── build.bat # One-click installer build
├── build_icon.py # Generates conductor.ico
├── conductor.spec # PyInstaller spec
├── installer.iss # Inno Setup script
└── conductor.db # SQLite database (auto-created)
| Layer | Technology |
|---|---|
| Backend | Python 3, Flask |
| Scheduling | APScheduler (BackgroundScheduler + MemoryJobStore) |
| Persistence | SQLite |
| Worker State | Redis (port 6379, bundled on Windows) |
| Frontend | Vanilla JS, single HTML file |
| AI Integration | Claude via MCP (21 tools) + Anthropic API (error analysis) |
The debug log includes an Analyze Errors button. When ERROR entries are present, click it to send them to Claude for diagnosis. Requires an Anthropic API key in .env:
ANTHROPIC_API_KEY=sk-ant-...
Example — before / after:
Raw error in the debug log:
[ERROR] worker "Daily Metrics Report" exit code 1
Traceback (most recent call last):
File "C:\scripts\metrics.py", line 142, in <module>
driver.find_element(By.ID, "report-table").click()
File ".../selenium/.../webdriver.py", line 830, in find_element
raise NoSuchElementException(message)
selenium.common.exceptions.NoSuchElementException: Message: no such element:
Unable to locate element: {"method":"css selector","selector":"[id="report-table"]"}
Claude's diagnosis (one click later):
The script is failing on a
find_elementcall before the page has finished loading — Selenium is racing the DOM. The element#report-tableis rendered after an XHR completes. Two fixes, in order of preference:
- Wrap the lookup in a
WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, "report-table")))so it polls until the element exists.- If you don't want to import the wait helpers, a
time.sleep(2)before the click will work but is brittle. The traceback shows this happened on the first run after a ShipExec UI change yesterday — they may have also renamed the element. Verify the ID is stillreport-tablein DevTools before adding the wait.
Click 📧 Email in the header to configure Gmail credentials. Requires a Gmail App Password (2-Step Verification must be enabled first). Credentials are stored locally in .env and never transmitted except to Gmail's SMTP server.
Once configured, all templates and worker notifications can send email.
| Method | Path | Purpose |
|---|---|---|
GET | /api/workers | List all workers |
POST | /api/workers | Register worker(s) |
PUT | /api/workers/<id> | Update worker |
POST | /api/workers/<id>/pause | Toggle pause/resume |
POST | /api/workers/<id>/run-now | Fire immediately |
GET | /api/workers/<id>/history | Run history |
POST | /api/workers/<id>/assign-group | Assign to group |
DELETE | /api/workers/<id> | Delete worker |
POST | /api/workers/pause-all | Pause all workers |
DELETE | /api/workers/all | Delete all workers |
GET | /api/chains | List all chains |
POST | /api/chains | Create chain |
PUT | /api/chains/<id> | Update chain |
POST | /api/chains/<id>/pause | Toggle pause/resume |
POST | /api/chains/<id>/run-now | Fire immediately |
GET | /api/chains/<id>/history | Run history |
DELETE | /api/chains/<id> | Delete chain |
GET | /api/groups | List groups |
POST | /api/groups | Create group |
DELETE | /api/groups/<id> | Delete group |
GET | /api/profiles | List profiles |
POST | /api/profiles | Save profile |
GET | /api/profiles/<id> | Load profile |
DELETE | /api/profiles/<id> | Delete profile |
POST | /api/templates | Create from template |
GET | /api/export | Export all as JSON |
POST | /api/import | Import from JSON |
GET/POST | /api/email-settings | Email configuration |
GET | /api/service/status | Auto-start status |
POST | /api/service/install | Install auto-start |
POST | /api/service/uninstall | Remove auto-start |
GET | /api/update-check | Check for updates |
GET | /api/logs?since=N | Log entries |
GET | /api/redis-status | Redis status |
GET | /api/browse?mode=file|dir | Native file picker |
MIT
GMAIL_USERGmail address for sending email notifications
GMAIL_APP_PASSWORDsecretGmail App Password for sending email notifications
gongrzhe/office-powerpoint-mcp-server
gongrzhe/office-word-mcp-server
io.github.mindstone/mcp-server-office
greirson/mcp-todoist
henilcalagiya/mcp-apple-notes
ankimcp/anki-mcp-server-addon