devir
Manages multiple development services with colored logs, filtering, and MCP integration for Claude Code.
README
Devir - Dev Runner CLI
A terminal UI for managing multiple dev services with colored logs, filtering, and MCP integration.
<p align="center"> <img src=".github/assets/screen.png" alt="Devir Screenshot" width="800"> </p>
Features
- Bubble Tea TUI - Interactive terminal UI with tabs, viewport, and status bar
- Colored Logs - Each service has its own color for easy identification
- Service Types - Long-running, oneshot, interval, and HTTP request services
- Custom Icons - Emoji icons for services with dynamic status updates
- Service Filtering - View logs from all services or filter by specific service
- Search - Filter logs by text pattern
- Port Management - Detects ports in use and offers to kill them
- MCP Server - Integrate with Claude Code via Model Context Protocol
- Daemon Mode - Multiple TUI/MCP clients can connect to the same services
- Chrome DevTools Extension - View logs in browser DevTools panel
Installation
Quick Install (Recommended)
curl -fsSL https://raw.githubusercontent.com/productdevbook/devir/master/install.sh | bash
Homebrew (macOS/Linux)
brew install productdevbook/tap/devir
Manual Download
Download from Releases
| Platform | Download |
|---|---|
| macOS (Apple Silicon) | devir-darwin-arm64.tar.gz |
| macOS (Intel) | devir-darwin-amd64.tar.gz |
| Linux (x64) | devir-linux-amd64.tar.gz |
| Linux (ARM64) | devir-linux-arm64.tar.gz |
| Windows (x64) | devir-windows-amd64.zip |
From Source
go install github.com/productdevbook/devir@latest
Or build manually:
git clone https://github.com/productdevbook/devir.git
cd devir
make build
Quick Start
# Create devir.yaml (auto-detects project structure)
devir init
# Start services
devir
Usage
Initialize Project
devir init
This creates a devir.yaml file by detecting your project structure:
- Node.js - Detects
package.jsonwithdevscript - Go - Detects
go.mod - Rust - Detects
Cargo.toml - Python - Detects
requirements.txtorpyproject.toml - Monorepos - Scans
apps/*,packages/*,services/*
TUI Mode (default)
# Start all default services
devir
# Start specific services
devir admin server
# With filters
devir --filter "error"
devir --exclude "hmr"
MCP Server Mode
devir --mcp
Daemon Mode
Devir uses a Unix socket daemon, allowing multiple clients (TUI or MCP) to connect to the same running services:
# Terminal 1: Start TUI (daemon starts automatically)
devir
# Terminal 2: Connect another TUI (same services, same logs)
devir
# Terminal 3: Connect via MCP (Claude Code controls same services)
devir --mcp
All clients share the same daemon and see the same logs in real-time. When Claude Code restarts a service, you'll see it immediately in your TUI.
Keyboard Shortcuts
| Key | Action |
|---|---|
Tab |
Cycle through services |
1-9 |
Select specific service |
a |
Show all services |
/ |
Search logs |
c |
Copy logs to clipboard |
r |
Restart current service |
j/k |
Scroll up/down |
q |
Quit |
Configuration
Create devir.yaml in your project root:
services:
admin:
dir: apps/admin
cmd: bun run dev
port: 3000
color: blue
server:
dir: server
cmd: bun run dev
port: 3123
color: magenta
defaults:
- admin
- server
Service Options
| Field | Description |
|---|---|
dir |
Working directory (relative to config file) |
cmd |
Command to run |
port |
Port number (for status display) |
color |
Log prefix color: blue, green, yellow, magenta, cyan, red, white |
icon |
Custom emoji/icon for the service |
type |
Service type: service (default), oneshot, interval, http |
interval |
Run interval for interval type (e.g., 5s, 1m) |
url |
URL for http type |
method |
HTTP method for http type (default: GET) |
body |
Request body for http type |
headers |
Custom headers for http type |
Service Types
Devir supports 4 different service types:
service (default)
Long-running process. For web servers, APIs, etc.
web:
dir: apps/web
cmd: npm run dev
port: 3000
icon: "🌐"
color: blue
oneshot
Run once and exit. For migrations, setup scripts, etc.
migrate:
type: oneshot
dir: .
cmd: npm run migrate
icon: "⚙️"
color: yellow
interval
Run periodically. For health checks, cleanup jobs, etc.
health:
type: interval
interval: 5s
dir: .
cmd: bash health.sh
icon: "💓"
color: green
http
Make HTTP requests. For API calls, webhooks, etc.
api-check:
type: http
url: https://api.example.com/health
method: GET
icon: "📡"
color: magenta
With POST body:
notify:
type: http
url: https://api.example.com/webhook
method: POST
body: '{"event": "started"}'
headers:
- "Authorization: Bearer token123"
icon: "📤"
color: cyan
Status Symbols
| Symbol | Status | Description |
|---|---|---|
● |
Running | Service is active |
✓ |
Completed | Oneshot/HTTP completed successfully |
✗ |
Failed | Service failed |
◐ |
Waiting | Interval service waiting for next run |
○ |
Stopped | Service is stopped |
Dynamic Status
Services can dynamically update their icon and status by writing to .devir-status file in their directory:
# Simple - just icon
echo "🟢" > .devir-status
# JSON - icon + message
echo '{"icon": "🟢", "message": "All OK"}' > .devir-status
# JSON - full control
echo '{"icon": "🔴", "color": "red", "status": "failed", "message": "DB down!"}' > .devir-status
Dynamic Status Fields
| Field | Description |
|---|---|
icon |
Override icon with emoji or short text |
color |
Override service color |
status |
Override status: running, completed, failed, waiting |
message |
Status message (shown in MCP response) |
Example: Health Check with Dynamic Status
#!/bin/bash
# health.sh
if curl -sf http://localhost:3000/health >/dev/null 2>&1; then
echo '{"icon": "🟢", "message": "All systems operational"}' > .devir-status
echo "Health OK"
else
echo '{"icon": "🔴", "color": "red", "message": "Service down!"}' > .devir-status
echo "Health FAIL"
fi
MCP Integration
Add to your project's .mcp.json:
{
"mcpServers": {
"devir": {
"command": "devir",
"args": ["--mcp"],
"cwd": "/path/to/project"
}
}
}
Note: Set
cwdto the directory containing yourdevir.yaml. The daemon socket is unique per project directory, so multiple projects can run independently.
Available MCP Tools
| Tool | Description |
|---|---|
devir_start |
Start services |
devir_stop |
Stop all services |
devir_status |
Get service status (includes type, icon, message) |
devir_logs |
Get recent logs |
devir_restart |
Restart a service |
devir_check_ports |
Check if ports are in use |
devir_kill_ports |
Kill processes on ports |
MCP Status Response Example
{
"services": [
{
"name": "web",
"running": true,
"port": 3000,
"type": "service",
"status": "running",
"icon": "🌐"
},
{
"name": "health",
"running": true,
"type": "interval",
"status": "waiting",
"icon": "🟢",
"message": "All systems operational",
"runCount": 5
}
]
}
Chrome DevTools Extension
View devir logs directly in Chrome DevTools. The extension connects via WebSocket to the devir daemon.
Installation
Download from Releases and extract devir-extension.zip.
- Open
chrome://extensions - Enable "Developer mode"
- Click "Load unpacked"
- Select the extracted extension folder
Usage
-
Start devir with WebSocket enabled (default port 9222):
devir -
Open Chrome DevTools (F12) on any page
-
Click the "Devir" tab
Features
- Real-time logs - Logs stream as they happen
- Service tabs - Filter logs by service
- Level filtering - Filter by error, warn, info, debug
- Search - Filter logs by text
- Service controls - Start, Stop, Restart services directly from DevTools
- Status indicators - Green/yellow/red dots show service status
WebSocket Port
By default, devir starts WebSocket server on port 9222. To use a different port:
devir --ws-port 9333
Note: If you change the port, you'll need to modify the extension's
useWebSocket.tsto match.
Development
# Build
make build
# Build for all platforms
make build-all
# Run tests
make test
# Lint
make lint
Dependencies
- Bubble Tea - TUI framework
- Lip Gloss - Styling
- MCP Go SDK - MCP server
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.