Skip to main content

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_engine used 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_graph do 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


Download files

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

Source Distribution

veritasgraph_mcp-0.1.1.tar.gz (55.3 kB view details)

Uploaded Source

Built Distribution

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

veritasgraph_mcp-0.1.1-py3-none-any.whl (38.3 kB view details)

Uploaded Python 3

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

Hashes for veritasgraph_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 e06c90fb0576ba8ea7b069bfa82c966fe31f8b1d4502c768176fe0994cc99d34
MD5 cf9d1a3bf5e823cb6fe60e915bbe58c7
BLAKE2b-256 f16f2367c4ecc8bd3d7123daa9a85ec5d33b74d6eef2da175a86271eef6cfb01

See more details on using hashes here.

File details

Details for the file veritasgraph_mcp-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for veritasgraph_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0580bbd1fe94181ce21965379f359edb12a1fdab44bddf27118382e2dbcb3d89
MD5 22f80f2aca83b88c1b2a793afb48955a
BLAKE2b-256 50b0c614576795c483745c5f7e271b8e6a5da921bb34e3237bc2cffdedfbf6bf

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