The Semantica MCP server exposes your knowledge graph as 12 callable tools so any compatible AI client — Claude Desktop, Windsurf, VS Code extensions — can traverse the graph live, record decisions, run analytics, and export results during a conversation. Use it to give LLM agents direct, real-time access to graph data without writing custom tool wrappers.
The Semantica MCP server exposes 12 tools and 3 read-only resources. All tools accept and return JSON. No configuration beyond an optional environment variable for graph persistence is required.

Starting the Server

Install Semantica, then launch the MCP server. It starts in stdio mode by default — the protocol used by Claude Desktop, Windsurf, VS Code extensions, and most MCP clients.
pip install semantica
# Via the CLI entry-point (recommended)
semantica-mcp

# Or via the Python module directly
python -m semantica.mcp_server
Startup info prints to stderr. Without SEMANTICA_KG_PATH the server initialises an empty in-memory graph — sufficient for testing. For a persistent graph that survives restarts, set the path:
SEMANTICA_KG_PATH=/data/threat_graph.json semantica-mcp
Without SEMANTICA_KG_PATH, the graph resets when the server process exits. Always set this path for any session whose data should survive a restart.

Connecting to Claude Desktop

Edit the Claude Desktop config file — on macOS at ~/Library/Application Support/Claude/claude_desktop_config.json, on Windows at %APPDATA%\Claude\claude_desktop_config.json:
{
  "mcpServers": {
    "semantica": {
      "command": "semantica-mcp",
      "env": {
        "SEMANTICA_KG_PATH": "/path/to/knowledge_graph.json",
        "SEMANTICA_LOG_LEVEL": "INFO"
      }
    }
  }
}
Restart Claude Desktop after saving. The Semantica tools appear in the tool palette automatically — Claude can now call them during any conversation. If semantica-mcp is not on your system PATH (for example, if it is installed in a virtualenv), use the full binary path in "command": "/path/to/venv/bin/semantica-mcp".

Connecting to Other Clients

Windsurf — in Settings → MCP Servers → Add Server, or edit ~/.windsurf/mcp_servers.json:
{
  "semantica": {
    "command": "semantica-mcp",
    "env": { "SEMANTICA_KG_PATH": "/path/to/knowledge_graph.json" }
  }
}
VS Code (Cline / Roo Code / Continue) — add to .mcp.json in your project root:
{
  "servers": {
    "semantica": {
      "type": "stdio",
      "command": "semantica-mcp",
      "env": {
        "SEMANTICA_KG_PATH": "${workspaceFolder}/knowledge_graph.json",
        "SEMANTICA_LOG_LEVEL": "DEBUG"
      }
    }
  }
}
Docker:
docker run --rm -i \
  -e SEMANTICA_KG_PATH=/data/kg.json \
  -v /local/path:/data \
  ghcr.io/semantica-agi/semantica-mcp:latest

What the Agent Can Do: The 12 Tools

Once connected, the LLM can call any of these tools during a conversation. The agent chains them automatically — you do not orchestrate the sequence, you just describe what you want. Entity and relation extractionextract_entities pulls named entities from free text; extract_relations extracts semantic relationships and RDF triplets. These two tools turn a raw OSINT report into structured graph inputs without any preprocessing. Knowledge graph manipulationadd_entity adds a node, add_relationship adds a directed edge. After extraction, the agent calls these to persist what it found into the live graph. Decision intelligencerecord_decision writes a decision as a provenance node with confidence score, reasoning, and decision maker identity. query_decisions retrieves past decisions by query or category. find_precedents finds the most similar past decisions by semantic similarity. get_causal_chain traces decision causality upstream or downstream. Reasoningrun_reasoning applies forward-chaining IF/THEN rules over a set of facts and returns derived conclusions. Analytics and exportget_graph_analytics computes PageRank centrality and community detection. get_graph_summary returns node count, decision count, and server status. export_graph serializes the current graph to Turtle, JSON-LD, N-Triples, or plain JSON.

Watching a Real Agent Session

