mailmodo-mcp
This is a TypeScript project that implements a Message Control Protocol (MCP) server for Mailmodo integration with Claude Desktop and other MCP supported client.
Prerequisites
- Node.js (v20 or higher recommended)
- npm (comes with Node.js)
Installation
- Clone the repository:
git clone https://github.com/mailmodo/mailmodo-mcp.git
cd mailmodo-mcp
- Install dependencies:
npm install
Building the Project
To compile the TypeScript code to JavaScript, run:
npm run build
This will create a dist directory containing the compiled JavaScript files.
Running the Project
After building, you can run the project using:
node dist/index.js
Or use the npm script:
npm start
Claude Desktop Configuration
Local Run from Code
To configure this project with Claude Desktop, add the following configuration to your Claude Desktop settings:
{
"mcpServers": {
"mailmodo": {
"command": "node",
"args": [
"/path/to/your/mailmodo-mcp/dist/index.js"
]
}
}
}
Run from docker image
{
"mcpServers": {
"mailmodo": {
"command": "docker",
"args": [
"run",
"--platform",
"linux/amd64",
"-i",
"--rm",
"-e",
"MAILMODO_API_KEY",
"avneesh001/mailmodo-mcp"
],
"env": {
"MAILMODO_API_KEY": "<GET MAILMODO KEY from https://manage.mailmodo.com/app/settings/apikey and insert here>"
}
}
}
}
Run from npx
{
"mcpServers": {
"mailmodo": {
"command": "npx",
"args": [
"-y",
"@mailmodo/mcp"
],
"env": {
"MAILMODO_API_KEY": "<GET MAILMODO KEY from https://manage.mailmodo.com/app/settings/apikey and insert here>"
}
}
}
}
Connect via Remote Server
{
"mcpServers": {
"mailmodo": {
"command": "npx",
"args": [
"-y",
"mcp-remote",
"https://mcp.app.mailmodo.com/mcp",
"--header",
"mmApiKey:${MAILMODO_API_KEY}"
],
"env": {
"MAILMODO_API_KEY": "<GET MAILMODO KEY from https://manage.mailmodo.com/app/settings/apikey and insert here>"
}
}
}
}
Make sure to adjust the file path in the args array to match your local project directory.
Development
To run the project in development mode with automatic recompilation:
- Install
ts-nodeandnodemonas dev dependencies:
npm install --save-dev ts-node nodemon
- Add a dev script to your package.json:
{
"scripts": {
"dev": "nodemon src/index.ts",
"build": "tsc",
"start": "node dist/index.js"
}
}
- Run the development server:
npm run dev
Project Structure
mailmodo-mcp/
├── src/ # TypeScript source files
├── dist/ # Compiled JavaScript files
├── package.json # Project dependencies and scripts
└── tsconfig.json # TypeScript configuration
Tools and Resources
The Mailmodo MCP server provides several tools and resources for interacting with Mailmodo’s functionality. Here’s a comprehensive list:
Resources
Mailmodo Templates (
mailmodo://templates)- Returns a list of all available email templates in JSON format
- MIME Type: application/json
Mailmodo Campaigns (
mailmodo://campaigns)- Returns a list of all campaigns in JSON format
- MIME Type: application/json
Mailmodo Contact Lists (
mailmodo://contact-lists)- Returns all contact lists in JSON format
- MIME Type: application/json
Tools
User Details
- Name:
userDetails - Description: Get all details of a contact
- Parameters:
email(string): Email address of the contact
- Name:
Campaign Report Tool
- Name:
MailmodoCampainReportTool - Description: Get campaign reports including open, click, and submission counts
- Parameters:
campaignId(UUID): ID of the campaignfromDate(YYYY-MM-DD): Start date for the reporttoDate(YYYY-MM-DD): End date for the report
- Name:
Current DateTime
- Name:
currentDateTime - Description: Get current date and time
- Parameters: None
- Name:
Send Event
- Name:
sendEvent - Description: Send custom events with email and event properties
- Parameters:
email(string): Contact’s email addressevent_name(string): Name of the eventts(number, optional): Timestampevent_properties(object, optional): Additional event properties
- Name:
Contact List Management
Add Contact to List
- Name:
addContactToList - Description: Add a single contact to a list
- Parameters:
email(string): Contact’s emaillistName(string): Name of the listdata(object, optional): Contact properties- Various optional fields for contact metadata
- Name:
Bulk Add Contacts
- Name:
addBulkContactToList - Description: Add multiple contacts to a list in a single operation
- Parameters:
listName(string): Name of the listvalues(array): Array of contact objects
- Name:
Remove Contact from List
- Name:
removeContactFromList - Description: Remove a contact from a specific list
- Parameters:
email(string): Contact’s emaillistName(string): Name of the list
- Name:
Contact Status Management
Unsubscribe Contact
- Name:
unsubscribeContact - Description: Unsubscribe or suppress a contact
- Parameters:
email(string): Contact’s email
- Name:
Resubscribe Contact
- Name:
resubscribeContact - Description: Resubscribe a previously unsubscribed contact
- Parameters:
email(string): Contact’s email
- Name:
Archive Contact
- Name:
archiveContact - Description: Permanently archive a contact
- Parameters:
email(string): Contact’s email
- Name:
Campaign Management
Send Email Campaign
- Name:
sendEmailToCampaign - Description: Trigger an email campaign with personalization
- Parameters:
campaignId(string): Campaign IDemail(string): Recipient’s email- Various optional parameters for customization
- Name:
Broadcast Campaign
- Name:
broadcastCampaignToList - Description: Trigger campaigns to an entire contact list
- Parameters:
campaignId(string): Campaign IDlistId(string): Target list ID- Optional parameters for campaign customization
- Name:
License
MIT License
Mailmodo Integration Server
Project Details
- mailmodo/mailmodo-mcp
- GNU General Public License v3.0
- Last Updated: 4/22/2025
Recomended MCP Servers
Play your favorite song without leaving Cursor
Playwright MCP fork that works with Cloudflare Browser Rendering
MCP server that integrates with Keycloak, allowing you to manage Keycloak users and realms through a standardized protocol....
It's like v0 but in your Cursor/WindSurf/Cline. 21st dev Magic MCP server for working with your frontend like...
Integration of Needle in modelcontextprotocol
MCP wrapper for Swagger/OpenAPI definitions
Mcp server for postgres





