VIRP MCP Server — Cryptographic trust primitives for AI agents operating on live network infrastructure.
Project description
VIRP MCP Server
Cryptographic trust primitives for any AI agent.
Give your AI agent the ability to prove what it saw on your network. Every observation is HMAC-SHA256 signed at the point of collection, before the AI ever touches it. The AI cannot fabricate what the network never said.
VIRP MCP Server exposes the VIRP protocol as standard MCP tools. Any MCP-compatible client — Claude, GPT, Ollama, OpenClaw, or your own agent — connects and gets signed, verified infrastructure observations out of the box.
What This Solves
Every AI operations platform on the market trusts its own telemetry implicitly. The AI says "I checked your firewall." Did it? Can you prove it?
VIRP MCP Server adds a cryptographic trust layer between your AI agent and your infrastructure:
Any AI Agent (Claude, GPT, Ollama, h-cli, OpenClaw)
│
│ MCP protocol (stdio or SSE)
▼
┌─────────────────────┐
│ VIRP MCP Server │ ← You are here
│ (Python) │
└────────┬────────────┘
│ TCP / Unix socket
▼
┌─────────────────────┐
│ VIRP O-Node │ Isolated C daemon
│ HMAC-SHA256 signing │ chain.db audit trail
│ Device SSH access │ Key management
└────────┬────────────┘
│ SSH
▼
┌─────────────────────┐
│ Network Devices │ Cisco, Fortinet, Palo Alto, ...
└─────────────────────┘
The MCP server is a translation layer. It takes tool calls from your AI agent, forwards them to the VIRP O-Node, and returns cryptographically signed results. The O-Node does all signing — this server never touches keys.
Quick Start
Install
pip install virp-mcp-server
Or from source:
git clone https://github.com/nhowardtli/virp.git
cd virp/mcp-server
pip install -e .
Configure
# Point to your O-Node (TCP via socat bridge)
export VIRP_ONODE_HOST=10.0.0.211
export VIRP_ONODE_PORT=9999
# Or use Unix socket for local O-Node
# export VIRP_ONODE_SOCKET=/tmp/virp-onode.sock
Run
virp-mcp
Connect from Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"virp": {
"command": "virp-mcp",
"env": {
"VIRP_ONODE_HOST": "10.0.0.211",
"VIRP_ONODE_PORT": "9999"
}
}
}
}
Connect from Claude Code
claude mcp add virp -- virp-mcp
Tools
| Tool | Description |
|---|---|
virp_collect |
Collect a signed observation from a device. Returns output + HMAC + sequence + trust tier. |
virp_verify |
Verify a previously collected observation against the chain. |
virp_devices |
List all devices registered with the O-Node. |
virp_baseline |
Get baseline state for a device, flag deviations from known-good. |
virp_intent |
Submit a proposed change. Trust-tier gated: GREEN/YELLOW/RED/BLACK. |
virp_chain |
Query the immutable audit trail. Each entry hashes the previous one. |
virp_status |
Check O-Node health and connection status. |
Trust Tiers
VIRP enforces structural limits on what the AI can do:
| Tier | What it means | Example |
|---|---|---|
| GREEN | Auto-execute. Read-only. | show ip bgp summary, ping |
| YELLOW | Flagged for review. | Restart a non-critical service |
| RED | Human approval required. | Firewall rule change, interface shutdown |
| BLACK | Structurally impossible. | Factory reset, delete keys, disable VIRP |
BLACK tier operations cannot be approved. The O-Node refuses them at the protocol level.
Resources and Prompts
MCP Resources (agents can read for context):
virp://trust-tiers— Trust tier definitions and examplesvirp://protocol-info— Protocol overview, version, DOI, links
Built-in Prompts:
network_audit— Full VIRP-verified audit across all devicesinvestigate_device— Deep investigation of a specific device
Configuration
| Variable | Default | Description |
|---|---|---|
VIRP_ONODE_HOST |
127.0.0.1 |
O-Node TCP host |
VIRP_ONODE_PORT |
9999 |
O-Node TCP port |
VIRP_ONODE_SOCKET |
— | Unix socket path (overrides TCP) |
VIRP_ONODE_TIMEOUT |
30 |
Command timeout (seconds) |
VIRP_LOG_LEVEL |
INFO |
Logging level |
VIRP_TRANSPORT |
stdio |
MCP transport: stdio or sse |
Also supports YAML config files. See virp-mcp.example.yaml.
Prerequisites
A running VIRP O-Node with registered devices. See the VIRP repository for O-Node setup.
Or use the built-in Mock O-Node to test without any hardware:
# Terminal 1: Start mock O-Node (simulates Cisco, Fortinet, Palo Alto devices)
virp-mock-onode
# Terminal 2: Start MCP server pointing at mock
VIRP_ONODE_PORT=9999 virp-mcp
Testing
pip install virp-mcp-server[dev]
pytest tests/ -v
28 tests covering connection, collection, verification, intents, trust tiers, chain integrity, and baselines. All tests run against the Mock O-Node, no hardware required.
How It Works
- Your AI agent calls
virp_collect("r1", "show ip bgp summary")via MCP - The MCP server forwards the request to the O-Node
- The O-Node SSHs into the device, executes the command
- The O-Node signs the raw output with HMAC-SHA256
- The observation is stored in chain.db with a sequence number
- The MCP server returns the signed observation to your agent
- Your agent makes claims about the network with cryptographic proof
If the AI references a device without a matching signed observation, the Observation Gate catches it. No signed observation = no verified claim.
Protocol
VIRP — Verified Infrastructure Response Protocol
- RFC: draft-howard-virp-01 (submitted to IETF)
- DOI: 10.5281/zenodo.18830236
- Repository: github.com/nhowardtli/virp
- Author: Nate Howard, Third Level IT LLC
- License: Apache 2.0
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 virp_mcp_server-0.1.0.tar.gz.
File metadata
- Download URL: virp_mcp_server-0.1.0.tar.gz
- Upload date:
- Size: 24.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
86b364fed9945e89a2b059d873958b4fd9ee3555ecbed314593558c8aaf3262f
|
|
| MD5 |
14c9a24d256593ade64992b8298935a8
|
|
| BLAKE2b-256 |
c7fff6eafa405a3457444281d8ef69eed86b3962bad380799b1279ac6880c436
|
File details
Details for the file virp_mcp_server-0.1.0-py3-none-any.whl.
File metadata
- Download URL: virp_mcp_server-0.1.0-py3-none-any.whl
- Upload date:
- Size: 25.2 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 |
356688cd11fbe22184bf877d4d5ac59c920650bf3d689e99f894fdf8240e7ea4
|
|
| MD5 |
c99d2b9db807a221626a4d224c3dea25
|
|
| BLAKE2b-256 |
d86b8425a9d070f32164273ad95437c019fa8570314727b44bf67e74cf530892
|