Skip to main content

Search and browse Claude conversation history with hybrid search (FTS + Spotlight + vector embeddings)

Project description

Cowork History MCP

An MCP (Model Context Protocol) server for searching and browsing your Claude conversation history stored in ~/.claude/. Works with both Claude Code and Cowork conversations.

Features

  • Hybrid Search - Combines multiple search methods for best results:
    • SQLite FTS5 - Fast full-text search with BM25 ranking
    • macOS Spotlight - Leverages system content indexing via mdfind
    • Vector Embeddings - Semantic similarity search (optional, requires Ollama)
  • Smart Path Reconstruction - Recovers actual filesystem paths via probing (not heuristic guessing)
  • Persistent Index - SQLite database with incremental updates for fast queries
  • Ollama Setup Tools - Automated installation and configuration for embeddings

Installation

Option 1: Claude Desktop (One-Click Install)

Download cowork-history.mcpb from the latest release and double-click to install.

Option 2: Via uvx (Recommended for CLI)

uvx cowork-history

Option 3: Via pip

pip install cowork-history

Option 4: Manual Configuration

Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "cowork-history": {
      "command": "uvx",
      "args": ["cowork-history"],
      "env": {
        "OLLAMA_URL": "http://localhost:11434",
        "EMBEDDING_MODEL": "nomic-embed-text"
      }
    }
  }
}

Quick Start

Once installed, Claude can search your conversation history:

"What did we discuss about authentication last week?"
"Find the conversation where we debugged the payment webhook"
"Show me my conversations in the my-project folder"

Available Tools

Search & Browse

Tool Description
cowork_history_search Search conversations using hybrid search (FTS + Spotlight + vector)
cowork_history_list List recent conversations, optionally filtered by project
cowork_history_get Get full content of a specific conversation by session ID
cowork_history_projects List all projects with conversation history
cowork_history_stats Get statistics and search capability status
cowork_history_reindex Rebuild index and optionally generate embeddings

Ollama Setup (for Vector Search)

Tool Description
history_system_check Check system requirements for Ollama
history_setup_ollama Install Ollama via Homebrew (macOS)
history_setup_ollama_direct Install Ollama via direct download (no Homebrew)
history_ollama_status Check Ollama status and embedding model availability

Search Modes

The cowork_history_search tool supports multiple search modes:

Mode Description
auto (default) Uses all available methods, best results
fts Full-text search only (fastest)
spotlight macOS Spotlight only
vector Semantic similarity only (requires Ollama)
hybrid Explicit combination with ranking

Search Examples

"authentication bug"           → finds conversations with both words
"how to deploy"                → semantic search finds related discussions
"\"exact phrase\""             → exact phrase matching
project:"my-app" "database"    → filter by project

Enabling Vector Search

Vector search provides semantic similarity matching (finding related concepts even without exact keywords). It requires Ollama with an embedding model.

Quick Setup

Ask Claude to set it up for you:

"Set up Ollama for vector search"

Or manually:

# Install Ollama (macOS)
brew install ollama

# Start Ollama service
brew services start ollama

# Pull the embedding model
ollama pull nomic-embed-text

Then generate embeddings:

"Rebuild the history index with embeddings"

How It Works

Indexing

The server maintains a SQLite database at ~/.claude/.history-index/conversations.db with:

  • FTS5 virtual table for fast full-text search
  • Conversation metadata (session ID, project, timestamps, topic)
  • Full content for comprehensive search
  • Path cache for reconstructed paths
  • Embeddings table for vector search (optional)

The index updates automatically when you search (if >5 minutes old) or you can force a rebuild with cowork_history_reindex.

Environment Variables

Variable Default Description
OLLAMA_URL http://localhost:11434 Ollama server URL
EMBEDDING_MODEL nomic-embed-text Ollama embedding model

Troubleshooting

No conversations found

  1. Make sure ~/.claude/ directory exists
  2. Check that you have conversation history (use Claude Code or Cowork first)
  3. Verify the MCP server is properly configured

Vector search not available

  1. Check Ollama is installed: ollama --version
  2. Check Ollama is running: curl http://localhost:11434/api/tags
  3. Check model is available: ollama list
  4. Pull embedding model: ollama pull nomic-embed-text

Search not finding expected results

  • Try natural language queries (semantic search is more flexible)
  • Use mode: "fts" for exact phrase matching
  • Check cowork_history_stats to see which search backends are active

Development

Running locally

# Clone the repository
git clone https://github.com/egoughnour/cowork-history
cd cowork-history

# Install in development mode
pip install -e ".[dev]"

# Run tests
pytest tests/

# Run the server directly
python -m src.cowork_history_server

Testing with MCP Inspector

npx @modelcontextprotocol/inspector uvx cowork-history

License

MIT License - see LICENSE file for details.

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

cowork_history-4.0.1.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

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

cowork_history-4.0.1-py3-none-any.whl (18.5 kB view details)

Uploaded Python 3

File details

Details for the file cowork_history-4.0.1.tar.gz.

File metadata

  • Download URL: cowork_history-4.0.1.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cowork_history-4.0.1.tar.gz
Algorithm Hash digest
SHA256 44d6fcdfbd93c2058242e57ed2c19043d8e806fdd6b0650f31f6c17de9c2f67c
MD5 188868a679dc1606559467757b6c5ab6
BLAKE2b-256 9a8d12ec4737694498c2d66f63910881338285217d8980adaa1e1a94bc09912a

See more details on using hashes here.

Provenance

The following attestation bundles were made for cowork_history-4.0.1.tar.gz:

Publisher: release.yml on egoughnour/cowork-history

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cowork_history-4.0.1-py3-none-any.whl.

File metadata

  • Download URL: cowork_history-4.0.1-py3-none-any.whl
  • Upload date:
  • Size: 18.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cowork_history-4.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f280b362eb12b3f46b4f81bc755044bd0ef7c257e465b2ae0a8c6b2e3c385cc2
MD5 8b263e116889b9c93e427354f6c4fe8e
BLAKE2b-256 e422af554e1a24a67f8c03a716626537d488f00aebb20802f963a0d6bc978384

See more details on using hashes here.

Provenance

The following attestation bundles were made for cowork_history-4.0.1-py3-none-any.whl:

Publisher: release.yml on egoughnour/cowork-history

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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