@kunwarshah/claudex
v1.2.1
Published
Professional conversation viewer and analysis tool for Claude Code. Search, analyze, and export your AI conversations with enterprise-grade full-text search and multi-platform support.
Downloads
236
Maintainers
Readme
Claudex
Professional conversation viewer and analysis tool for Claude Code
Category: Development Tools · Conversation Analysis · Usage Monitoring
Claudex is a full-stack web application designed for developers, QA engineers, and researchers who need to inspect, search, and analyze Claude Code conversation histories. Built with React and Fastify, it provides enterprise-grade full-text search using SQLite FTS5, universal template support for all Claude Code versions, and comprehensive analytics dashboards.
📚 Documentation | 💬 Discussions | 🐛 Issues
🆕 What's New
Version 1.1.1 (October 31, 2025)
- 🐛 Fixed Critical Bug: Resolved duplicate message IDs causing intermittent empty session displays (PR #7)
- Line-based unique ID generation ensures all messages render correctly
- Eliminates React duplicate key warnings
- Handles Claude Code's multi-part message format seamlessly
- 📄 Added LICENSE: MIT License file for improved GitHub API discoverability (PR #8)
- 🚀 Quick Start Script: One-command installation leveraging existing system checker
Version 1.1.0 (October 27, 2025)
- 🎯 Smart Title Extraction: Automatically extracts meaningful session titles from conversation content
- 📊 Tremor Analytics Dashboard: Re-enabled with proper Tailwind-based color system and multi-scale visualizations
- 🐳 Docker Multi-Platform: Support for amd64 and arm64 with optimized ~200MB images
- ⚡ Performance: 121x faster async search index rebuild
- 🔧 System Checker: Auto-fix capabilities for common setup issues (
npm run check:fix)
View full changelog | Troubleshooting guide
📸 Screenshots
Conversation View
Full-Text Search
✨ Features
- Auto Project Discovery: Automatically scans
~/.claude/projectsdirectory to discover all available conversations across multiple projects - Full-Text Search: Enterprise-grade SQLite FTS5 search engine with advanced filtering by project, session, role, date range, and content highlighting
- Universal Template Support: Intelligent template detection and parsing for all Claude Code versions (V1.x, V2-mixed, V2.0+) with automatic format detection
- Smart Content Rendering: Syntax-highlighted code blocks, markdown rendering, diff visualization, JSON formatting, and tool usage tracking
- Session Analytics: Comprehensive analytics dashboard with message distribution charts, file operation tracking, and conversation statistics using Tremor React
- Export Options: Export conversations to JSON (structured data), HTML (readable format), or plain TXT for archival and sharing
- Modern UI: Responsive React interface with fixed header/footer navigation, infinite scroll, and optimized for developer workflows
- Hot Reload: Development mode with automatic restart on code changes for rapid iteration
🚀 Quick Start
Prerequisites
- Node.js 18+ and npm
- Claude Code installed with conversation history in
~/.claude/projects
Installation
Option 1: npm (Recommended - Coming Soon)
Note: npm package will be available after Phase B.2 completion
# Global installation
npm install -g @kunwarshah/claudex
# Then run anywhere:
claudex
# Or use without installing (npx):
npx @kunwarshah/claudexOption 2: From Source
- Clone the repository:
git clone https://github.com/kunwar-shah/claudex.git
cd claudex- Run system check (optional but recommended):
npm run checkThis validates your environment and catches common setup issues.
- Install dependencies (or use auto-fix):
# Option 1: Manual installation
npm install
cd server && npm install && cd ..
cd client && npm install && cd ..
# Option 2: Auto-fix (installs deps + creates .env)
npm run check:fix- Configure environment (if not using auto-fix):
cd server
cp .env.example .env
# Edit .env if needed (default: PROJECT_ROOT=~/.claude/projects)
cd ..- Start the application:
# Automatically runs system check, then starts servers
npm run dev- Open your browser: http://localhost:3000
The backend API runs on http://localhost:3400
System Checker
Claudex includes a comprehensive system checker that validates your environment:
# Quick check
npm run check
# Detailed output
npm run check:verbose
# Auto-fix common issues
npm run check:fix
# JSON output (for CI/CD)
npm run check:jsonWhat it checks:
- ✅ Node.js & npm versions
- ✅ PROJECT_ROOT path & permissions
- ✅ Port availability (3000, 3400)
- ✅ Dependencies installation
- ✅ Claude Code data (projects, sessions)
- ✅ JSONL file validity
- ✅ Database permissions
- ✅ Search index status
Global CLI Installation (Optional)
Install globally to use claudex command anywhere:
./install.sh
# Then run from anywhere:
claudex🔧 Configuration
Server Configuration (.env)
# Path to Claude Code projects directory
# Supports ~ expansion (e.g., ~/.claude/projects)
PROJECT_ROOT=~/.claude/projects
# Server port
PORT=3400
# Environment
NODE_ENV=developmentDefault Ports
- Frontend: http://localhost:3000 (Vite dev server)
- Backend: http://localhost:3400 (Fastify API)
- Frontend build: Uses port 3400 (served by backend in production)
📂 Project Structure
claudex/
├── server/ # Backend (Node.js + Fastify)
│ ├── src/
│ │ ├── parsers/ # Template detection & message parsing
│ │ │ ├── templateDetector.js # V1/V2/V3 template detection
│ │ │ └── messageParser.js # Universal message parser
│ │ ├── services/ # Core business logic
│ │ │ ├── fileScanner.js # Project/session discovery
│ │ │ ├── sessionParser.js # Full session parsing
│ │ │ ├── searchDatabase.js # SQLite FTS5 search
│ │ │ └── searchIndexer.js # Search index builder
│ │ ├── routes/ # API endpoints
│ │ │ ├── projects.js # Project/session routes
│ │ │ ├── search.js # Search routes
│ │ │ └── export.js # Export routes
│ │ ├── utils/ # Helper utilities
│ │ │ └── pathHelper.js # Path expansion (~/ support)
│ │ └── server.js # Main server
│ ├── data/ # SQLite database (auto-created)
│ ├── .env.example # Environment template
│ └── package.json
├── client/ # Frontend (React + Vite)
│ ├── src/
│ │ ├── components/ # React components
│ │ │ ├── ProjectSelector.jsx
│ │ │ ├── SessionList.jsx
│ │ │ ├── ConversationThread.jsx
│ │ │ ├── MessageBubble.jsx
│ │ │ ├── ClaudeMessageRenderer.jsx
│ │ │ └── SearchPage.jsx
│ │ ├── services/ # API client
│ │ │ └── api.js
│ │ └── App.jsx # Main app
│ └── package.json
├── bin/ # CLI entry point
├── test-search.sh # Search API testing script
├── install.sh # Global CLI installer
├── SETUP.md # Detailed setup guide
├── README.md # This file
└── package.json # Root package (CLI + concurrently)🎯 Supported Claude Code Formats
The viewer automatically detects and parses all Claude Code conversation formats:
V3 Template (Universal - Recommended)
- Claude Code v2.0+: New format with
rolefield directly - Claude Code v1.x: Original format with
typefield - Edge cases: Mixed formats and migration states
- New message types:
file-history-snapshotsupport - Role mapping: All system messages → assistant (binary user/assistant classification)
Legacy Templates (Auto-detected)
- V2-Mixed: Transition format between V1 and V2
- V1: Original Claude Code format
The template detector uses a waterfall detection strategy, automatically selecting the best parser for your conversation files.
🔍 Search System
Building the Search Index
The search index needs to be built before searching:
# Option 1: Via API
curl -X POST http://localhost:3400/api/search/index/build
# Option 2: Via test script
./test-search.sh
# Option 3: Via UI (Search page → "Rebuild Index" button)When to Rebuild Index
Rebuild the search index when:
- First time setup
- After template changes
- When new conversations are added
- If search results seem outdated
Search API Examples
# Basic search
curl -X POST http://localhost:3400/api/search \
-H "Content-Type: application/json" \
-d '{"q": "migration", "limit": 10}'
# Search with filters
curl -X POST http://localhost:3400/api/search \
-H "Content-Type: application/json" \
-d '{
"q": "database",
"projectId": "my-project",
"role": "user",
"limit": 20,
"offset": 0
}'
# Check index status
curl http://localhost:3400/api/search/index/status📡 API Endpoints
Projects & Sessions
| Endpoint | Method | Description |
|----------|--------|-------------|
| /api/projects | GET | List all projects |
| /api/projects/:id/sessions | GET | Get sessions for project |
| /api/projects/:id/sessions/:sessionId | GET | Get full session with messages |
Search
| Endpoint | Method | Description |
|----------|--------|-------------|
| /api/search | POST | Search conversations (FTS5) |
| /api/search/index/build | POST | Build/rebuild search index |
| /api/search/index/status | GET | Get index statistics |
| /api/search/index/clear | POST | Clear search index |
Export
| Endpoint | Method | Description |
|----------|--------|-------------|
| /api/export/session/:projectId/:sessionId?format=json | GET | Export as JSON |
| /api/export/session/:projectId/:sessionId?format=html | GET | Export as HTML |
| /api/export/session/:projectId/:sessionId?format=txt | GET | Export as TXT |
Health
| Endpoint | Method | Description |
|----------|--------|-------------|
| /api/health | GET | Health check + system info |
🛠️ Development
Development Mode
# Run both frontend + backend with hot reload
npm run dev
# Or run separately:
# Terminal 1 - Backend (auto-restarts on changes)
cd server && npm run dev
# Terminal 2 - Frontend (hot module replacement)
cd client && npm run devTesting the Search System
# Run comprehensive search tests
./test-search.shThis script will:
- Check server health
- Get index status
- Build/rebuild index
- Run test searches with various filters
- Display results
Adding New Templates
- Update Template Detector (
server/src/parsers/templateDetector.js):
'my-template': {
name: 'My Template Name',
detect: (samples) => {
return samples.some(s => s.myUniqueField !== undefined);
},
parser: 'my-template'
}- Add Parser Method (
server/src/parsers/messageParser.js):
parseMyTemplate(rawMessage) {
return {
id: rawMessage.id || this.generateId(),
role: rawMessage.myRole === 'user' ? 'user' : 'assistant',
content: rawMessage.myContent || '',
timestamp: rawMessage.myTimestamp,
// ... other fields
};
}- Rebuild Search Index: The new template will be automatically detected and used.
📝 Scripts Reference
Claudex Directory
npm run dev- Run frontend + backend concurrently (with pre-check)npm start- Run frontend + backend (production mode)npm run check- Run system health checknpm run check:verbose- Run detailed system checknpm run check:fix- Auto-fix common setup issuesnpm run check:json- JSON output for CI/CD./install.sh- Install as global CLI command./test-search.sh- Test search API endpoints
Server Directory
npm run dev- Run with nodemon (auto-restart)npm start- Run in production mode
Client Directory
npm run dev- Vite dev server (http://localhost:3000)npm run build- Build for productionnpm run preview- Preview production build
🐛 Troubleshooting
Quick Diagnosis
Run the system checker first to identify issues:
npm run check:verboseThis will check all common problems and provide actionable suggestions.
Common Issues
"No messages found" Despite Messages Existing
Fixed in v1.1.1 - If you see intermittent empty sessions or duplicate key warnings:
# Update to latest version
cd claude-viewer
git pull origin main
npm install && cd server && npm install && cd ../client && npm install && cd ..
npm run devSee detailed troubleshooting guide for more information.
No Projects Found
# Check what the system sees
npm run check
# Verify path
cat server/.env | grep PROJECT_ROOT- Verify
PROJECT_ROOTin.envpoints to~/.claude/projects - Check that Claude Code has created conversation files
- Run
npm run check:fixto auto-create missing directories
Search Not Working
# Quick fix via UI
# Visit http://localhost:3000/search → Click "Rebuild Index"
# Or via command line
curl -X POST http://localhost:3400/api/search/index/buildPort Conflicts
# System checker will detect port conflicts
npm run check
# Auto-detected ports in use show PID
# Kill process: kill <PID>
# Or change PORT in server/.envPermission Errors
# Check permissions
npm run check:verbose
# Fix permissions
chmod +r ~/.claude/projects
chmod +w claude-viewer/server/dataDependencies Issues
# Auto-install all dependencies
npm run check:fix🚢 Production Deployment
Using Docker (Recommended)
Claudex includes production-ready Docker configuration with multi-stage builds for optimal image size.
Quick Start with Docker
# Build and start with docker-compose
docker-compose up -d
# View logs
docker-compose logs -f
# Stop
docker-compose downAccess at: http://localhost:3400
Docker Configuration
The default docker-compose.yml mounts your Claude projects directory as read-only:
volumes:
# Adjust path to match your system
- ~/.claude/projects:/root/.claude/projects:roCommon path configurations:
# Linux/macOS
~/.claude/projects:/root/.claude/projects:ro
# Windows (WSL2)
/mnt/c/Users/YourName/.claude/projects:/root/.claude/projects:ro
# Custom path
/path/to/your/projects:/root/.claude/projects:roDocker Commands
# Build image manually
docker build -t claudex:latest .
# Run container manually
docker run -d \
-p 3400:3400 \
-v ~/.claude/projects:/root/.claude/projects:ro \
-v claudex-data:/app/data \
--name claudex-web \
claudex:latest
# Check health
docker ps # Check STATUS column for "healthy"
# View logs
docker logs claudex-web -f
# Stop and remove
docker stop claudex-web && docker rm claudex-webDocker Features
- Multi-stage build: Optimized image size (~200MB)
- Non-root user: Runs as nodejs user for security
- Health checks: Automatic health monitoring
- Persistent volumes: Stores search index and logs
- Read-only mounts: Claude projects mounted read-only for safety
- Log rotation: JSON logs with 10MB max size, 3 file rotation
Docker Environment Variables
# Override in docker-compose.yml or docker run
-e PORT=3400 # Server port
-e HOST=0.0.0.0 # Bind address
-e NODE_ENV=production # Environment
-e PROJECT_ROOT=/root/.claude/projects # Claude projects pathManual Production Build
For non-Docker deployments:
# 1. Install dependencies
npm run install-deps
# 2. Build client
npm run build
# 3. Start server (serves built client)
cd server && NODE_ENV=production npm startAccess at: http://localhost:3400
📋 Roadmap
- [x] SQLite FTS5 full-text search
- [x] Universal template support (V1/V2/V3)
- [x] Export to JSON/HTML/TXT
- [x] Path portability with
~/support - [x] Hot reload development mode
- [x] Docker deployment (v1.1.0)
- [x] Conversation analytics dashboard (v1.1.0)
- [ ] WebSocket live updates
- [ ] Authentication for multi-user
- [ ] Plugin system for custom parsers
- [ ] Diff viewer for file changes
📄 License
MIT License - see LICENSE file for details.
🤝 Contributing
- Fork the repository
- Create a feature branch:
git checkout -b feature/amazing-feature - Commit changes:
git commit -m 'Add amazing feature' - Push to branch:
git push origin feature/amazing-feature - Open a Pull Request
📚 Additional Documentation
- SETUP.md - Detailed setup and configuration guide
- INSTALL.md - Legacy installation instructions
💡 Tips
- Use the search page to find conversations across all projects
- Export conversations to share with team members
- Rebuild search index after adding new conversations
- Check
/api/healthendpoint to verify system status - Use
npm run devfor the best development experience with hot reload
