Agent Compliance Passport MCP

Agent Compliance Passport MCP

Issues, verifies, and exchanges portable cryptographic compliance passports for AI agents, enabling offline verification of regulatory compliance across 11 frameworks.

Category
Visit Server

README

Agent Compliance Passport MCP

MCP Python License: MIT Tests

In a world of unverifiable AI claims, we sell the auditor's math.

The Agent Compliance Passport is a single signed, portable credential an AI agent carries proving it is compliant with EU AI Act, GDPR, HIPAA, and nine other frameworks. Any other agent verifies the passport offline, in microseconds, with no network and no phone-home before transacting.

This is the Mavis 7-file MCP server that issues, verifies, and exchanges those passports.


Why

Every AI vendor ships a "trust center." Every AI agent makes compliance claims. None of it is cryptographically verifiable. Two agents transacting in 2026 still exchange Word documents and Slack screenshots.

The Agent Compliance Passport fixes this:

  • Portable — one signed JSON blob travels with the agent.
  • Verifiable offline — the public key is enough. No API call. No vendor lock-in. The verifier does the math, not the vendor.
  • Structured — a per-article claim status across 11 frameworks, with a machine-readable schema for the whole regulation set.
  • Cheap to issue — a +1 cent per passport cost. Free for the first 1,000 / month.
  • A2A-ready — the exchange_credentials tool is the handshake.

Positioning (from BREAKTHROUGH_INSIGHTS.md):

The Anti-Billion-Dollar-Whale. The big platforms will sell you "AI compliance" at $500K/yr. We sell the math the auditor needs to check the claim, for free, open-sourced, and runnable on a Raspberry Pi.


Install

git clone https://github.com/meok-ai/meok-compliance-passport-mcp
cd meok-compliance-passport-mcp
python3 -m venv .venv
source .venv/bin/activate
pip install -e .

The package depends on mcp>=0.9.0, pydantic>=2.0, cryptography>=42.0, and httpx>=0.25.


30-second demo

Issue a passport, verify it offline, exchange it in a handshake. Six lines.

from meok_compliance_passport_mcp.server import (
    issue_passport, verify_passport, exchange_credentials,
)

passport = issue_passport(        # signed, 365-day, Ed25519
    agent_id="did:meok:my-agent-001",
    agent_type="llm_agent",
    frameworks=["eu_ai_act", "gdpr"],
    claims={"eu_ai_act": {"article_9": "compliant"}},
)

print(verify_passport(passport))  # {'valid': True, ...}  -- OFFLINE

print(exchange_credentials(
    passport, counterparty_id="did:meok:peer-007"
))                                  # {'authorized': True, 'scope': [...], ...}

The 3 tools

1. issue_passport(agent_id, agent_type, frameworks, claims) -> Passport

Signs and returns a Passport. The signature is Ed25519 over a canonical (sorted-keys, no-whitespace) JSON encoding of every field except the signature itself.

Field Type Description
agent_id str did:meok:<uuid>
agent_type str one of llm_agent, rag_system, mcp_server, ai_pipeline, autonomous_agent
frameworks_covered list subset of 11 supported frameworks
claims dict {framework: {article: status}}
issuer str meok.ai
issued_at str ISO 8601 UTC (YYYY-MM-DDTHH:MM:SSZ)
expires_at str ISO 8601 UTC, default +365 days
public_key str 32-byte Ed25519 public key, hex
signature str 64-byte Ed25519 signature, hex
kid str Key ID, derived from public key

2. verify_passport(passport) -> {valid, issuer, expires_at, frameworks_covered}

100% offline. No network. Reconstructs the canonical payload from the passport, runs the Ed25519 verification, and checks the expiry. Returns valid: False with a reason on any failure (bad signature, malformed key, expired, etc.).

This is the auditor's math. The math is open, the math is portable, and the math runs on a Raspberry Pi in microseconds.

3. exchange_credentials(agent_id_passport, counterparty_id) -> {authorized, scope, expires}

The A2A handshake. Two agents meet, each presents its passport, and the verifier produces a short-lived authorization token whose scope is the intersection of the frameworks the presented passport covers. Default token TTL: 60 seconds.


EU AI Act Article 50 alignment

