Skip to main content

A lightweight, local-first web app to browse, inspect, and export logs from CLI-based AI coding agents

Project description

A lightweight, local-first web app to browse, inspect, and export logs from CLI-based AI coding agents — Claude Code, OpenAI Codex, and Gemini CLI.

FeaturesSupported ToolsInstallationUsageScreenshots

Python 3.7+ FastAPI License MIT PRs Welcome


Installation

Via uv tool (Recommended)

uv is a fast Python package installer. Install it first if you haven't:

curl -LsSf https://astral.sh/uv/install.sh | sh

Then install clicodelog as an isolated tool:

uv tool install clicodelog

To upgrade:

uv tool upgrade clicodelog

Via pip

pip install clicodelog

From source

git clone https://github.com/monk1337/clicodelog.git
cd clicodelog
uv tool install -e .
# or with pip:
pip install -e .

Usage

After installation, simply run:

clicodelog

The app will:

  • Auto-kill any process on port 6126 (if occupied)
  • Sync data from all AI coding agent sources
  • Start a web server at http://localhost:6126

Command Options

clicodelog --help               # Show all options
clicodelog --port 8080          # Use custom port
clicodelog --host 0.0.0.0       # Bind to all interfaces
clicodelog --no-sync            # Skip initial data sync
clicodelog --debug              # Run in debug mode

Alternative: Run from source

git clone https://github.com/monk1337/clicodelog.git
cd clicodelog
python -m clicodelog.cli

Features

  • Multi-source support — View logs from Claude Code, OpenAI Codex, and Gemini CLI
  • Three-panel layout — Projects → Sessions → Conversation
  • Auto-sync — Backs up data from source directories every hour
  • Export — Download any session as a .txt file
  • Theme support — Light (soft blue) and Dark modes
  • Rich display — User/assistant messages, thinking blocks, tool usage, token stats
  • Search — Quickly find projects and sessions

Supported Tools

Tool Source Directory Status
Claude Code ~/.claude/projects/ ✅ Supported
OpenAI Codex ~/.codex/sessions/ ✅ Supported
Gemini CLI ~/.gemini/tmp/ ✅ Supported

Claude Code

  • Sessions organized by project directory
  • Displays summaries, messages, thinking blocks, and tool usage
  • Shows model metadata and token usage

OpenAI Codex

  • Sessions organized by date (YYYY/MM/DD/)
  • Groups sessions by working directory (cwd) as projects
  • Displays messages, function calls, and reasoning blocks
  • Filters out system prompts for cleaner inspection

Gemini CLI

  • Sessions stored as JSON files in {hash}/chats/session-*.json
  • Groups sessions by project hash
  • Displays messages, thoughts (thinking), and tool calls
  • Shows token usage (input, output, cached)

CLI Options

clicodelog --help               # Show help message
clicodelog --version            # Show version
clicodelog --port 8080          # Run on custom port (default: 6126)
clicodelog --host 0.0.0.0       # Bind to all interfaces (default: 127.0.0.1)
clicodelog --no-sync            # Skip initial data sync
clicodelog --debug              # Run in debug mode

Note: The app automatically kills any process running on the specified port before starting.


How It Works

  • Startup sync — Copies logs from source directories into local ./data/
  • Background sync — Automatically refreshes every hour
  • Manual sync — Trigger a sync for the active source via UI
  • Source switching — Switch between Claude Code, Codex, and Gemini CLI

Data Storage

data/
├── claude-code/          # Claude Code backup
│   ├── -Users-project1/
│   │   ├── session1.jsonl
│   │   └── session2.jsonl
│   └── -Users-project2/
├── codex/                # OpenAI Codex backup
│   └── 2026/
│       └── 01/
│           ├── 16/
│           │   └── rollout-xxx.jsonl
│           └── 17/
└── gemini/               # Gemini CLI backup
    ├── {project-hash-1}/
    │   └── chats/
    │       ├── session-2026-01-17T12-57-xxx.json
    │       └── session-2026-01-17T13-04-xxx.json
    └── {project-hash-2}/

Controls

Control Action
Source dropdown Switch between supported tools
📥 Export Download current session as .txt
🔄 Sync Manually refresh logs from source
☀️ / 🌙 Theme Toggle light/dark mode

Screenshots

Light Mode Dark Mode
Light Mode Dark Mode

Project Structure

clicodelog/
├── app.py              # Flask backend (multi-source support)
├── run.sh              # Run script
├── requirements.txt    # Dependencies
├── data/               # Synced logs (auto-created)
│   ├── claude-code/
│   ├── codex/
│   └── gemini/
└── templates/
    └── index.html      # Frontend

API Endpoints

Endpoint Method Description
/api/sources GET List available sources
/api/sources/<id> POST Set active source
/api/projects?source= GET List projects
/api/projects/<id>/sessions?source= GET List sessions
/api/projects/<id>/sessions/<id>?source= GET Fetch session
/api/sync?source= POST Trigger sync
/api/status?source= GET Sync status

Requirements

  • Python 3.7+
  • Flask 2.0+
  • flask-cors

Adding New Sources

To add support for another CLI-based AI tool, update app.py:

SOURCES = {
    "claude-code": {
        "name": "Claude Code",
        "source_dir": Path.home() / ".claude" / "projects",
        "data_subdir": "claude-code"
    },
    "codex": {
        "name": "OpenAI Codex",
        "source_dir": Path.home() / ".codex" / "sessions",
        "data_subdir": "codex"
    },
    "gemini": {
        "name": "Gemini CLI",
        "source_dir": Path.home() / ".gemini" / "tmp",
        "data_subdir": "gemini"
    },
    # Add new tool here
}

Then implement the corresponding parser for its log format.


License

MIT


Built for inspecting what AI coding agents actually did.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

clicodelog-0.2.1.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

clicodelog-0.2.1-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

File details

Details for the file clicodelog-0.2.1.tar.gz.

File metadata

  • Download URL: clicodelog-0.2.1.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for clicodelog-0.2.1.tar.gz
Algorithm Hash digest
SHA256 f78559f4cc30b037546ea280db655e3247242d9bef67977cfe1b7538d9333383
MD5 41ab560d90bd3c572d30c8efcbaf45ea
BLAKE2b-256 40e86b641954468ff4e25b7ad12adc99cb0bb14020406a31bfd80ce4abcbef99

See more details on using hashes here.

File details

Details for the file clicodelog-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: clicodelog-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 23.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for clicodelog-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e3ea6a8efde08c0e0821aad315fdd99488049d9e39dd1ac3da8316365218d716
MD5 a9b45e9aae4273b8ce0e886c12d6e5d1
BLAKE2b-256 a518c5d4d57c48a20b48c19b42e50407ddca820252c32c3efa641fa2142957f8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page