# Emailoctopus

```json
{
  "name": "Emailoctopus",
  "slug": "emailoctopus",
  "url": "https://composio.dev/toolkits/emailoctopus",
  "markdown_url": "https://composio.dev/toolkits/emailoctopus.md",
  "logo_url": "https://logos.composio.dev/api/emailoctopus",
  "categories": [
    "marketing & social media"
  ],
  "is_composio_managed": false,
  "updated_at": "2026-05-12T10:10:16.645Z"
}
```

![Emailoctopus logo](https://logos.composio.dev/api/emailoctopus)

## Description

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Emailoctopus MCP or direct API to send campaigns, manage subscribers, build lists, and automate marketing—all through natural language.

## Summary

EmailOctopus is a straightforward email marketing platform for creating, sending, and analyzing campaigns. It helps you grow and engage your audience with affordable, easy-to-use tools.

## Categories

- marketing & social media

## Toolkit Details

- Tools: 20

## Images

- Logo: https://logos.composio.dev/api/emailoctopus

## Authentication

- **Api Key**
  - Type: `api_key`
  - Description: Api Key authentication for EmailOctopus.
  - Setup:
    - Configure Api Key credentials for EmailOctopus.
    - Use the credentials when creating an auth config in Composio.

## Suggested Prompts

- Add new subscribers to my newsletter list
- Unsubscribe a user from marketing emails
- List all recent email campaigns sent
- Delete a contact from a specific list

## Supported Tools

| Tool slug | Name | Description |
|---|---|---|
| `EMAILOCTOPUS_CREATE_CONTACT` | Create Contact | This tool creates a new contact in EmailOctopus. The tool will add a contact to a specified list with the provided information. |
| `EMAILOCTOPUS_CREATE_FIELD` | Create Field | Tool to create a new custom field on an EmailOctopus mailing list. Use when you need to add additional data fields beyond the default Email, First Name, and Last Name fields. |
| `EMAILOCTOPUS_CREATE_LIST` | Create List | Creates a new mailing list in EmailOctopus for organizing and managing email contacts. The list is created with default fields (Email address, First name, Last name) and can be used to add contacts, send campaigns, and track subscriber engagement. |
| `EMAILOCTOPUS_CREATE_TAG` | Create Tag | Tool to create a new tag on an EmailOctopus mailing list. Use when you need to add a new tag for contact segmentation and filtering purposes. |
| `EMAILOCTOPUS_DELETE_CONTACT` | Delete Contact | Permanently deletes a contact from a specified EmailOctopus list. This action is irreversible - once deleted, the contact and all associated data will be removed from the list. Use this for list management, honoring deletion requests, and data privacy compliance (e.g., GDPR right to erasure). |
| `EMAILOCTOPUS_DELETE_FIELD` | Delete Field | Permanently deletes a custom field from a specified EmailOctopus list. This action is irreversible - once deleted, the field and all associated data will be removed from the list. Use this for list customization and field management. |
| `EMAILOCTOPUS_DELETE_LIST` | Delete List | This tool allows you to delete an existing mailing list from your EmailOctopus account. Once a list is deleted, it cannot be recovered, and all contacts within the list will be permanently removed. Note: Lists can only be deleted if no contacts within the list have received an email in the last 7 days. |
| `EMAILOCTOPUS_DELETE_TAG` | Delete Tag | Tool to delete a tag from a mailing list in EmailOctopus. Use when you need to remove an existing tag that is no longer needed for contact organization or segmentation. |
| `EMAILOCTOPUS_GET_ALL_LISTS` | Get All Lists | This tool retrieves all the mailing lists associated with the EmailOctopus account. |
| `EMAILOCTOPUS_GET_CONTACT` | Get Contact | Tool to retrieve details of a specific contact from an EmailOctopus list. Use when you need to fetch contact information including email, fields, tags, and subscription status. |
| `EMAILOCTOPUS_GET_LIST` | Get List | Retrieves details of a specific mailing list by ID. Use when you need to fetch list information, including its name, fields, tags, contact counts, and opt-in settings. |
| `EMAILOCTOPUS_GET_RECENT_CAMPAIGNS` | Get Recent Campaigns | This tool retrieves a list of recent campaigns from the EmailOctopus account. |
| `EMAILOCTOPUS_LIST_CONTACTS` | List Contacts | Tool to retrieve contacts from an EmailOctopus list. Returns a paginated list of contacts with optional filtering by tag, status, and date ranges. |
| `EMAILOCTOPUS_LIST_TAGS` | List Tags | Tool to retrieve all tags from a mailing list. Use when you need to see what tags are available on a specific list for contact segmentation. |
| `EMAILOCTOPUS_UNSUBSCRIBE_CONTACT` | Unsubscribe Contact | Unsubscribes a contact from an EmailOctopus mailing list. This tool updates the contact's subscription status to 'unsubscribed', which stops them from receiving future emails from the specified list. The contact record is preserved but marked as unsubscribed. |
| `EMAILOCTOPUS_UPDATE_CONTACTS_BATCH` | Batch Update Contacts | Tool to update multiple contacts in an EmailOctopus list in a single batch operation. Use when you need to efficiently update multiple contacts at once with changes to their email, fields, status, or tags. |
| `EMAILOCTOPUS_UPDATE_FIELD` | Update Field | Updates an existing custom field on an EmailOctopus list including its label, tag, type, and fallback value. Use this action to modify field properties or rename field tags. Note that changing the tag will affect how the field is referenced in email templates. |
| `EMAILOCTOPUS_UPDATE_LIST` | Update List | Tool to update an existing mailing list's name in EmailOctopus. Use when you need to rename a list. |
| `EMAILOCTOPUS_UPDATE_TAG` | Update Tag | Tool to update an existing tag on a mailing list. Use when you need to rename a tag. |
| `EMAILOCTOPUS_UPSERT_CONTACT` | Create or Update Contact | Tool to create or update a contact in EmailOctopus. If the contact does not exist, it will be created. If the contact already exists, it will be updated. Use when you need to ensure a contact exists with specific information regardless of whether they're already in the list. |

## Supported Triggers

None listed.

## Installation and MCP Setup

### Path 1: SDK Installation

#### Path 1, Step 1: Install Composio

Install the Composio SDK
```python
pip install composio_openai
```

```typescript
npm install @composio/openai
```

#### Path 1, Step 2: Initialize Composio and Create Tool Router Session

Import and initialize Composio client, then create a Tool Router session
```python
from openai import OpenAI
from composio import Composio
from composio_openai import OpenAIResponsesProvider

composio = Composio(provider=OpenAIResponsesProvider())
openai = OpenAI()
session = composio.create(user_id='your-user-id')
```

```typescript
import OpenAI from 'openai';
import { Composio } from '@composio/core';
import { OpenAIResponsesProvider } from '@composio/openai';

const composio = new Composio({
  provider: new OpenAIResponsesProvider(),
});
const openai = new OpenAI({});
const session = await composio.create('your-user-id');
```

#### Path 1, Step 3: Execute Emailoctopus Tools via Tool Router with Your Agent

Get tools from Tool Router session and execute Emailoctopus actions with your Agent
```python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'Create a new contact in the newsletter list'
  }]
)
result = composio.provider.handle_tool_calls(
  response=response,
  user_id='your-user-id'
)
print(result)
```

```typescript
const tools = session.tools;
const response = await openai.responses.create({
  model: 'gpt-4.1',
  tools: tools,
  input: [{
    role: 'user',
    content: 'Create a new contact in the newsletter list'
  }],
});
const result = await composio.provider.handleToolCalls(
  'your-user-id',
  response.output
);
console.log(result);
```

### Path 2: MCP Server Setup

#### Path 2, Step 1: Install Composio

Install the Composio SDK and Claude Agent SDK
```python
pip install composio claude-agent-sdk
```

```typescript
npm install @composio/core ai @ai-sdk/openai @ai-sdk/mcp
```

#### Path 2, Step 2: Create Tool Router Session

Initialize the Composio client and create a Tool Router session
```python
from composio import Composio
from claude_agent_sdk import ClaudeSDKClient, ClaudeAgentOptions

composio = Composio(api_key='your-composio-api-key')
session = composio.create(user_id='your-user-id')
url = session.mcp.url
```

```typescript
import { Composio } from '@composio/core';

const composio = new Composio({ apiKey: 'your-api-key' });

console.log("Creating Tool Router session...");
const { mcp } = await composio.create('your-user-id');
console.log(`Tool Router session created: ${mcp.url}`);
```

#### Path 2, Step 3: Connect to AI Agent

Use the MCP server with your AI agent
```python
import asyncio

options = ClaudeAgentOptions(
    permission_mode='bypassPermissions',
    mcp_servers={
        'tool_router': {
            'type': 'http',
            'url': url,
            'headers': {
                'x-api-key': 'your-composio-api-key'
            }
        }
    },
    system_prompt='You are a helpful assistant with access to Emailoctopus tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Get all mailing lists in my EmailOctopus account')
        async for message in client.receive_response():
            if hasattr(message, 'content'):
                for block in message.content:
                    if hasattr(block, 'text'):
                        print(block.text)

asyncio.run(main())
```

```typescript
import { openai } from '@ai-sdk/openai';
import { experimental_createMCPClient as createMCPClient } from '@ai-sdk/mcp';
import { generateText, stepCountIs } from 'ai';

const client = await createMCPClient({
  transport: {
    type: 'http',
    url: mcp.url,
    headers: { 'x-api-key': 'your-composio-api-key' }
  }
});

const tools = await client.tools();

const { text } = await generateText({
  model: openai('gpt-4o'),
  tools,
  messages: [{ role: 'user', content: 'Get all mailing lists in my EmailOctopus account' }],
  stopWhen: stepCountIs( 5 )
});

console.log(`Agent: ${text}`);
```

## Why Use Composio?

### 1. AI Native Emailoctopus Integration

- Supports both Emailoctopus MCP and direct API based integrations
- Structured, LLM-friendly schemas for reliable tool execution
- Rich coverage for reading, writing, and querying your Emailoctopus data

### 2. Managed Auth

- Built-in API Key handling with secure storage
- Central place to manage and revoke Emailoctopus credentials
- Assign credentials per user or environment—no more hard-coded secrets

### 3. Agent Optimized Design

- Tools tuned using real agent feedback for better reliability
- Comprehensive logs so you always know what happened and when

### 4. Enterprise Grade Security

- Fine-grained RBAC to choose which agents and users can access Emailoctopus
- Scoped, least-privilege access to your lists and campaigns
- Full audit trail of agent activity for compliance and peace of mind

## Use Emailoctopus with any AI Agent Framework

Choose a framework you want to connect Emailoctopus with:

- [OpenAI Agents SDK](https://composio.dev/toolkits/emailoctopus/framework/open-ai-agents-sdk)
- [Claude Agent SDK](https://composio.dev/toolkits/emailoctopus/framework/claude-agents-sdk)
- [Claude Code](https://composio.dev/toolkits/emailoctopus/framework/claude-code)
- [Claude Cowork](https://composio.dev/toolkits/emailoctopus/framework/claude-cowork)
- [Codex](https://composio.dev/toolkits/emailoctopus/framework/codex)
- [OpenClaw](https://composio.dev/toolkits/emailoctopus/framework/openclaw)
- [Hermes](https://composio.dev/toolkits/emailoctopus/framework/hermes-agent)
- [Google ADK](https://composio.dev/toolkits/emailoctopus/framework/google-adk)
- [LangChain](https://composio.dev/toolkits/emailoctopus/framework/langchain)
- [Vercel AI SDK](https://composio.dev/toolkits/emailoctopus/framework/ai-sdk)
- [Mastra AI](https://composio.dev/toolkits/emailoctopus/framework/mastra-ai)
- [LlamaIndex](https://composio.dev/toolkits/emailoctopus/framework/llama-index)
- [CrewAI](https://composio.dev/toolkits/emailoctopus/framework/crew-ai)
- [Pydantic AI](https://composio.dev/toolkits/emailoctopus/framework/pydantic-ai)
- [AutoGen](https://composio.dev/toolkits/emailoctopus/framework/autogen)

## Related Toolkits

- [Reddit](https://composio.dev/toolkits/reddit) - Reddit is a social news platform with thriving user-driven communities (subreddits). It's the go-to place for discussion, content sharing, and viral marketing.
- [Facebook](https://composio.dev/toolkits/facebook) - Facebook is a social media and advertising platform for businesses and creators. It helps you connect, share, and manage content across your public Facebook Pages.
- [Linkedin](https://composio.dev/toolkits/linkedin) - LinkedIn is a professional networking platform for connecting, sharing content, and engaging with business opportunities. It's the go-to place for building your professional brand and unlocking new career connections.
- [Active campaign](https://composio.dev/toolkits/active_campaign) - ActiveCampaign is a marketing automation and CRM platform for managing email campaigns, sales pipelines, and customer segmentation. It helps businesses engage customers and drive growth through smart automation and targeted outreach.
- [ActiveTrail](https://composio.dev/toolkits/active_trail) - ActiveTrail is a user-friendly email marketing and automation platform. It helps you reach subscribers and automate campaigns with ease.
- [Ahrefs](https://composio.dev/toolkits/ahrefs) - Ahrefs is an SEO and marketing platform for site audits, keyword research, and competitor insights. It helps you improve search rankings and drive organic traffic.
- [Amcards](https://composio.dev/toolkits/amcards) - AMCards lets you create and mail personalized greeting cards online. Build stronger customer relationships with easy, automated card campaigns.
- [Beamer](https://composio.dev/toolkits/beamer) - Beamer is a news and changelog platform for in-app announcements and feature updates. It helps companies boost user engagement by sharing news where users are most active.
- [Benchmark email](https://composio.dev/toolkits/benchmark_email) - Benchmark Email is a platform for creating, sending, and tracking email campaigns. It's built to help you engage audiences and analyze results—all in one place.
- [Bigmailer](https://composio.dev/toolkits/bigmailer) - BigMailer is an email marketing platform for managing multiple brands with white-labeling and automation. It helps teams streamline campaigns and simplify integration with Amazon SES.
- [Brandfetch](https://composio.dev/toolkits/brandfetch) - Brandfetch is an API that delivers company logos, colors, and visual branding assets. It helps marketers and developers keep brand visuals consistent everywhere.
- [Brevo](https://composio.dev/toolkits/brevo) - Brevo is an all-in-one email and SMS marketing platform for transactional messaging, automation, and CRM. It helps businesses engage customers and streamline communications through powerful campaign tools.
- [Campayn](https://composio.dev/toolkits/campayn) - Campayn is an email marketing platform for creating, sending, and managing campaigns. It helps businesses engage contacts and grow audiences with easy-to-use tools.
- [Cardly](https://composio.dev/toolkits/cardly) - Cardly is a platform for creating and sending personalized direct mail to customers. It helps businesses break through the digital clutter by getting real engagement via physical mailboxes.
- [ClickSend](https://composio.dev/toolkits/clicksend) - ClickSend is a cloud-based SMS and email marketing platform for businesses. It streamlines communication by enabling quick message delivery and contact management.
- [Crustdata](https://composio.dev/toolkits/crustdata) - CrustData is an AI-powered data intelligence platform for real-time company and people data. It helps B2B sales teams, AI SDRs, and investors react to live business signals.
- [Curated](https://composio.dev/toolkits/curated) - Curated is a platform for collecting, curating, and publishing newsletters. It streamlines content aggregation and distribution for creators and teams.
- [Customerio](https://composio.dev/toolkits/customerio) - Customer.io is a customer engagement platform for targeted messaging across email, SMS, and push. Easily automate, segment, and track communications with your audience.
- [Cutt ly](https://composio.dev/toolkits/cutt_ly) - Cutt.ly is a URL shortening service for managing and analyzing links. Streamline your workflows with quick, trackable, and branded short URLs.
- [Demio](https://composio.dev/toolkits/demio) - Demio is webinar software built for marketers, offering both live and automated sessions with interactive features. It helps teams engage audiences and optimize lead generation through detailed analytics.

## Frequently Asked Questions

### Do I need my own developer credentials to use Emailoctopus with Composio?

Yes, Emailoctopus requires you to configure your own API key credentials. Once set up, Composio handles secure credential storage and API request handling for you.

### Can I use multiple toolkits together?

Yes! Composio's Tool Router enables agents to use multiple toolkits. [Learn more](https://docs.composio.dev/tool-router/overview).

### Is Composio secure?

Composio is SOC 2 and ISO 27001 compliant with all data encrypted in transit and at rest. [Learn more](https://trust.composio.dev).

### What if the API changes?

Composio maintains and updates all toolkit integrations automatically, so your agents always work with the latest API versions.

---
[See all toolkits](https://composio.dev/toolkits) · [Composio docs](https://docs.composio.dev/llms.txt)