Article 50 of the EU AI Act imposes transparency obligations on providers and deployers of AI systems that interact with natural persons. Sub-paragraphs cover:

  • Informing users they are interacting with an AI system (Art. 50(1))
  • Disclosure of emotion-recognition / biometric categorisation (Art. 50(3))
  • Deepfake disclosure (Art. 50(4))
  • AI-generated content marking (Art. 50(4))

The passport has first-class support for ai_act_article_50 as one of its eleven frameworks. An agent's claims map can carry per-sub-article status (e.g. transparency_50: compliant) and the verifier enforces it just like any other framework.

This server is the keystone companion to meok-compliance-gateway, which provides the underlying zero-knowledge and signature machinery. The passport adds the agent identity and the portable claim. Together they are the auditor's math.


Verify offline

The full verification path uses only the public key, the signature, and the fields in the passport. No phone-home. No meok.ai API call.

from cryptography.hazmat.primitives.asymmetric.ed25519 import Ed25519PublicKey
from cryptography.exceptions import InvalidSignature
from meok_compliance_passport_mcp.server import Passport, ISSUER_PUBLIC_KEY_HEX

def verify_with_public_key(passport: Passport) -> bool:
    pub = Ed25519PublicKey.from_public_bytes(bytes.fromhex(passport.public_key))
    payload = passport.canonical_payload()
    try:
        pub.verify(bytes.fromhex(passport.signature), payload)
        return True
    except InvalidSignature:
        return False

You can publish ISSUER_PUBLIC_KEY_HEX anywhere — on-chain, in DNS, in a transparency log — and any third party can verify any passport without ever talking to us.


Next: A2A handshake

The exchange_credentials tool is the production primitive for the Agent-to-Agent (A2A) handshake. In a typical flow:

  1. Agent A calls issue_passport(...) once, at startup.
  2. Agent B does the same.
  3. When A and B meet, each presents its passport.
  4. Each calls verify_passport(peer_passport)offline.
  5. Each calls exchange_credentials(peer_passport, my_did).
  6. The resulting scope is the agreed regulatory surface for the transaction.

Token TTL is 60 seconds by default, so this is meant to be re-run on every meaningful interaction, not cached.


The 11 supported frameworks

Key Framework
eu_ai_act EU AI Act (high-risk system obligations)
ai_act_article_50 EU AI Act Article 50 (transparency)
gdpr EU General Data Protection Regulation
hipaa US Health Insurance Portability and Accountability Act
soc2 AICPA SOC 2 Trust Services Criteria
iso_42001 ISO/IEC 42001 AI Management System
nist_ai_rmf NIST AI Risk Management Framework
cra EU Cyber Resilience Act
dora EU Digital Operational Resilience Act
nis2 EU NIS2 Directive
code_of_practice GPAI Code of Practice

Per-article schema hints for each framework are exported as REGULATION_SCHEMA in server.py. They are not enforced at issue time — they are a documentation surface for downstream tooling (a UI, a gap-analysis engine, a regulator's report generator).


Pricing

Tier Quota Price
Free 1,000 passports / mo $0
Pro 100,000 passports / mo $499 / mo
Enterprise Unlimited Talk to us

Issue cost is on the order of a fraction of a cent — the bottleneck is signature verification, which is +1 ms per check, offline. The exchange_credentials handshake is free for both parties.


Running the MCP server

The package exposes a console script:

meok-compliance-passport-mcp

This speaks the Model Context Protocol over stdio. To wire it into an MCP host (Claude Desktop, Cursor, etc.), add it to your mcp.json:

{
  "mcpServers": {
    "meok-compliance-passport": {
      "command": "meok-compliance-passport-mcp",
      "args": []
    }
  }
}

Once wired, the three tools above are callable as native MCP tools.


Security notes

  • The bundled private key is deterministic and public. It exists so the demo works out of the box and so anyone can reproduce the signature for verification. Replace it with the meok-compliance-gateway KMS in production. The constant TEST_PRIVATE_KEY in server.py is the single line to swap.
  • Verification is intentionally offline. The server never makes a network call during verify_passport or exchange_credentials.
  • exchange_credentials re-runs verify_passport internally. There is no fast path that skips signature checking.

License

MIT. See LICENSE.

© 2026 meok.ai. The auditor's math is open.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured