Skip to main content

Hardened, self-hosted MCP server that lets your AI agent query and govern your Infraveil control plane in-loop — signed both ways, human-approval-gated.

Project description

Infraveil MCP server

A hardened, self-hosted Model Context Protocol server that lets your own AI agent query and govern your Infraveil control plane in-loop — read the governed state of your backend, and file deploy and remediation requests that always pass through human approval.

It is built on the same principle as the rest of Infraveil: trust by inspection, not assertion. This server adds no new authority and no new auth surface. It signs every request with the token your agent already holds, and it verifies the control plane's signed responses in return — so neither side can be forged on the wire. You can read every line here and diff the signing code against the published agent source; they are the same scheme.

Why this exists

The MCP ecosystem's security is, bluntly, bad — most public MCP servers require no auth at all. An MCP server that hands an AI agent operational reach into your backend is exactly the thing that should not be unauthenticated. This one:

  • Signs both directions (HMAC-SHA256 over a canonical request/response, keyed by your per-agent token; nonce + timestamp replay protection).
  • Cannot apply a change by itself. request_deploy and remediate enqueue a request into the control plane's human-approval queue and return the approval URL. There is no code path here that mutates your infrastructure.
  • Is least-privilege. The token is scoped to one client/agent; tenancy is enforced by the control plane. This process holds no more authority than the agent already running on the host.

Install

pip install infraveil-mcp

Configure

The server reuses your existing Infraveil agent identity — it never mints credentials. Either set the environment variables:

export INFRAVEIL_BASE_URL=https://api.infraveil.com
export INFRAVEIL_CLIENT_ID=...
export INFRAVEIL_AGENT_ID=...
export INFRAVEIL_AGENT_TOKEN=...        # your agent's existing token

…or point it at your rendered agent source and let it read the ids and token straight out of the file you can already inspect:

export INFRAVEIL_AGENT_FILE=/opt/infraveil/agent.py

Claude Desktop / Claude Code

{
  "mcpServers": {
    "infraveil": {
      "command": "infraveil-mcp",
      "env": {
        "INFRAVEIL_BASE_URL": "https://api.infraveil.com",
        "INFRAVEIL_CLIENT_ID": "...",
        "INFRAVEIL_AGENT_ID": "...",
        "INFRAVEIL_AGENT_TOKEN": "..."
      }
    }
  }
}

Tools

Read (no side effects):

Tool What it returns
get_agent_status Fleet/agent state: online/offline, heartbeats, CPU/mem/disk, deploy state
get_security_findings Active security policy + recent security events
get_request_trace Recent request/operation traces and outcomes
query_runtime_truth_graph Authoritative host ↔ agent ↔ service ↔ policy snapshot

Governed (enqueue for human approval — never auto-applied):

Tool What it does
evaluate_deploy_gate Reports whether a proposed change would pass policy. Read-only.
request_deploy Files a deploy request into the approval queue; returns request id + approval URL
remediate Files a remediation proposal (respects your blocked categories); returns id + approval URL

Verify it yourself

  1. Read infraveil_mcp/client.py. The request-signing and response-verification code is plain stdlib hmac/hashlib.
  2. Diff it against the published Infraveil agent source (_signed_headers, verify_response_signature). They implement the same protocol.
  3. Run the test suite: pytest tests/. It transcribes the server's verifier and asserts this client's signatures are accepted and tampering is rejected.

License

AGPL-3.0-or-later. The control plane (central authority graph, multi-tenant policy, audit/evidence store) is the commercial product; the code that runs on your machine is open because you should never have to trust code you can't read.

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

infraveil_mcp-0.1.1.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

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

infraveil_mcp-0.1.1-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file infraveil_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: infraveil_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for infraveil_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 94df753b0e7a62bf6afcf2985cdc9997869cabf9cd80ba3d95d22c9544099af7
MD5 26d7faaedfb334fe4c67f0fab096b43d
BLAKE2b-256 829f1c3206fc6fedc45a0cbbdf47b401be89bcc17327462e366b54de45e3e22c

See more details on using hashes here.

Provenance

The following attestation bundles were made for infraveil_mcp-0.1.1.tar.gz:

Publisher: publish.yml on infraveilhq/infraveil-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

  • Download URL: infraveil_mcp-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for infraveil_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d46128b51931527c6abde1f63fceed64a6d9dfa677e9775ff3dea450e228b1b3
MD5 f87d444485f01cbeeca9c9af27051d1f
BLAKE2b-256 8d2ecc687909e67ec570554c57eb2a570c7e967f5b99196e6c8ad5c94c5ce2c1

See more details on using hashes here.

Provenance

The following attestation bundles were made for infraveil_mcp-0.1.1-py3-none-any.whl:

Publisher: publish.yml on infraveilhq/infraveil-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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