Agent Compliance Passport MCP
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Agent Compliance Passport MCPverify the compliance passport of did:meok:my-agent"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Agent Compliance Passport MCP
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 centper passport cost. Free for the first 1,000 / month.A2A-ready — the
exchange_credentialstool 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.
Related MCP server: TrustAtom MCP Server
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 |
| str |
|
| str | one of |
| list | subset of 11 supported frameworks |
| dict |
|
| str |
|
| str | ISO 8601 UTC ( |
| str | ISO 8601 UTC, default |
| str | 32-byte Ed25519 public key, hex |
| str | 64-byte Ed25519 signature, hex |
| 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 FalseYou 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:
Agent A calls
issue_passport(...)once, at startup.Agent B does the same.
When A and B meet, each presents its passport.
Each calls
verify_passport(peer_passport)— offline.Each calls
exchange_credentials(peer_passport, my_did).The resulting
scopeis 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 (high-risk system obligations) |
| EU AI Act Article 50 (transparency) |
| EU General Data Protection Regulation |
| US Health Insurance Portability and Accountability Act |
| AICPA SOC 2 Trust Services Criteria |
| ISO/IEC 42001 AI Management System |
| NIST AI Risk Management Framework |
| EU Cyber Resilience Act |
| EU Digital Operational Resilience Act |
| EU NIS2 Directive |
| 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-mcpThis 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_KEYinserver.pyis the single line to swap.Verification is intentionally offline. The server never makes a network call during
verify_passportorexchange_credentials.exchange_credentialsre-runsverify_passportinternally. There is no fast path that skips signature checking.
License
MIT. See LICENSE.
© 2026 meok.ai. The auditor's math is open.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/CSOAI-ORG/meok-compliance-passport-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server