Like browser history for your Claude Code sessions.
You run dozens of Claude Code and Codex sessions a day. Which repos have active work? What was that session doing? Where did you leave off yesterday?
Agent Kitchen gives you a single dashboard for all of it — sessions grouped by repo, LLM-generated summaries, live git status, and one-click resume.
# One command. No install needed.
uvx agent-kitchen webWhy
AI coding agents don't have a "recent projects" view. Your session history is scattered across hidden JSONL files. Switching between repos means losing context on what you were doing elsewhere.
Agent Kitchen fixes this by scanning your local session data, grouping everything by git repo, and surfacing what matters:
- What's active — sessions sorted by recency, status badges (done, in progress, waiting)
- What changed — per-repo timeline showing work evolution over days
- What's dirty — live git status (branch, uncommitted changes, unpushed commits)
- What it was about — LLM-generated one-line summaries via Claude Haiku
Features
- Unified view — Claude Code and Codex CLI sessions in one place, grouped by repo
- LLM summaries — one-line descriptions and status classification (done / in progress / waiting)
- Live git status — current branch, dirty files, unpushed commits per repo
- Repo timelines — see how work evolved across sessions over days
- One-click resume — click any session to resume it in a terminal
- Browser terminal — resume sessions in-browser via xterm.js
- Fuzzy search — press
/to filter across all sessions - Fast startup — cached summaries load instantly, LLM upgrades happen in the background
- No build step — vanilla HTML/JS/CSS, zero npm dependencies
Quick Start
# Run directly — no install needed uvx agent-kitchen web # Or install it uv pip install agent-kitchen agent-kitchen web
Opens at http://localhost:8099.
Usage
# Custom port agent-kitchen web --port 9000 # Scan further back in history agent-kitchen web --scan-days 90 # Don't auto-open the browser agent-kitchen web --no-open # Enable background LLM summarization agent-kitchen web --summarize
Pre-indexing summaries
By default, the dashboard shows fallback summaries (the first user message). For LLM-generated summaries, either pass --summarize to the web command, or pre-index:
agent-kitchen index # Index all sessions from the last 60 days agent-kitchen index --dry-run # Preview without LLM calls agent-kitchen index --force # Re-index everything, ignoring cache agent-kitchen index --concurrency 5 # Control LLM concurrency (default: 3)
Summaries are cached at ~/.cache/agent-kitchen/summaries.json.
Authentication (for LLM summaries)
LLM summaries require a Claude API credential, checked in order:
ANTHROPIC_API_KEY— standard Anthropic API keyCLAUDE_CODE_OAUTH_TOKEN— Claude Max subscription tokenpasspassword manager atdev/CLAUDE_SUBSCRIPTION_TOKEN
export ANTHROPIC_API_KEY=sk-ant-...
agent-kitchen web --summarizeWithout credentials, the dashboard still works — you just get fallback summaries instead.
Configuration
| Variable | Default | Description |
|---|---|---|
AGENT_KITCHEN_PORT |
8099 |
Server port |
AGENT_KITCHEN_SCAN_DAYS |
60 |
Days of history to scan |
AGENT_KITCHEN_REFRESH_INTERVAL |
60 |
Background rescan interval (seconds) |
AGENT_KITCHEN_TERMINAL |
ghostty |
Terminal app (ghostty or terminal) |
How It Works
JSONL session files (~/.claude, ~/.codex)
→ Scanner (parse sessions, filter noise)
→ Git Status (branch, dirty, unpushed)
→ Cache (reuse prior summaries by mtime)
→ LLM Summarizer (Claude Haiku via Agent SDK)
→ Grouping (by repo, sorted by recency)
→ FastAPI server (JSON API + static frontend)
Only interactive sessions are shown. Programmatic SDK sessions (≤1 user turn) and subagent child sessions are filtered out. See docs/session-formats.md for details.
Development
git clone https://github.com/haldar/agent-kitchen.git cd agent-kitchen uv pip install -e ".[dev]" uv run pytest # Run tests uvx ruff check --fix . # Lint uvx ruff format . # Format
Requirements
- Python 3.12+
- macOS (terminal launch uses AppleScript; the dashboard itself works anywhere)
~/.claudeand/or~/.codexdirectories with session data
License
Apache 2.0 — see LICENSE.
