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.0.tar.gz (21.5 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.0-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: infraveil_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 21.5 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.0.tar.gz
Algorithm Hash digest
SHA256 19b9950dfe392c106f7348598f39fa161e54295dc477039d532e272983ab14c6
MD5 42dff975df4d8765fa766b7ff33426eb
BLAKE2b-256 c90fc02481f44d20ed90e44ec1e10190bc710fac4c1224ee4ee1f6685ca21af9

See more details on using hashes here.

Provenance

The following attestation bundles were made for infraveil_mcp-0.1.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: infraveil_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.8 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a0f271ce260df884b0ebf8aa7865944979faaa31f2afb4fc06f832b99c0ef6a0
MD5 79518cde542b770dbe9b2ba5a7c22ade
BLAKE2b-256 26fe2703a4ed0084d221679e244c4d73b5a316a0846dc87f5b473f6b9e3dc629

See more details on using hashes here.

Provenance

The following attestation bundles were made for infraveil_mcp-0.1.0-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