agentmail
Provides SMS verification capabilities by integrating with Twilio to rent phone numbers and receive SMS messages, enabling AI agents to verify phone numbers and receive OTPs.
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., "@agentmailScreen 0xabc123def456 for OFAC sanctions."
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.
agentmail โ compliance & verification toolkit for AI agents
Your agent is about to send USDC to a stranger. Is that stranger sanctioned? 782 OFAC crypto wallets ยท 19,086 sanctioned names ยท 16 embargoed jurisdictions. No API key. No signup. 30-second setup. Free & open source.
agentmail gives any AI agent three capabilities it can't provide itself:
Layer | What | Status |
๐ก๏ธ Compliance | OFAC sanctions screen, KYA, transaction risk score, disputes | โ Live โ real OFAC data |
๐ง Email | Disposable verification inbox (receive OTP/magic links) | โ Live |
๐ฑ SMS | Rentable phone numbers (receive SMS/OTP) | โ Live (mock free, 5sim/Twilio paid) |
It exposes all of these through three surfaces โ MCP tools (for Claude Code / Cursor / Hermes), an HTTP API (for any agent), and a CLI (for you). Same core, same data.
Why this exists
Agents are starting to pay for things (x402, AP2, ACP, Coinbase AgentKit). But every payment rail assumes a human is watching. If your agent autonomously pays a wallet that's on the OFAC Specially Designated Nationals list, that's your legal problem โ and the big payment infra players (OpenAI, Stripe, Coinbase) explicitly do not handle per-jurisdiction sanctions screening, Know-Your-Agent, or agent-transaction fraud signals. That's the gap this fills.
agent โโabout to payโโโถ sanctions_check(wallet) โโโถ clean? proceed. sanctioned? ABORT.Related MCP server: agentline-mcp
Quick start (30 seconds)
git clone https://github.com/kindrat86/agentmail.git
cd agentmail
pip install -e .Option A โ use it from an MCP client (Claude Code / Cursor)
// .mcp.json or your client's MCP config
{
"mcpServers": {
"agentmail": {
"command": "python",
"args": ["-m", "agentmail.mcp_server"]
}
}
}Now your agent can call sanctions_check, risk_score, kya_verify, dispute_open, create_inbox, fetch_code, create_number, fetch_sms, release_number, list_inboxes.
Option B โ use it as an HTTP API
python -m agentmail.api # serves on :8000# Screen a wallet against real OFAC data โ no key, no auth needed for self-host
curl "http://localhost:8000/sanctions?wallet=0x098B716B8Aaf21512996dC57EB0615e2383E2f96"
# โ {"matches":[{"list":"OFAC_SDN","match_type":"wallet_exact","confidence":1.0}],
# "clean":false,"provider":"osint"}
curl "http://localhost:8000/risk" -d '{"counterparty_id":"0xabc...","amount":"5000","rail":"x402"}'
# โ {"score":0,"recommendation":"decline","reasons":["sanctions_match:OFAC_SDN/..."]}Option C โ use it from the CLI
# Sanctions screen โ real OFAC data, no key
python -m agentmail.cli sanctions --wallet 0x098B716B8Aaf21512996dC57EB0615e2383E2f96
# โ flagged: OFAC_SDN wallet_exact
python -m agentmail.cli risk 0xabc123def456 5000 --rail x402
python -m agentmail.cli kya my-agent --wallet 0xabc... --wallet-age 400 --domain bot.dev
python -m agentmail.cli compliance-status
# โ OFAC SDN: 782 wallets, 19086 names; source=vile/ofac-sdn-list@...The compliance layer (the part that matters)
Four tools, called before an agent trusts or pays a counterparty:
Tool | When to call | Returns |
| Cheapest check. Call first. |
|
| Right before authorizing payment |
|
| Before trusting another agent |
|
| When a paid transaction went bad |
|
Where the data comes from (all public, free, no key)
Source | What | Refresh |
vile/ofac-sdn-list (GitHub releases) | 782 multi-chain crypto addresses (ETH/USDT/TRX/XBT/...) | daily |
US Treasury OFAC | 19,086 sanctioned individuals & entities | as published |
Embargoed jurisdictions set | 16 ISO-2 codes under comprehensive OFAC/UN/EU sanctions | tracked manually |
Lists are cached locally (~/.agentmail/cache/, 24h TTL) and refresh from source. If the network is down, a stale cache is used and status() reports degraded: true so you know screening is against older data rather than failing silently.
Providers (swappable backend)
AGENTMAIL_COMPLIANCE_PROVIDER=osint โ default, real OFAC data, free
AGENTMAIL_COMPLIANCE_PROVIDER=mock โ rule-based, for offline tests
AGENTMAIL_COMPLIANCE_PROVIDER=paid โ ComplyAdvantage passthrough (roadmap)The osint provider does exact + token-subset name matching, exact case-insensitive wallet matching, and ISO-2 country matching. Every match carries a confidence so you can decide how hard to block.
The other two layers (verification toolkit)
Email โ a disposable inbox an agent can use to sign up and receive OTP/magic-link verifications (backed by Mail.tm). create_inbox() โ address โ fetch_code() โ OTP.
SMS โ a rentable phone number an agent can use for phone/SMS verification. Mock provider works with no key (for dev); AGENTMAIL_SMS_PROVIDER=fivesim AGENTMAIL_FIVESIM_KEY=... goes live with real numbers.
Both share an otp.py extraction brain (regex for codes + magic links) so email and SMS produce the same {code, link} shape.
Self-host vs. hosted
Self-host is fully functional and free โ that's what this repo is. Run the MCP server locally or the HTTP API on your own box, screen against real OFAC data, never pay a cent.
Hosted API (roadmap) is for when you don't want to keep a server up, keep lists fresh, or keep a 24/7 uptime: a managed endpoint with API-key auth, rate limits, and an audit log of every screen (the thing regulators/investors ask for). Dev tier ~$19/mo. This README updates when it ships.
Roadmap
Email inbox (Mail.tm) + SMS/OTP (mock/5sim/twilio) + OTP extraction
Compliance layer โ real OFAC data (osint provider): 782 wallets + 19,086 names
MCP server (10 tools) + HTTP API + CLI
Hosted API with API-key auth + rate limiting (Fly.io)
Audit log (tamper-evident screen history โ the enterprise wedge)
EU + UN consolidated lists (osint provider, phase 2)
Paid provider: ComplyAdvantage passthrough (enterprise)
x402 per-call billing (when agents pay themselves)
Design notes (honest)
The compliance layer has the real moat. Email/SMS are plumbing a platform could swallow. Sanctions screening tied to agent-transaction history builds a dataset nobody else has, and per-jurisdiction rules are something the big infra players explicitly avoid.
Self-host is the free tier, not a trap. The value you pay for (eventually) is not the data โ it's uptime, freshness, and the audit trail. The data is and will stay public.
5sim numbers are shared-after-release. Fine for receiving an OTP, never for 2FA on accounts you intend to keep.
License
MIT โ see LICENSE.
Contributing
Issues and PRs welcome. If you're using agentmail in production, I'd love to hear what for.
This server cannot be installed
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/kindrat86/agentmail'
If you have feedback or need assistance with the MCP directory API, please join our Discord server