Here is what happens when an analyst types a prompt into Claude Desktop and the graph is live. The prompt is:
“Extract entities and relationships from this OSINT report, add them to the knowledge graph, then record an attribution decision for APT29 with confidence 0.88 and export the full graph as Turtle.”
Claude chains five tool calls automatically:
1. extract_entities(text="<report text>")
   → { "entities": [{"label": "APT29", "type": "ThreatActor"}, ...] }

2. extract_relations(text="<report text>")
   → { "relations": [{"source": "APT29", "type": "EXPLOITS", "target": "CVE-2024-3400"}] }

3. add_entity(id="apt29", label="APT29", type="ThreatActor", metadata={"alias": "NOBELIUM"})
   → { "status": "added", "id": "apt29" }
   (repeated for each extracted entity)

4. add_relationship(source="apt29", target="cve-2024-3400", type="EXPLOITS",
                    metadata={"confidence": 0.97})
   → { "status": "added" }
   (repeated for each extracted relation)

5. record_decision(
       category="threat_attribution",
       scenario="C2 beacon from 185.220.101.47, TTP T1566.001 observed",
       reasoning="IP overlaps APT29 infrastructure cluster; TTPs match NOBELIUM phishing playbook",
       outcome="attributed_to_apt29",
       confidence=0.88,
       decision_maker="analyst_zhang"
   )
   → { "decision_id": "dec_a3f2b1", "status": "recorded" }

6. export_graph(format="turtle")
   → { "format": "turtle", "data": "@prefix ... <apt29> a :ThreatActor ..." }
The analyst asked one question in natural language. Six structured tool calls happened against live graph data. The result is a populated graph, a recorded attribution decision with full provenance, and a Turtle export ready for the SPARQL endpoint — all in a single conversation turn.

The Three Read-Only Resources

Resources expose graph state without a tool call — the client can read them at any point:
URIDescription
semantica://graph/summaryNode count, edge count, server status
semantica://decisions/listUp to 50 most recent recorded decisions
semantica://schema/infoServer version, capabilities, available tool list

Domain Examples

The CTI team uses Claude Desktop to correlate new OSINT reports against the existing threat graph, record attribution decisions, and query causal chains — all through natural language, with the graph updated live.Analyst prompt:
“Extract entities from this Mandiant report on APT40, add them to the knowledge graph, find any past decisions about APT40 attribution, and record a new attribution decision with confidence 0.84.”
Claude chains automatically:
  1. extract_entities + extract_relations on the report text
  2. add_entity for each extracted entity (APT40, CVEs, infrastructure nodes)
  3. add_relationship for each extracted relation
  4. query_decisions(query="APT40 attribution", category="threat_attribution")
  5. find_precedents(scenario="APT40 targeting maritime sector", max_results=3)
  6. record_decision(category="threat_attribution", outcome="attributed_to_apt40", confidence=0.84, decision_maker="analyst_zhang")
The attribution is now a graph node linked to the OSINT evidence, searchable by future agents.
{
  "category": "threat_attribution",
  "scenario": "C2 infrastructure overlaps APT40 cluster; TEMP.Periscope TTPs confirmed",
  "reasoning": "Three C2 IPs match known APT40 hosting ASN; T1190 exploit chain identical to 2023 campaign",
  "outcome": "attributed_to_apt40",
  "confidence": 0.84,
  "decision_maker": "analyst_zhang"
}

Troubleshooting

Server does not appear in Claude Desktop — fully quit and reopen Claude Desktop after editing the config (close the window is not enough). Verify the binary is on PATH: which semantica-mcp on Unix, where semantica-mcp on Windows. If using a virtualenv, use the absolute binary path in "command". Set SEMANTICA_LOG_LEVEL=DEBUG and check stderr for startup errors. Graph data not persisting between sessions — set SEMANTICA_KG_PATH to an absolute file path. Without it the graph is in-memory only and resets on every server restart. Tool calls returning empty resultsget_graph_summary returning "node_count": 0 means the graph is empty. Populate it via add_entity and add_relationship, or run extract_entities on text first and then add_entity for each result. Permission errors on SEMANTICA_KG_PATH — the server process needs read/write access to the file and its parent directory. If running inside Docker, verify the volume mount and file ownership.