Code intelligence MCP server — multi-project code graph, semantic search, session history, knowledge base, web search
Project description
solograph
Code intelligence MCP server for Claude Code. Multi-project code graph, semantic search, session history, knowledge base, web search.
PyPI:
pip install solograph/uvx solograph
All vector search powered by FalkorDB (embedded, no Docker). No ChromaDB dependency.
Embeddings
Two backends, both produce 384-dimensional vectors:
| Backend | Model | Platform | Languages |
|---|---|---|---|
| MLX (primary) | multilingual-e5-small-mlx |
Apple Silicon | RU + EN |
| sentence-transformers (fallback) | all-MiniLM-L6-v2 |
Any | EN |
Auto-detects Apple Silicon → uses MLX. Falls back to sentence-transformers on other platforms.
Install MLX support (optional):
uv add solograph[mlx]
Install
uv add solograph
# or
pip install solograph
Usage
MCP Server (for Claude Code)
claude mcp add -s project solograph -- uvx solograph
Or add manually to .mcp.json:
{
"mcpServers": {
"solograph": {
"command": "uvx",
"args": ["solograph"]
}
}
}
CLI
solograph-cli init ~/my-projects # First-time setup (scan + build graph)
solograph-cli init ~/my-projects --deep # + imports, calls, inheritance
solograph-cli scan # Re-scan projects into graph
solograph-cli scan --deep # + imports, calls, inheritance (tree-sitter)
solograph-cli stats # Graph statistics
solograph-cli explain my-app # Architecture overview
solograph-cli xray ~/my-projects # Portfolio X-Ray (all projects at once)
solograph-cli diagram my-app # Mermaid diagram
solograph-cli query "MATCH (n) RETURN n LIMIT 5"
solograph-cli web-search "query" # Web search via SearXNG/Tavily
solograph-cli index-youtube -c GregIsenberg -n 10 # Index YouTube channel
solograph-cli index-youtube -u "https://youtube.com/watch?v=ID" # Index specific video by URL
solograph-cli index-youtube # Index all channels from channels.yaml
Install globally:
uv tool install solograph # → solograph + solograph-cli in PATH
Quick Start
# 1. Install
uv tool install solograph
# 2. Init — creates ~/.solo/, scans projects, builds graph
solograph-cli init ~/my-projects
# 3. Add MCP to Claude Code
claude mcp add -s project solograph -- uvx solograph
# 4. Done — MCP tools available in Claude Code
Configuration
Environment variables:
| Variable | Default | Description |
|---|---|---|
CODEGRAPH_DB_PATH |
~/.solo/codegraph.db |
FalkorDB code graph path |
CODEGRAPH_REGISTRY |
~/.solo/registry.yaml |
Project registry path |
CODEGRAPH_SCAN_PATH |
~/projects |
Where to scan for projects |
KB_PATH |
(none) | Knowledge base root (markdown files with YAML frontmatter) |
TAVILY_API_URL |
http://localhost:8013 |
Tavily-compatible search URL |
TAVILY_API_KEY |
(none) | API key for Tavily |
15 MCP Tools
codegraph_query— Cypher queries against code graphcodegraph_stats— graph statistics (projects, files, symbols, packages)codegraph_explain— architecture overview of a projectcodegraph_shared— packages shared across projectsproject_code_search— semantic code search (auto-indexes on first call)project_code_reindex— reindex project code into FalkorDB vectorssession_search— Claude Code session history searchproject_info— project registry infokb_search— knowledge base semantic searchweb_search— web search (Tavily/SearXNG)source_search— search indexed external sources (YouTube, Telegram)source_list— list indexed sources with document countssource_tags— auto-detected topics with video countssource_related— find related videos by shared tags
Web Search
The web_search tool connects to any Tavily-compatible API. Works great with self-hosted SearXNG + Tavily Adapter — private, no API keys, smart engine routing.
# Self-hosted (Docker, 1 minute setup)
git clone https://github.com/fortunto2/searxng-docker-tavily-adapter.git
cd searxng-docker-tavily-adapter
cp config.example.yaml config.yaml
docker compose up -d
# → http://localhost:8013/search (Tavily API)
# → http://localhost:8999 (SearXNG UI)
Or use Tavily API directly — set TAVILY_API_URL=https://api.tavily.com and TAVILY_API_KEY.
Smart engine routing auto-selects search engines by query type:
- tech: github, stackoverflow (keywords: python, react, code)
- academic: arxiv, google scholar (keywords: research, paper)
- product: brave, reddit, app stores (keywords: app, competitor, pricing)
- news: google news (keywords: news, latest, trend)
- general: google, duckduckgo, brave (default)
Graph Schema
Nodes
| Node | Key Properties | Source |
|---|---|---|
Project |
name, stack, path | registry.yaml |
File |
path, lang, lines, project | tree-sitter scan |
Symbol |
name, kind (class/function/method), file, line | tree-sitter AST |
Package |
name, version, source (npm/pip/spm/gradle) | manifest files |
Session |
session_id, project_name, started_at, slug | .claude/ history |
Edges
| Edge | From → To | Description |
|---|---|---|
HAS_FILE |
Project → File | Project contains file |
DEFINES |
File → Symbol | File defines symbol |
IMPORTS |
File → File/Package | Import relationship |
CALLS |
File → Symbol | File calls symbol |
INHERITS |
Symbol → Symbol | Class inheritance |
DEPENDS_ON |
Project → Package | Package dependency |
MODIFIED |
Session → File | Git history (lines added/removed) |
TOUCHED / EDITED / CREATED |
Session → File | Session file operations |
IN_PROJECT |
Session → Project | Session belongs to project |
Example Cypher Queries
-- Hub files (most imported)
MATCH (f:File)<-[:IMPORTS]-(other:File)
RETURN f.path, COUNT(other) AS importers
ORDER BY importers DESC LIMIT 10
-- Shared packages across projects
MATCH (p1:Project)-[:DEPENDS_ON]->(pkg:Package)<-[:DEPENDS_ON]-(p2:Project)
WHERE p1.name <> p2.name
RETURN pkg.name, COLLECT(DISTINCT p1.name) AS projects
-- Impact analysis: what breaks if I change this file?
MATCH (f:File {path: 'lib/utils.ts'})<-[:IMPORTS*1..3]-(dep:File)
RETURN dep.path
-- Most edited files (from session history)
MATCH (s:Session)-[:EDITED]->(f:File)
RETURN f.path, COUNT(s) AS sessions
ORDER BY sessions DESC LIMIT 10
-- Files touched by sessions in a project
MATCH (s:Session {project_name: 'my-app'})-[r]->(f:File)
RETURN f.path, type(r) AS action, COUNT(s) AS times
ORDER BY times DESC
YouTube Source Graph
Separate FalkorDB graph at ~/.solo/sources/youtube/graph.db:
| Node | Key Properties |
|---|---|
Channel |
name, handle, subscriber_count |
Video |
video_id, title, duration, view_count, created |
VideoChunk |
text, chapter, start_time, start_seconds, chunk_index, chunk_type, embedding (384-dim) |
Tag |
name |
| Edge | Description |
|---|---|
HAS_VIDEO |
Channel → Video |
HAS_CHUNK |
Video → VideoChunk |
TAGGED |
Video → Tag (weighted by confidence) |
Indexer: solograph-cli index-youtube — discovers videos via SearXNG, fetches metadata + VTT via yt-dlp, chunks by chapters, embeds, upserts into graph.
Channels: ~/.solo/sources/youtube/channels.yaml — YAML list of YouTube handles to index. Symlink from your project's channels.yaml.
Chunking: VTT subtitles parsed into timestamped segments, grouped by chapter boundaries via chunk_segments_by_chapters(). Each chunk has accurate start_seconds from real VTT timestamps.
VTT cache: ~/.solo/sources/youtube/vtt/{videoId}.vtt — persistent, reused on re-index.
ProductHunt Source Graph
Separate FalkorDB graph at ~/.solo/sources/producthunt/graph.db:
| Node | Key Properties |
|---|---|
SourceDoc |
doc_id, title, url, content, tags, created, popularity, embedding (384-dim) |
Maker |
username, name, headline, bio, points, streak_days, followers, twitter, linkedin |
Indexer: solograph-cli index-producthunt — scrapes ProductHunt GraphQL API v2, maps products to SourceDoc with upvotes as popularity.
solograph-cli index-producthunt -d 30 # Last 30 days
solograph-cli index-producthunt --all --resume # Full 3-year dump with checkpoint
solograph-cli import-producthunt data.jsonl # Import from JSONL file
Ranking: Search results are boosted by popularity (upvotes). At equal semantic relevance, products with more upvotes rank higher.
Search Server
HTTP API for vector search across all indexed sources. Designed to run as a Docker service alongside SearXNG.
# Standalone
solograph-search # starts on port 8002
# Docker (in searxng-docker-tavily-adapter)
docker compose up -d solograph-search
Endpoints:
GET /search?q=AI+tool&source=producthunt&n=5— semantic search (source optional)GET /sources— list indexed sources with countsGET /health— status
Popularity boost: Products with more upvotes rank higher at equal relevance. Score = cosine_similarity * 0.85 + log10(upvotes) * boost. Fetch 3x candidates, re-rank, return top N.
| Variable | Default | Description |
|---|---|---|
SOLOGRAPH_SEARCH_PORT |
8002 |
HTTP server port |
SOURCES_ROOT |
~/.solo/sources |
FalkorDB graphs directory |
Storage
- Code graph:
~/.solo/codegraph.db(FalkorDB) - Session vectors:
~/.solo/sessions/graph.db(FalkorDB) - KB vectors:
{KB_PATH}/.solo/kb/graph.db(FalkorDB) - Project vectors:
{project_path}/.solo/vectors/graph.db(per-project FalkorDB) - YouTube source:
~/.solo/sources/youtube/graph.db(FalkorDB) +youtube/vtt/(cached VTT files) +youtube/channels.yaml - ProductHunt source:
~/.solo/sources/producthunt/graph.db(FalkorDB) — 26k+ products with upvote-based ranking
Part of Solo Factory
Solograph is the MCP backend for Solo Factory — 9 skills and 3 agents for shipping startups faster. PyPI
Install skills + MCP together:
# Option 1: Skills for any agent (Claude Code, Cursor, Copilot, Gemini CLI, etc.)
npx skills add fortunto2/solo-factory --all
# Option 2: Claude Code plugin (skills + agents + MCP auto-start)
claude plugin marketplace add fortunto2/solo-factory
claude plugin install solo --scope user
Or use solograph standalone — just add to .mcp.json as shown above.
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file solograph-0.2.4.tar.gz.
File metadata
- Download URL: solograph-0.2.4.tar.gz
- Upload date:
- Size: 301.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
455b0a51b40e9f131140ee6145376dbd8de0a22149c76c0746fc5201f2aeec8b
|
|
| MD5 |
3c9c6cc818eb034c5c5454f5918f5f2c
|
|
| BLAKE2b-256 |
cc9ca1bcb7409a1404f19355d30583a673b18c189b06f457c42a4b733bf8f883
|
File details
Details for the file solograph-0.2.4-py3-none-any.whl.
File metadata
- Download URL: solograph-0.2.4-py3-none-any.whl
- Upload date:
- Size: 115.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
693ec6a1ac0a7af8c04737b3c87dcd385f62ac3380d17ca000fb52ff0e24a33c
|
|
| MD5 |
1712fba58f70b7a95faeb3a59c5f3bb3
|
|
| BLAKE2b-256 |
6e1b0524df2798458213e2f3bc0e101a893c9eb619a225b622648be1db290fdb
|