Skip to main content

MCP server for Migadu email hosting — manage domains, mailboxes, aliases, identities, forwardings, and rewrites.

Project description

Migadu MCP Server

PyPI version Python 3.13+ License: MIT

Control your Migadu email hosting from AI assistants via the Model Context Protocol.

What is Migadu?

Migadu is a Swiss email host that prices on actual usage instead of mailbox count, with standard SMTP/IMAP/POP3 and no lock-in.

What this does

Covers the full Migadu API surface as MCP tools:

  • Domains — create, update, activate, DNS records, diagnostics, usage
  • Mailboxes — CRUD, autoresponders, password resets
  • Aliases — forwarding rules without a mailbox behind them
  • Identities — send-as addresses on a mailbox
  • Forwardings — external delivery copies with confirmation flow
  • Rewrites — pattern-based routing rules

Setup

Get an API key at Migadu Admin → My Account → API Keys.

Add to your MCP client config (e.g. Claude Desktop, ~/.claude.json, etc.):

{
  "mcpServers": {
    "migadu": {
      "command": "uvx",
      "args": ["migadu-mcp"],
      "env": {
        "MIGADU_EMAIL": "you@example.com",
        "MIGADU_API_KEY": "your-api-key",
        "MIGADU_DOMAIN": "example.com"
      }
    }
  }
}

Or via the Claude Code CLI:

claude mcp add migadu \
  --env MIGADU_EMAIL=you@example.com \
  --env MIGADU_API_KEY=your-api-key \
  --env MIGADU_DOMAIN=example.com \
  -- uvx migadu-mcp

MIGADU_DOMAIN is optional. It's the default domain used by tools like list_mailboxes when you don't pass one explicitly. Skip it if you manage multiple domains and prefer to pass domain on every call.

Example usage

Once configured, ask your AI assistant things like:

  • "Onboard a new domain acme.example — walk me through DNS setup and activation"
  • "Create mailboxes for alice@acme.example and bob@acme.example"
  • "Set up support@acme.example as an alias to both Alice and Bob"
  • "Configure an autoresponder on vacation@acme.example until January 15th"
  • "Delete the mailboxes for everyone who left: list of addresses..."

Three built-in prompts are registered to scaffold common workflows: mailbox_creation_wizard, bulk_operation_planner, domain_onboarding.

Tools

Domain

list_domains, get_domain, create_domain, update_domain, get_domain_records, get_domain_diagnostics, activate_domain, get_domain_usage

Mailbox

list_mailboxes, get_mailbox, create_mailbox, update_mailbox, delete_mailbox, reset_mailbox_password, set_autoresponder

Alias

list_aliases, get_alias, create_alias, update_alias, delete_alias

Identity

list_identities, get_identity, create_identity, update_identity, delete_identity

Forwarding

list_forwardings, get_forwarding, create_forwarding, update_forwarding, delete_forwarding

Rewrite

list_rewrites, get_rewrite, create_rewrite, update_rewrite, delete_rewrite

All mutation tools (create_*, update_*, delete_*, activate_*, set_autoresponder, reset_mailbox_password) accept a list[dict] of items and return a bulk-result envelope with per-item success/failure. A single-item list works too.

Resources

Read-only views addressable by URI:

  • domains:// — all domains on the account
  • domain://{name} — one domain's full config
  • domain-records://{name} — required DNS records for setup
  • domain-usage://{name} — message + storage metrics
  • mailboxes://{domain} — mailboxes for a domain
  • mailbox://{domain}/{local_part} — one mailbox
  • identities://{domain}/{mailbox} — identities on a mailbox
  • forwardings://{domain}/{mailbox} — forwardings on a mailbox
  • aliases://{domain} — aliases for a domain
  • rewrites://{domain} — rewrite rules for a domain

Notes

  • Migadu's API returns HTTP 500 on successful DELETE (known quirk). The client treats 200/204/404/500 as success on DELETE; other codes raise.
  • One long-lived httpx.AsyncClient per server process, closed on shutdown via FastMCP lifespan hook.
  • list_* tools pass responses through a static summarizer when they exceed ~2000 tokens, returning a count plus a sample instead of flooding context.

Development

git clone https://github.com/Michaelzag/migadu-mcp.git
cd migadu-mcp
uv sync --group dev

# Quality gates (same as CI)
uv run ruff format --check .
uv run ruff check migadu_mcp/ tests/
uv run ty check migadu_mcp/
uv run pytest
uv run bandit -r migadu_mcp/

Tests use respx to mock the Migadu API — no credentials needed. Integration tests (behind @pytest.mark.integration) hit the real API and are skipped by default.

License

MIT — see LICENSE.

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

migadu_mcp-3.6.1.tar.gz (56.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

migadu_mcp-3.6.1-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

Details for the file migadu_mcp-3.6.1.tar.gz.

File metadata

  • Download URL: migadu_mcp-3.6.1.tar.gz
  • Upload date:
  • Size: 56.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for migadu_mcp-3.6.1.tar.gz
Algorithm Hash digest
SHA256 a0d67429d68658b5a6e94fa7015a186ddadc6aa16d80501248ea397097b9a73f
MD5 71932586f6dc85d6161164e184f31095
BLAKE2b-256 b9d4457402d05959e7a1e5b8e54a9a8a7520b31115a38c16b529151584df3d3f

See more details on using hashes here.

Provenance

The following attestation bundles were made for migadu_mcp-3.6.1.tar.gz:

Publisher: main.yml on Michaelzag/migadu-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 migadu_mcp-3.6.1-py3-none-any.whl.

File metadata

  • Download URL: migadu_mcp-3.6.1-py3-none-any.whl
  • Upload date:
  • Size: 30.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for migadu_mcp-3.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 869f929e1d5acab5909082e15c3c129dd66c318419183d7ac92a85b246d43d72
MD5 be6bea81f56baa47509ebbbcb41ff2e5
BLAKE2b-256 78624746cbbea0abc2815e2c19b9bd92f8677e1c329c23e6fa9b4f1b33749331

See more details on using hashes here.

Provenance

The following attestation bundles were made for migadu_mcp-3.6.1-py3-none-any.whl:

Publisher: main.yml on Michaelzag/migadu-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