BaseMail - Onchain Email for AI Agents on Base

📬 BaseMail - Onchain Email for AI Agents on Base. Get [email protected] linked to your Basename (.base.eth). SIWE wallet auth, no CAPTCHA, no passwords. Give your agent a verifiable email identity on Base Chain — register for services, send emails, and receive confirmations autonomously.

ติดตั้ง
$clawhub install basemail

📬 BaseMail - Onchain Email for AI Agents on Base

Your agent gets a real email address, linked to its onchain identity. No human needed.

TL;DR: Own a Basename (yourname.base.eth)? Get [email protected] instantly. Sign with your Base wallet, send emails autonomously.

Why BaseMail?

  • Built on Base Chain — Email identity tied to your onchain wallet on Base (Coinbase's L2)

  • Basename integration.base.eth holders get matching @basemail.ai addresses automatically

  • SIWE authentication — Sign-In with Ethereum, no passwords or CAPTCHA needed

  • Autonomous for AI agents — Register for services, submit forms, receive confirmations without human help

  • Verifiable identity — Your email is cryptographically linked to your Base wallet address

BaseMail gives AI agents verifiable email identities on Base Chain:

How it works

Base Wallet → SIWE Signature → BaseMail Registration → [email protected]
     ↑                                                        ↓
Basename (.base.eth)                              Send & receive email autonomously


🔐 Wallet Setup (Choose One)

If you already have a wallet, just set the env var — no private key stored to file:

export BASEMAIL_PRIVATE_KEY="0x..."
node scripts/register.js

✅ Safest method: private key exists only in memory.


Option B: Specify Wallet Path

Point to your existing private key file:

node scripts/register.js --wallet /path/to/your/private-key

✅ Uses your existing wallet, no copying.


Option C: Managed Mode (Beginners)

Let the skill generate and manage a wallet for you:

node scripts/setup.js --managed
node scripts/register.js

Always encrypted — Private key protected with AES-256-GCM - You'll set a password during setup (min 8 chars, must include letter + number) - Password required each time you use the wallet - Mnemonic displayed once for manual backup (never saved to file) - Password input is masked (hidden) in terminal


⚠️ Security Guidelines

  1. Never commit private keys to git

  2. Never share private keys or mnemonics publicly

  3. Never add ~/.basemail/ to version control

  4. Private key files should be chmod 600 (owner read/write only)

  5. Prefer environment variables (Option A) over file storage

  6. --wallet paths are validated: must be under $HOME, no traversal, max 1KB file size

  7. Private key format is validated (0x + 64 hex chars) before use

  8. Password input is masked in terminal (characters hidden)

  9. This skill only signs SIWE authentication messages — it never sends funds or on-chain transactions


# BaseMail - NEVER commit!
.basemail/
**/private-key.enc


🚀 Quick Start

1️⃣ Register


# Using environment variable
export BASEMAIL_PRIVATE_KEY="0x..."
node scripts/register.js

# Or with Basename
node scripts/register.js --basename yourname.base.eth

2️⃣ Send Email

node scripts/send.js "[email protected]" "Hello!" "Nice to meet you 🦞"

3️⃣ Check Inbox

node scripts/inbox.js              # List emails
node scripts/inbox.js <email_id>   # Read specific email


📦 Scripts

Script Purpose Needs Private Key
setup.js Show help
setup.js --managed Generate wallet (always encrypted)
register.js Register email address
send.js Send email ❌ (uses token)
inbox.js Check inbox ❌ (uses token)
audit.js View audit log

📍 File Locations

~/.basemail/
├── private-key.enc   # Encrypted private key (AES-256-GCM, chmod 600)
├── wallet.json       # Wallet info (public address only)
├── token.json        # Auth token (chmod 600)
└── audit.log         # Operation log (no sensitive data)


🎨 Get a Basename-Linked Email

Want [email protected] instead of [email protected]?

  1. Register a Basename (.base.eth) at https://www.base.org/names

  2. Link it: node scripts/register.js --basename yourname.base.eth

Your Basename is your onchain identity on Base — and BaseMail turns it into a working email address.


🔧 API Reference

Endpoint Method Purpose
/api/auth/start POST Start SIWE auth
/api/auth/verify POST Verify wallet signature
/api/register POST Register email
/api/register/upgrade PUT Upgrade to Basename
/api/send POST Send email
/api/inbox GET List inbox
/api/inbox/:id GET Read email content

Full docs: https://api.basemail.ai/api/docs



📝 Changelog

v1.8.0 (2026-02-18)

  • 📝 Enhanced description: emphasize Base Chain and Basename (.base.eth) integration

  • 📝 Added architecture diagram showing wallet → SIWE → email flow

  • 📝 Better explanation of onchain identity and verifiable email

  • 🔗 Added source repo and Base Chain links

v1.7.0 (2026-02-18)

  • 🔐 Security hardening (addresses ClawHub "Suspicious" classification):

    • Added OpenClaw metadata: declares BASEMAIL_PRIVATE_KEY in requires.env
    • Password input now masked in terminal (characters hidden as *)
    • Stronger password requirements: min 8 chars, must include letter + number
    • --wallet path validation: must be under $HOME, no .. traversal, max 1KB, regular file only
    • Private key format validation (0x + 64 hex chars) on all input sources
    • Removed --no-encrypt option — managed wallets are always encrypted
    • Mnemonic is displayed once and never saved to file (removed save-to-file prompt)
    • Removed legacy plaintext key file references
  • 📝 Added notes in metadata clarifying: this skill only signs SIWE messages, never sends funds

  • 📝 Updated security guidelines and file locations documentation

v1.4.0 (2026-02-08)

  • ✨ Better branding and descriptions

  • 📝 Full English documentation

v1.1.0 (2026-02-08)

  • 🔐 Security: opt-in private key storage

  • ✨ Support env var, path, auto-detect

  • 🔒 Encrypted storage option (--encrypt)

  • 📊 Audit logging

v1.6.0 (Security Update)

  • 🔐 Breaking: --managed now encrypts by default

  • 🔐 Removed auto-detection of external wallet paths (security improvement)

  • 🔐 Mnemonic no longer auto-saved; displayed once for manual backup

  • 📝 Updated documentation for clarity

v1.0.0

  • 🎉 Initial release