Search, browse, and resume your Claude Code and Codex CLI sessions, plus MCP server to remember past context.
When your coding agent forgets, tell it: see what you have done.
Why ccrider?
You've got months of coding agent sessions sitting in ~/.claude/projects/ and ~/.codex/sessions/. Finding that conversation where you fixed the authentication bug? Good luck grepping through nested JSON files.
ccrider indexes Claude Code and Codex CLI sessions into a single searchable database, with a TUI browser, CLI search, and an MCP server so your agent can search past sessions too.
# Import sessions from Claude Code and Codex CLI ccrider sync # Launch the TUI - browse, search, resume ccrider tui # Or search from command line ccrider search "authentication bug"
Stay in your terminal. Find any conversation. Resume where you left off. Codex sessions are tagged with [codex] in the TUI for easy identification.
Installation:
# Homebrew (recommended) brew install neilberkman/tap/ccrider # Or from source git clone https://github.com/neilberkman/ccrider.git cd ccrider go build -o ccrider cmd/ccrider/main.go sudo mv ccrider /usr/local/bin/ # Install MCP server for all your projects (optional) claude mcp add --scope user ccrider $(which ccrider) serve-mcp
"Vibe code like a king The King!"
ccrider.mp4
Core Features
1. Interactive TUI Browser
Browse your sessions with a polished terminal UI:
- Arrow keys to navigate
- Enter to view full conversation
- o to open session in new terminal tab (auto-detects Ghostty, iTerm, Terminal.app)
- / to search across all messages
- p to toggle project filter (show only current directory)
- ? for help
Sessions matching your current directory are highlighted in light green - instantly see which sessions are relevant to your current work.
2. Full-Text Search
ccrider search "postgres migration" ccrider search "error handling" --project ~/code/myapp ccrider search "authentication" --after 2024-01-01
Powered by SQLite FTS5 - search message content, filter by project or date, get results instantly.
3. Resume Sessions
Press r in the TUI or use the CLI:
ccrider resume <session-id>
Launches claude --resume in the right directory with the right session. Just works.
4. Incremental Sync
ccrider sync # Import new sessions from all providers ccrider sync --full # Re-import everything
Automatically discovers Claude Code (~/.claude/projects/) and Codex CLI (~/.codex/sessions/) sessions. Detects ongoing sessions and imports new messages without re-processing everything.
MCP Server
ccrider includes a built-in MCP (Model Context Protocol) server that gives your coding agent access to your session history.
Ask your agent to search past conversations while working on new problems:
- "Find sessions where I worked on authentication"
- "Show me my most recent Elixir sessions"
- "What was I working on last week in the billing project?"
- "Search my Codex sessions for database migrations"
Setup
Claude Code:
# Install for all your projects (recommended) claude mcp add --scope user ccrider $(which ccrider) serve-mcp # Or for current project only claude mcp add ccrider $(which ccrider) serve-mcp
Claude Desktop:
Add to your config (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"ccrider": {
"command": "ccrider",
"args": ["serve-mcp"]
}
}
}Available Tools
- search_sessions - Full-text search across all session content with date/project/provider filters
- list_recent_sessions - Get recent sessions, optionally filtered by project or provider
- get_session_messages - Get messages from a session (supports tail mode, context around search matches)
- generate_session_anchor - Generate a unique phrase to tag your session for later retrieval
All tools support a provider parameter to filter by claude or codex. The MCP server provides read-only access to your session database. Your conversations stay local.
Configuration
Note: Claude Code auto-deletes session JSON files after 30 days by default. ccrider preserves all session content in its own database, but if you want the original files kept (for resume, etc.), add
"cleanupPeriodDays": 99999to your~/.claude/settings.json.
ccrider looks for config in ~/.config/ccrider/:
# config.toml - pass additional flags to claude --resume claude_flags = ["--dangerously-skip-permissions"]
# terminal_command.txt - custom command for 'o' key # Available placeholders: {cwd}, {command} wezterm cli spawn --cwd {cwd} -- {command}
# resume_prompt.txt - customize the prompt sent when resuming sessionsSee CONFIGURATION.md for full details.
Architecture
Built with strict core/interface separation following Saša Jurić's principles:
- Core (
pkg/,internal/core/): Pure business logic - parsing, database, search, multi-provider import - Interface (
internal/interface/,cmd/): Thin wrappers - CLI, TUI, MCP server
Uses proven technologies:
- Go for performance and single-binary distribution
- SQLite with FTS5 for fast full-text search
- Bubbletea for polished terminal UI
- MCP for Claude integration
Why This Matters
Other coding agent session tools are broken:
- Incomplete schema support (can't parse all message types)
- Broken builds and abandoned dependencies
- No real search (just grep)
- Can't actually resume sessions
- Single-provider only
ccrider fixes this with:
- 100% schema coverage - parses all message types correctly
- Multi-provider - Claude Code and Codex CLI in one database
- SQLite FTS5 search - fast, powerful full-text search
- Single binary - no npm, no pip, no dependencies
- Native resume - one keystroke to resume sessions
- Incremental sync - detects new messages in ongoing sessions
Development
See CONTRIBUTING.md for development setup and guidelines.
Project Structure
cmd/ccrider/ # CLI entry point + MCP server
internal/
core/ # Business logic (no UI concerns)
db/ # Database operations
importer/ # Session import/sync
search/ # Full-text search
session/ # Session launch logic
interface/ # Thin UI wrappers
cli/ # Command handlers
tui/ # Terminal UI (bubbletea)
pkg/
ccsessions/ # Claude Code session parser (public API)
codexsessions/ # Codex CLI session parser (public API)
Quick Build
go build -o ccrider cmd/ccrider/main.go ./ccrider sync ./ccrider tui
Documentation
License
MIT