MCP Mailtrap Server
June 1, 2026 · View on GitHub
MCP Mailtrap Server
An MCP server that provides tools for sending and testing in sandbox via Mailtrap.
Prerequisites
Before using this MCP server, you need to:
- Create a Mailtrap account
- Verify your domain
- Get your API token from Mailtrap API settings
- Get your Account ID from Mailtrap account management
Required Environment Variables:
MAILTRAP_API_TOKEN- Required for all functionalityMAILTRAP_ACCOUNT_ID- Required for templates, stats, email logs, sandbox list/show, and sending domains. Optional only for send-email and send-sandbox-email.
Optional (can be passed as tool parameters instead):
DEFAULT_FROM_EMAIL- Default sender email whenfromis not provided to send-email or send-sandbox-email. Enables switching sender per call via thefromparameter.MAILTRAP_TEST_INBOX_ID- Default test inbox ID for sandbox tools whentest_inbox_idis not provided. Enables switching between inboxes per call via thetest_inbox_idparameter.MAILTRAP_SANDBOX_ID- Default sandbox ID for sandbox tools whensandbox_idis not provided. Enables switching between sandboxes per call via thesandbox_idparameter.MAILTRAP_ORGANIZATION_ID- Required for organization tools (list-sub-accounts,create-sub-account).MAILTRAP_ORGANIZATION_API_TOKEN- Organization-scoped API token. Required for organization tools (separate fromMAILTRAP_API_TOKEN).
Quick Install
Smithery CLI
Smithery is a registry installer and manager for MCP servers that works with all AI clients.
npx @smithery/cli install mailtrap
Smithery automatically handles client configuration and provides an interactive setup process. It's the easiest way to get started with MCP servers locally.
Setup
Claude Desktop
Use MCPB to install the Mailtrap server. You can find those files in Releases.
Download .MCPB file and open it. If you have Claude Desktop - it will open it and suggest to configure.
Claude Desktop or Cursor
Add the following configuration:
{
"mcpServers": {
"mailtrap": {
"command": "npx",
"args": ["-y", "mcp-mailtrap"],
"env": {
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
If you are using asdf for managing Node.js you must use absolute path to executable (example for Mac)
{
"mcpServers": {
"mailtrap": {
"command": "/Users/<username>/.asdf/shims/npx",
"args": ["-y", "mcp-mailtrap"],
"env": {
"PATH": "/Users/<username>/.asdf/shims:/usr/bin:/bin",
"ASDF_DIR": "/opt/homebrew/opt/asdf/libexec",
"ASDF_DATA_DIR": "/Users/<username>/.asdf",
"ASDF_NODEJS_VERSION": "20.6.1",
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
Claude Desktop config file location
Mac: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Cursor config file location
Mac: ~/.cursor/mcp.json
Windows: %USERPROFILE%\.cursor\mcp.json
VS Code
Manually changing config
Run in Command Palette: Preferences: Open User Settings (JSON)
Then, in the settings file, add the following configuration:
{
"mcp": {
"servers": {
"mailtrap": {
"command": "npx",
"args": ["-y", "mcp-mailtrap"],
"env": {
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
}
Tip
Don't forget to restart your MCP server after changing the "env" section.
MCP Bundle (MCPB)
For easy installation in hosts that support MCP Bundles, you can distribute an .mcpb bundle file.
# Build TypeScript and pack the MCPB bundle
npm run mcpb:pack
# Inspect bundle metadata
npm run mcpb:info
# Sign the bundle for distribution (optional)
npm run mcpb:sign
This creates mailtrap-mcp.mcpb using the repository manifest.json and built artifacts in dist/.
Usage
Once configured, you can ask agent to send emails and manage templates, for example:
Email Sending Operations:
- "Send an email to john.doe@example.com with the subject 'Meeting Tomorrow' and a friendly reminder about our upcoming meeting."
- "Email sarah@example.com about the project update, and CC the team at team@example.com"
- "Send the welcome template (uuid
b81aabcd-1a1e-41cf-91b6-eca0254b3d96) to new@example.com with variables{ name: 'Alex' }" - "Send a sandbox email to test@example.com with subject 'Test Template' to preview how our welcome email looks"
Email Logs (debug delivery):
- "List my recent sent email logs"
- "Show email logs for emails sent to user@example.com"
- "Get the email log message for ID abc-123-uuid to check delivery status"
Sending Statistics:
- "Get sending stats for January 2025"
- "Show delivery rates broken down by domain for last month"
- "What are my email stats by category from 2025-01-01 to 2025-01-31?"
Sandbox Operations:
- "Get all messages from my sandbox inbox"
- "Show me the first page of sandbox messages"
- "Search for messages containing 'test' in my sandbox inbox"
- "Show me the details of sandbox message with ID 5159037506"
Template Operations:
- "List all email templates in my Mailtrap account"
- "Create a new email template called 'Welcome Email' with subject 'Welcome to our platform!'"
- "Update the template with ID 12345 to change the subject to 'Updated Welcome Message'"
- "Delete the template with ID 67890"
Sending Domains:
- "List my sending domains"
- "Get sending domain with ID 3938"
- "Create a sending domain for example.com"
- "Delete sending domain 3938"
- "Get sending domain 3938 with DNS setup instructions"
Available Tools
send-email
Sends a transactional email through Mailtrap. Supports two mutually exclusive modes — inline content (subject + text/html) or template-based (template_uuid).
Parameters:
from(optional): Sender as an email string or{ email, name? }. If not provided,DEFAULT_FROM_EMAILis used.to(optional): Recipient(s) — a single email/{ email, name? }or an array. Optional ifccorbccis provided; at least one ofto/cc/bccmust contain a recipient.cc(optional): Array of CC recipients (email strings or{ email, name? }each).bcc(optional): Array of BCC recipients (email strings or{ email, name? }each).subject(conditional): Email subject line. Required for inline sends; must be omitted whentemplate_uuidis set.text(conditional): Email body text. Required (alongside or instead ofhtml) for inline sends; must be omitted whentemplate_uuidis set.html(conditional): HTML version of the email body. Required (alongside or instead oftext) for inline sends; must be omitted whentemplate_uuidis set.category(optional): Email category for tracking and analytics. Must be omitted whentemplate_uuidis set.template_uuid(optional): Use a Mailtrap email template instead of inline content. When set,subject/text/html/categorymust be omitted (per Mailtrap API).template_variables(optional): Object of variables substituted into the template referenced bytemplate_uuid. Only allowed together withtemplate_uuid.
batch-send-transactional-email
Sends a batch of transactional emails in one Mailtrap API call (default sending stream). Shared fields go on base; per-recipient overrides go in requests[]. Each request must include at least one recipient via to, cc, or bcc. Same inline-vs-template mutual exclusion as send-email — checked after merging base with each request.
Parameters:
base(optional): Object with fields shared across the batch.from(optional): Sender as an email string or{ email, name? }. Falls back toDEFAULT_FROM_EMAIL.reply_to(optional): Reply-to address.subject/text/html/category(optional, inline mode): Default content for every request.template_uuid/template_variables(optional, template mode): Default template + variables. Mutually exclusive with the inline fields.custom_variables(optional): Default custom variables (string-valued).headers(optional): Default custom headers.
requests(required): Non-empty array of per-recipient messages. Each entry has:to(optional): Recipient(s) — string,{ email, name? }, or an array. Optional ifccorbccis provided; at least one ofto/cc/bccmust contain a recipient.cc,bcc,reply_to(optional).- Inline (
subject/text/html/category) or template (template_uuid/template_variables) overrides; any field omitted falls back to the matchingbasevalue. custom_variables,headers(optional).
batch-send-bulk-email
Sends a batch of bulk emails through Mailtrap's bulk-stream API. Same base + requests[] shape, validation, and inline-vs-template rules as batch-send-transactional-email — the only difference is that this tool routes the call through the bulk endpoint instead of the transactional one. See the parameters above.
list-email-logs
Lists sent email logs (delivery history) with optional pagination and filters. Use to debug delivery issues from the IDE.
Parameters:
search_after(optional): Pagination cursor from the previous response'snext_page_cursorsent_after(optional): ISO 8601 date/time; only logs sent after this timesent_before(optional): ISO 8601 date/time; only logs sent before this timefrom_email(optional): Filter by sender email; use withfrom_operator(default: ci_equal)to_email(optional): Filter by recipient email; use withto_operator(default: ci_equal)status(optional): Filter by delivery status: delivered, not_delivered, enqueued, opted_out; use withstatus_operator(default: equal)subject(optional): Filter by email subject; use withsubject_operator(default: ci_contain). Usesubject_operator: empty/not_empty to filter by presence of subject.sending_domain_id(optional): Filter by sending domain ID (number); use withsending_domain_id_operator(default: equal)sending_stream(optional): Filter by stream: transactional or bulk; use withsending_stream_operator(default: equal)events(optional): Filter by event type(s): delivery, open, click, bounce, spam, unsubscribe, soft_bounce, reject, suspension; use withevents_operator(include_event / not_include_event)clicks_count/opens_count(optional): Filter by click/open count; use with*_operator: equal, greater_than, less_thanclient_ip/sending_ip(optional): Filter by IP; use with*_operator: equal, not_equal, contain, not_containemail_service_provider_response(optional): Filter by provider response text; use with*_operator(ci_contain, etc.)email_service_provider(optional): Filter by provider (exact); use with*_operator: equal, not_equalrecipient_mx(optional): Filter by recipient MX; use withrecipient_mx_operator(ci_contain, etc.)category(optional): Filter by email category; use withcategory_operator: equal, not_equal
All parameters are optional.
get-email-log-message
Gets a single email log message by ID (UUID): a readable summary (from, to, subject, sent time, status, category, stream, engagement, delivery context), then detailed event history. Optionally, with include_content: true, you can also load and show the message body (HTML and plain text) when Mailtrap exposes a raw message URL.
Parameters:
message_id(required): UUID of the email log message (from send response or list-email-logs). Uselist-email-logsto find message IDs.include_content(optional): Whentrue, fetches the raw EML (ifraw_message_urlis available) and appends parsed HTML and plain-text body sections, similar to show-sandbox-email-message.
get-sending-stats
Get email sending statistics (delivery, bounce, open, click, spam rates) for a date range. Optionally break down by domain, category, email service provider, or date. Check delivery rates without leaving the editor.
Parameters:
start_date(required): Start date for the stats range (YYYY-MM-DD)end_date(required): End date for the stats range (YYYY-MM-DD)breakdown(optional): How to break down the stats:aggregated(default),by_domain,by_category,by_email_service_provider, orby_datesending_domain_ids(optional): Limit results to these sending domain IDs (array of integers)sending_streams(optional): Limit totransactionaland/orbulk(array of strings)categories(optional): Limit to these email categories (array of strings)email_service_providers(optional): Limit to these providers, e.g. Google, Yahoo, Outlook (array of strings)
create-template
Creates a new email template in your Mailtrap account.
Parameters:
name(required): Name of the templatesubject(required): Email subject linehtml(ortextis required): HTML content of the templatetext(orhtmlis required): Plain text version of the templatecategory(optional): Template category (defaults to "General")
list-templates
Lists all email templates in your Mailtrap account.
Parameters:
- No parameters required
get-template
Get a single email template by ID, including subject, category, and HTML/text body.
Parameters:
template_id(required): ID of the template to fetch
update-template
Updates an existing email template.
Parameters:
template_id(required): ID of the template to updatename(optional): New name for the templatesubject(optional): New email subject linehtml(optional): New HTML content of the templatetext(optional): New plain text version of the templatecategory(optional): New category for the template
Note
At least one updatable field (name, subject, html, text, or category) must be provided when calling update-template to perform an update.
delete-template
Deletes an existing email template.
Parameters:
template_id(required): ID of the template to delete
send-sandbox-email
Sends an email to your Mailtrap test inbox for development and testing purposes. This is perfect for testing email templates without sending emails to real recipients. Supports the same two modes as send-email — inline content or template-based (template_uuid).
Parameters:
test_inbox_id(optional): Mailtrap test inbox ID. Required unlessMAILTRAP_TEST_INBOX_IDis set; pass per call to target a specific inbox.from(optional): Sender as an email string or{ email, name? }. If not provided,DEFAULT_FROM_EMAILis used.to(optional): Recipients as a comma-separated string, or an array of email strings /{ email, name? }objects. Optional ifccorbccis provided; at least one ofto/cc/bccmust contain a recipient.cc(optional): Array of CC recipients (email strings or{ email, name? }each).bcc(optional): Array of BCC recipients (email strings or{ email, name? }each).subject(conditional): Email subject line. Required for inline sends; must be omitted whentemplate_uuidis set.text(conditional): Email body text. Required (alongside or instead ofhtml) for inline sends; must be omitted whentemplate_uuidis set.html(conditional): HTML version of the email body. Required (alongside or instead oftext) for inline sends; must be omitted whentemplate_uuidis set.category(optional): Email category for tracking. Must be omitted whentemplate_uuidis set.template_uuid(optional): Use a Mailtrap email template instead of inline content. When set,subject/text/html/categorymust be omitted.template_variables(optional): Object of variables substituted into the template referenced bytemplate_uuid. Only allowed together withtemplate_uuid.
Note
For sandbox tools, provide test_inbox_id in the tool call or set the MAILTRAP_TEST_INBOX_ID environment variable. You can switch between inboxes per call by passing test_inbox_id.
get-sandbox-messages
Retrieves a list of messages from your Mailtrap test inbox. Useful for checking what emails have been received in your sandbox during testing.
Parameters:
page(optional): Page number for pagination (minimum: 1)last_id(optional): Pagination using last message ID. Returns messages after the specified message ID (minimum: 1)search(optional): Search query to filter messages
Note
All parameters are optional. If none are provided, the first page of messages from the inbox will be returned. Use page for traditional pagination, last_id for cursor-based pagination, or search to filter messages by content.
show-sandbox-email-message
Shows detailed information and content of a specific email message from your Mailtrap test inbox, including HTML and text body content.
Parameters:
message_id(required): ID of the sandbox email message to retrieve
Note
Use get-sandbox-messages first to get the list of messages and their IDs, then use this tool to view the full content of a specific message.
get-sandbox-project
Get a sandbox project by ID, including its inboxes and email counts.
Parameters:
project_id(required): ID of the project to fetch
update-sandbox-project
Rename an existing sandbox project.
Parameters:
project_id(required): ID of the project to updatename(required): New name for the project (2–100 characters)
list-sandboxes
List every sandbox accessible to the API token across all projects.
Parameters:
- No parameters required
mark-sandbox-as-read
Mark all messages in a sandbox as read.
Parameters:
sandbox_id(required): ID of the sandbox to act on
reset-sandbox-credentials
Reset the SMTP credentials for a sandbox. Returns the new username/password.
Parameters:
sandbox_id(required): ID of the sandbox to act on
enable-sandbox-email-address
Enable the receive-by-email address for a sandbox (turns on the Mailtrap address that delivers messages to the sandbox via SMTP).
Parameters:
sandbox_id(required): ID of the sandbox to act on
reset-sandbox-email-address
Generate a new receive-by-email address for a sandbox.
Parameters:
sandbox_id(required): ID of the sandbox to act on
forward-sandbox-message
Forward a sandbox message to an external email address. Counts against your monthly forwarding quota.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message to forwardemail(required): Email address to forward the message to
update-sandbox-message
Mark a sandbox message as read or unread.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message to updateis_read(required):truemarks as read,falsemarks as unread
delete-sandbox-message
Delete a single sandbox message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message to delete
get-sandbox-message-spam-score
Get the SpamAssassin spam report for a sandbox message (score, rules, full report). Standalone alternative to include_spam_report: true on show-sandbox-email-message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-html-analysis
Get the HTML analysis report for a sandbox message (client compatibility scores, problematic elements). Standalone alternative to include_html_analysis: true on show-sandbox-email-message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-headers
Get the parsed mail headers for a sandbox message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-html
Get the rendered HTML body of a sandbox message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-text
Get the plain-text body of a sandbox message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-raw
Get the raw, MIME-formatted message (headers + body) for a sandbox message.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-eml
Get the message rendered as an EML file payload (suitable for attaching to a ticket or importing into another mail client).
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-message-html-source
Get the unrendered HTML source of a sandbox message (HTML before any Mailtrap-side transformations like CID-link rewrites).
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
list-sandbox-attachments
List all attachments on a sandbox message (filename, content type, size, download path).
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message
get-sandbox-attachment
Get metadata and download URL for a single attachment.
Parameters:
sandbox_id(optional): Sandbox ID. Falls back toMAILTRAP_SANDBOX_ID.message_id(required): ID of the sandbox message that contains the attachmentattachment_id(required): ID of the attachment to fetch
list-sending-domains
List sending domains and their DNS verification status.
Parameters:
- No parameters required
get-sending-domain
Get a sending domain by ID and its verification status (including DNS records). Optionally include DNS setup instructions by setting include_setup_instructions to true.
Parameters:
sending_domain_id(required): Sending domain IDinclude_setup_instructions(optional): Iftrue, append DNS setup instructions to the response. Default:false
create-sending-domain
Create a new sending domain. After creation, add DNS records to verify the domain (use get-sending-domain with include_setup_instructions: true to see the records).
Parameters:
domain_name(required): Domain name (e.g. example.com)
delete-sending-domain
Delete a sending domain.
Parameters:
sending_domain_id(required): Sending domain ID to delete
send-sending-domain-setup-instructions
Email DNS setup instructions for a sending domain to a given address. Useful for forwarding DNS records to a DevOps teammate.
Parameters:
sending_domain_id(required): Sending domain IDemail(required): Email address to send DNS setup instructions to
list-suppressions
List or search suppressions (hard bounces, spam complaints, unsubscriptions, manual imports). Returns up to 1000 results per call.
Parameters:
email(optional): Email filter. Returns only suppressions matching this address.
delete-suppression
Delete a suppression by ID. Mailtrap will resume delivery to this email unless it gets suppressed again.
Parameters:
suppression_id(required): ID of the suppression to delete
list-webhooks
List all webhooks configured for the account. Returns the full webhook records as JSON.
Parameters:
- No parameters required
get-webhook
Get a single webhook by ID. Returns the full webhook record as JSON. Note: signing_secret is not returned here — it is only available in the response from create-webhook.
Parameters:
webhook_id(required): ID of the webhook to fetch
create-webhook
Create a webhook. The response includes a signing_secret for verifying webhook payload signatures — this secret is returned only on creation, so store it now. If you lose it, recreate the webhook.
Parameters:
url(required): URL Mailtrap will POST webhook events towebhook_type(required):"email_sending"or"audit_log"active(optional, boolean): defaults totruepayload_format(optional):"json"or"jsonlines". Defaults to"json"sending_stream(optional,email_sendingonly):"transactional"or"bulk"event_types(optional,email_sendingonly): array ofdelivery,soft_bounce,bounce,suspension,unsubscribe,open,spam_complaint,click,rejectdomain_id(optional,email_sendingonly): sending domain ID to scope this webhook to
update-webhook
Update a webhook's mutable fields. webhook_type, sending_stream, and domain_id cannot be changed after creation — recreate the webhook if you need to change those.
Parameters:
webhook_id(required): ID of the webhook to updateurl(optional): New webhook URLactive(optional, boolean): Enable or disable the webhookpayload_format(optional):"json"or"jsonlines"event_types(optional,email_sendingonly): array ofdelivery,soft_bounce,bounce,suspension,unsubscribe,open,spam_complaint,click,reject
delete-webhook
Permanently delete a webhook by ID. Returns the deleted webhook record.
Parameters:
webhook_id(required): ID of the webhook to delete
get-contact
Get a contact by ID or email. Returns the full contact record (list memberships, status, custom fields).
Parameters:
contact_identifier(required): Contact ID or email address
create-contact
Create a new contact.
Parameters:
email(required): Email addressfields(optional): Custom field values keyed by merge tag (e.g.first_name). String, number, or boolean valueslist_ids(optional): IDs of contact lists to subscribe this contact tounsubscribed(optional, boolean): Create the contact inunsubscribedstatus
update-contact
Update an existing contact identified by ID or email. list_ids replaces the contact's full membership set; list_ids_included/list_ids_excluded add/remove without disturbing the rest.
Parameters:
contact_identifier(required): Contact ID or emailemail(optional): New email addressfields(optional): Custom field values keyed by merge taglist_ids(optional): Replace membership set with this exact listlist_ids_included(optional): List IDs to add (additive)list_ids_excluded(optional): List IDs to removeunsubscribed(optional, boolean): Set tounsubscribed(true) orsubscribed(false)
delete-contact
Permanently delete a contact by ID or email. Returns the deleted contact record when the API responds with one; otherwise returns a confirmation payload.
Parameters:
contact_identifier(required): Contact ID or email
create-contact-event
Record a contact event against a contact (by ID or email). Used to trigger contact-list automations.
Parameters:
contact_identifier(required): Contact ID or emailname(required): Event name (matches automation triggers)params(required): Object of arbitrary key/value pairs. Values may be string, number, boolean, or null
list-contact-lists
List all contact lists for the account.
Parameters:
- No parameters required
get-contact-list
Get a contact list by ID.
Parameters:
list_id(required): ID of the contact list to fetch
create-contact-list
Create a new contact list.
Parameters:
name(required): Name for the new list
update-contact-list
Rename an existing contact list.
Parameters:
list_id(required): ID of the contact listname(required): New name for the list
delete-contact-list
Permanently delete a contact list by ID.
Parameters:
list_id(required): ID of the contact list to delete
list-contact-fields
List all contact field definitions for the account.
Parameters:
- No parameters required
get-contact-field
Get a contact field definition by ID.
Parameters:
field_id(required): ID of the contact field
create-contact-field
Create a new contact field definition. merge_tag must be unique within the account and is used as the placeholder name in template variables.
Parameters:
name(required): Display name (e.g. "First Name")merge_tag(required): Unique placeholder name (e.g.first_name)data_type(required): One oftext,number,boolean,date
update-contact-field
Update a contact field definition. Any combination of name, merge_tag, and data_type can be changed.
Parameters:
field_id(required): ID of the contact fieldname(optional): New display namemerge_tag(optional): New merge tag (must remain unique)data_type(optional): One oftext,number,boolean,date
delete-contact-field
Permanently delete a contact field definition by ID.
Parameters:
field_id(required): ID of the contact field to delete
create-contact-import
Bulk import contacts. Returns an import job record; poll its status with get-contact-import.
Parameters:
contacts(required): Array of contact entries. Each entry needs:email(required): Contact email addressfields(optional): Custom field values keyed by merge tag (string or number values)list_ids_included(optional): List IDs to add the contact tolist_ids_excluded(optional): List IDs to remove the contact from
get-contact-import
Get the status of a contact import job (created/started/finished/failed) with created/updated/over-limit counts.
Parameters:
import_id(required): ID of the contact import job
create-contact-export
Export contacts matching a set of AND-combined filters. Returns an export job record; poll status with get-contact-export to retrieve the download URL once status is finished.
Parameters:
filters(required): Array of filter objects. Each has:name(required): Field to filter on (list_id,subscription_status,email, etc.)operator(required): One ofequal,not_equal,contains,not_contains,is_empty,is_not_emptyvalue(required): Comparison value (string, number, boolean, or array)
get-contact-export
Get the status of a contact export job. Once status is finished, the url field holds the CSV download link.
Parameters:
export_id(required): ID of the contact export job
list-accounts
List Mailtrap accounts the current API token can access, with each account's access levels.
Parameters:
- No parameters required
get-billing-usage
Get the current billing cycle usage for the account: sending and testing plans, limits, and current counts.
Parameters:
- No parameters required
list-account-accesses
List account accesses (users, invites, API tokens) for the account. Optional filters narrow the result to specific resources. Requires account admin/owner permissions.
Parameters:
domain_uuids(optional): Filter by sending domain UUIDs (array of strings)inbox_ids(optional): Filter by sandbox inbox IDs (array of strings)project_ids(optional): Filter by sandbox project IDs (array of strings)
remove-account-access
Remove an account access by ID. For User specifiers this revokes their permissions; for Invite or ApiToken specifiers it removes the specifier entirely. Requires admin/owner.
Parameters:
account_access_id(required): ID of the access record to remove
get-permission-resources
Get all resources (inboxes, projects, domains, billing, account) to which the API token has admin access, nested by hierarchy.
Parameters:
- No parameters required
bulk-update-permissions
Bulk create, update, or destroy permissions for a single account access. Existing (resource_type, resource_id) pairs are updated; new ones are created. Set destroy: true on an entry to remove it.
Parameters:
account_access_id(required): Target account access IDpermissions(required): Array of permission entries. Each has:resource_id(required): Resource ID (number or string)resource_type(required): One ofaccount,project,inbox,domain,billingaccess_level(optional):admin/100orviewer/10destroy(optional, boolean): When true, removes this permission instead of creating/updating it
list-api-tokens
List all API tokens for the account.
Parameters:
- No parameters required
create-api-token
Create a new API token. The response includes the secret token value — this is the only time the full token is returned, so store it immediately. If you lose it, recreate the token.
Parameters:
name(required): Display name for the tokenresources(optional): Array of resource permissions to scope the token to. Each entry has:resource_type(required): One ofaccount,project,inbox,domain,billingresource_id(required): ID of the resourceaccess_level(required):100(admin) or10(viewer)
get-api-token
Get an API token by ID. Returns metadata only — the secret token value is not returned here (only from create-api-token / reset-api-token).
Parameters:
api_token_id(required): ID of the API token
reset-api-token
Reset (rotate) an API token by ID. The response includes the new secret token value — returned only on this call, so store it immediately. The previous token is invalidated.
Parameters:
api_token_id(required): ID of the API token to reset
delete-api-token
Permanently delete an API token by ID. The token can no longer authenticate after deletion.
Parameters:
api_token_id(required): ID of the API token to delete
list-sub-accounts
List sub-accounts in the organization. Requires MAILTRAP_ORGANIZATION_ID env var and sub-account management permissions.
Parameters:
- No parameters required
create-sub-account
Create a new sub-account under the organization. Requires MAILTRAP_ORGANIZATION_ID env var and sub-account management permissions.
Parameters:
name(required): Display name for the new sub-account
Development
- Clone the repository:
git clone https://github.com/mailtrap/mailtrap-mcp.git
cd mailtrap-mcp
- Install dependencies:
npm install
Configuration with Claude Desktop or Cursor
Tip
See the location of the config file in the Setup section.
Add the following configuration:
{
"mcpServers": {
"mailtrap": {
"command": "node",
"args": ["/path/to/mailtrap-mcp/dist/index.js"],
"env": {
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
If you are using asdf for managing Node.js you should use absolute path to executable:
(example for Mac)
{
"mcpServers": {
"mailtrap": {
"command": "/Users/<username>/.asdf/shims/node",
"args": ["/path/to/mailtrap-mcp/dist/index.js"],
"env": {
"PATH": "/Users/<username>/.asdf/shims:/usr/bin:/bin",
"ASDF_DIR": "/opt/homebrew/opt/asdf/libexec",
"ASDF_DATA_DIR": "/Users/<username>/.asdf",
"ASDF_NODEJS_VERSION": "20.6.1",
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
VS Code
Tip
See the location of the config file in the Setup section.
{
"mcp": {
"servers": {
"mailtrap": {
"command": "node",
"args": ["/path/to/mailtrap-mcp/dist/index.js"],
"env": {
"MAILTRAP_API_TOKEN": "your_mailtrap_api_token",
"DEFAULT_FROM_EMAIL": "your_sender@example.com",
"MAILTRAP_ACCOUNT_ID": "your_account_id",
"MAILTRAP_TEST_INBOX_ID": "your_test_inbox_id"
}
}
}
}
}
Testing
Running tools against real Mailtrap
There are two ways to exercise a tool end-to-end against a real Mailtrap account: the MCP Inspector browser UI for interactive exploration, or its CLI mode for one-shot calls from the shell.
Both require the bundle to be built first:
npm run build
and MAILTRAP_API_TOKEN + MAILTRAP_ACCOUNT_ID exported in your shell (the mcp:cli script forwards both to the spawned server).
Browser UI
npm run dev
The Inspector prints a URL like http://localhost:6274. Open it, switch to the Tools tab, pick a tool (e.g. get-template), fill the parameters as JSON, and hit Run. The Mailtrap response appears in the panel below.
CLI
For one-shot calls without the UI, use npm run mcp:cli. Pass the Inspector's CLI flags after -- so npm forwards them verbatim:
# List all tools
npm run mcp:cli -- --method tools/list
# Call a tool — flags after the `--`
npm run mcp:cli -- \
--method tools/call \
--tool-name get-template \
--tool-arg template_id=12345
# Multiple --tool-arg flags for tools with several params
npm run mcp:cli -- \
--method tools/call \
--tool-name send-sending-domain-setup-instructions \
--tool-arg sending_domain_id=3938 \
--tool-arg email=devops@example.com
Running the MCPB Server
# Run the MCPB server directly
node dist/mcpb-server.js
# Or use the provided binary
mailtrap-mcpb-server
Tip
For development with the MCP Inspector:
npm run dev:mcpb
Error Handling
This server uses structured error handling aligned with MCP conventions:
VALIDATION_ERROR: Input validation failuresCONFIGURATION_ERROR: Missing or invalid configurationEXECUTION_ERROR: Runtime execution errorsTIMEOUT: Operation timeout (30 seconds default)
Errors include actionable messages and are logged in structured form.
Security
- Input validated via Zod schemas
- Environment variables handled securely
- Timeout protection on operations (30 seconds)
- Sensitive details sanitized in error output
Logging
Structured JSON logs with levels: INFO, WARN, ERROR, DEBUG.
Enable debug logging by setting DEBUG=true.
# Example: enable debug logging
DEBUG=true node dist/mcpb-server.js
Important: The server writes logs to stderr so stdout remains reserved for JSON-RPC frames. This prevents hosts from encountering JSON parsing errors due to interleaved logs.
Log analysis example using jq:
# Filter error logs
node dist/mcpb-server.js 2>&1 | jq 'select(.level == "error")'
# Filter debug logs
node dist/mcpb-server.js 2>&1 | jq 'select(.level == "debug")'
Troubleshooting
Common issues:
- Missing API Token: ensure
MAILTRAP_API_TOKENis set - Sandbox not working: provide
test_inbox_idin the tool call or setMAILTRAP_TEST_INBOX_IDenv - Timeout errors: check network connectivity and Mailtrap API status
- Validation errors: ensure all required fields are provided
Contributing
Bug reports and pull requests are welcome on GitHub. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
License
The package is available as open source under the terms of the MIT License.
Code of Conduct
Everyone interacting in the Mailtrap project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.