The first zero-trust, air-gapped Enterprise GraphRAG server for the Model Context Protocol (MCP).
Project description
VeritasGraph MCP Server
mcp-name: io.github.bibinprathap/veritasgraph
The first zero-trust, air-gapped Enterprise GraphRAG server for the Model Context Protocol.
Connect your local IDE agent — Claude Desktop, Cursor, VS Code, Windsurf,
Cline, Continue — directly to the VeritasGraph knowledge-graph engine over a
standard JSON-RPC 2.0 stdio stream. Build graphs from your documents, run
multi-hop graph-grounded queries with verifiable [doc#chunk] citations, and
inspect entities — all 100% locally, with zero external data egress.
- Zero-trust / air-gapped — stdlib-only JSON-RPC server; no cloud calls, no telemetry. The only network hop is your local Ollama runtime.
- Verifiable attribution — every node and edge records the source chunk it came from, so answers cite their evidence.
- Drop-in — wraps the same
studio_api.graphrag_engineused by Studio.
Tools
| Tool | Purpose |
|---|---|
veritasgraph_ingest_document |
Chunk a document, extract entities/relationships, merge into the graph. |
veritasgraph_query |
Multi-hop, graph-grounded answer with citations and reasoning path. |
veritasgraph_search_entities |
Fast subgraph retrieval for a query (no LLM call). |
veritasgraph_get_graph |
Return the full graph: nodes, edges, stats. |
veritasgraph_clear_graph |
Clear the entire graph (destructive). |
Resources
| URI | Description |
|---|---|
veritasgraph://graph |
Live snapshot of the knowledge graph. |
veritasgraph://stats |
Entity / relationship / source counts. |
Requirements
-
Python 3.10+
-
VeritasGraph repo dependencies:
pip install -r requirements.txt -
A local Ollama runtime with a chat model pulled (ingest/query need a model;
search_entities/get_graphdo not):ollama serve & ollama pull qwen3:latest
Run it
# From the repository root
python -m veritasgraph_mcp # stdio JSON-RPC server
python -m veritasgraph_mcp --debug # verbose logging on stderr
Environment variables
| Variable | Default | Meaning |
|---|---|---|
VERITASGRAPH_MODEL |
qwen3:latest |
Default Ollama model for ingest/query. |
OLLAMA_HOST |
127.0.0.1:11434 |
Local Ollama endpoint. |
STUDIO_DATA_DIR |
studio_api/data |
Where the graph snapshot is persisted. |
Use it through VeritasGraph Studio
The same tools and resources are exposed over HTTP by the Studio backend, so you can drive the MCP server without an IDE — and the Studio agent pipeline can call its tools directly.
Start the Studio API and the bridge mounts under /mcp:
uvicorn studio_api.main:app --port 8200
| Method & path | Purpose |
|---|---|
GET /mcp/ |
Server identity, capabilities, tool/resource counts. |
GET /mcp/tools |
List tool definitions (same schema as tools/list). |
POST /mcp/tools/{name} |
Invoke one tool; body is the tool arguments. |
GET /mcp/resources |
List veritasgraph:// resources. |
GET /mcp/resources/read?uri=... |
Read a resource. |
POST /mcp/rpc |
Full JSON-RPC 2.0 bridge (any MCP method over HTTP). |
Two ready-to-use tools are pre-registered in the Studio Tools section
(VeritasGraph MCP · Query and VeritasGraph MCP · Search), pointing at loopback
/mcp/tools/... endpoints. Enable Tools on an agent to have the orchestrator
invoke them automatically during a run.
# Example: call a tool via the bridge
curl -s http://127.0.0.1:8200/mcp/tools/veritasgraph_search_entities \
-H 'Content-Type: application/json' -d '{"query": "acme corp"}'
Register in your IDE
Replace /abs/path/to/VeritasGraph with the absolute path to your clone, and
point command at the repo's Python (e.g. .venv/bin/python).
Claude Desktop — claude_desktop_config.json
{
"mcpServers": {
"veritasgraph": {
"command": "/abs/path/to/VeritasGraph/.venv/bin/python",
"args": ["-m", "veritasgraph_mcp"],
"cwd": "/abs/path/to/VeritasGraph",
"env": { "VERITASGRAPH_MODEL": "qwen3:latest" }
}
}
}
Cursor — .cursor/mcp.json
{
"mcpServers": {
"veritasgraph": {
"command": "/abs/path/to/VeritasGraph/.venv/bin/python",
"args": ["-m", "veritasgraph_mcp"],
"cwd": "/abs/path/to/VeritasGraph"
}
}
}
VS Code — .vscode/mcp.json
{
"servers": {
"veritasgraph": {
"type": "stdio",
"command": "/abs/path/to/VeritasGraph/.venv/bin/python",
"args": ["-m", "veritasgraph_mcp"],
"cwd": "/abs/path/to/VeritasGraph"
}
}
}
Windsurf, Cline, and Continue use the same command / args / cwd shape.
Quick manual test (no IDE)
Pipe raw JSON-RPC frames over stdio:
printf '%s\n' \
'{"jsonrpc":"2.0","id":1,"method":"initialize","params":{}}' \
'{"jsonrpc":"2.0","id":2,"method":"tools/list","params":{}}' \
'{"jsonrpc":"2.0","id":3,"method":"tools/call","params":{"name":"veritasgraph_get_graph","arguments":{}}}' \
| python -m veritasgraph_mcp
You should get three JSON-RPC responses: server info, the tool catalog, and the current graph snapshot.
How it fits VeritasGraph
The MCP server is a thin protocol adapter. All graph construction, multi-hop
retrieval, and citation logic live in
studio_api/graphrag_engine.py, the same
engine that powers Studio. That means the MCP surface, the Studio UI, and the
HTTP API all read and write the same local knowledge graph.
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 veritasgraph_mcp-0.1.1.tar.gz.
File metadata
- Download URL: veritasgraph_mcp-0.1.1.tar.gz
- Upload date:
- Size: 55.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e06c90fb0576ba8ea7b069bfa82c966fe31f8b1d4502c768176fe0994cc99d34
|
|
| MD5 |
cf9d1a3bf5e823cb6fe60e915bbe58c7
|
|
| BLAKE2b-256 |
f16f2367c4ecc8bd3d7123daa9a85ec5d33b74d6eef2da175a86271eef6cfb01
|
File details
Details for the file veritasgraph_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: veritasgraph_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 38.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0580bbd1fe94181ce21965379f359edb12a1fdab44bddf27118382e2dbcb3d89
|
|
| MD5 |
22f80f2aca83b88c1b2a793afb48955a
|
|
| BLAKE2b-256 |
50b0c614576795c483745c5f7e271b8e6a5da921bb34e3237bc2cffdedfbf6bf
|