SendGrid Automation via Rube MCP
Automate SendGrid email delivery workflows including marketing campaigns (Single Sends), contact and list management, sender identity setup, and email analytics through Composio's SendGrid toolkit.
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active SendGrid connection via
RUBE_MANAGE_CONNECTIONSwith toolkitsendgrid - Always call
RUBE_SEARCH_TOOLSfirst to get current tool schemas
Setup
Get Rube MCP: Add https://rube.app/mcp as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
- Verify Rube MCP is available by confirming
RUBE_SEARCH_TOOLSresponds - Call
RUBE_MANAGE_CONNECTIONSwith toolkitsendgrid - If connection is not ACTIVE, follow the returned auth link to complete SendGrid API key authentication
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. Create and Send Marketing Campaigns (Single Sends)
When to use: User wants to create and send a marketing email campaign to a contact list or segment.
Tool sequence:
SENDGRID_RETRIEVE_ALL_LISTS- List available marketing lists to target [Prerequisite]SENDGRID_CREATE_A_LIST- Create a new list if needed [Optional]SENDGRID_ADD_OR_UPDATE_A_CONTACT- Add contacts to the list [Optional]SENDGRID_GET_ALL_SENDER_IDENTITIES- Get verified sender ID [Prerequisite]SENDGRID_CREATE_SINGLE_SEND- Create the campaign with content, sender, and recipients [Required]
Key parameters for SENDGRID_CREATE_SINGLE_SEND:
name: Campaign name (required)email__config__subject: Email subject lineemail__config__html__content: HTML body contentemail__config__plain__content: Plain text versionemail__config__sender__id: Verified sender identity IDemail__config__design__id: Use instead of html_content for pre-built designssend__to__list__ids: Array of list UUIDs to send tosend__to__segment__ids: Array of segment UUIDssend__to__all: true to send to all contactsemail__config__suppression__group__idoremail__config__custom__unsubscribe__url: One required for compliance
Pitfalls:
- Setting
send_aton CREATE does NOT schedule the send; it only prepopulates the UI date; use the Schedule endpoint separately send_at: "now"is only valid with the Schedule endpoint, not CREATE- Must provide either
suppression_group_idorcustom_unsubscribe_urlfor unsubscribe compliance - Sender must be verified before use; check with
SENDGRID_GET_ALL_SENDER_IDENTITIES - Nested params use double-underscore notation (e.g.,
email__config__subject)
2. Manage Contacts and Lists
When to use: User wants to create contact lists, add/update contacts, search for contacts, or remove contacts from lists.
Tool sequence:
SENDGRID_RETRIEVE_ALL_LISTS- List all marketing lists [Required]SENDGRID_CREATE_A_LIST- Create a new contact list [Optional]SENDGRID_GET_A_LIST_BY_ID- Get list details and sample contacts [Optional]SENDGRID_ADD_OR_UPDATE_A_CONTACT- Upsert contacts with list association [Required]SENDGRID_GET_CONTACTS_BY_EMAILS- Look up contacts by email [Optional]SENDGRID_GET_CONTACTS_BY_IDENTIFIERS- Look up contacts by email, phone, or external ID [Optional]SENDGRID_GET_LIST_CONTACT_COUNT- Verify contact count after operations [Optional]SENDGRID_REMOVE_CONTACTS_FROM_A_LIST- Remove contacts from a list without deleting [Optional]SENDGRID_REMOVE_LIST_AND_OPTIONAL_CONTACTS- Delete an entire list [Optional]SENDGRID_IMPORT_CONTACTS- Bulk import from CSV [Optional]
Key parameters for SENDGRID_ADD_OR_UPDATE_A_CONTACT:
contacts: Array of contact objects (max 30,000 or 6MB), each with at least one identifier:email,phone_number_id,external_id, oranonymous_id(required)list_ids: Array of list UUID strings to associate contacts with
Pitfalls:
SENDGRID_ADD_OR_UPDATE_A_CONTACTis asynchronous; returns 202 withjob_id; contacts may take 10-30 seconds to appear- List IDs are UUIDs (e.g., "ca7a3796-e8a8-4029-9ccb-df8937940562"), not integers
- List names must be unique; duplicate names cause 400 errors
SENDGRID_ADD_A_SINGLE_RECIPIENT_TO_A_LISTuses the legacy API; preferSENDGRID_ADD_OR_UPDATE_A_CONTACTwithlist_idsSENDGRID_REMOVE_LIST_AND_OPTIONAL_CONTACTSis irreversible; require explicit user confirmation- Email addresses are automatically lowercased by SendGrid
3. Manage Sender Identities
When to use: User wants to set up or view sender identities (From addresses) for sending emails.
Tool sequence:
SENDGRID_GET_ALL_SENDER_IDENTITIES- List all existing sender identities [Required]SENDGRID_CREATE_A_SENDER_IDENTITY- Create a new sender identity [Optional]SENDGRID_VIEW_A_SENDER_IDENTITY- View details for a specific sender [Optional]SENDGRID_UPDATE_A_SENDER_IDENTITY- Update sender details [Optional]SENDGRID_CREATE_VERIFIED_SENDER_REQUEST- Create and verify a new sender [Optional]SENDGRID_AUTHENTICATE_A_DOMAIN- Set up domain authentication for auto-verification [Optional]
Key parameters for SENDGRID_CREATE_A_SENDER_IDENTITY:
from__email: From email address (required)from__name: Display name (required)reply__to__email: Reply-to address (required)nickname: Internal identifier (required)address,city,country: Physical address for CAN-SPAM compliance (required)
Pitfalls:
- New senders must be verified before use; if domain is not authenticated, a verification email is sent
- Up to 100 unique sender identities per account
- Avoid using domains with strict DMARC policies (gmail.com, yahoo.com) as from addresses
SENDGRID_CREATE_VERIFIED_SENDER_REQUESTsends a verification email; sender is unusable until verified
4. View Email Statistics and Activity
When to use: User wants to review email delivery stats, bounce rates, open/click metrics, or message activity.
Tool sequence:
SENDGRID_RETRIEVE_GLOBAL_EMAIL_STATISTICS- Get account-wide delivery metrics [Required]SENDGRID_GET_ALL_CATEGORIES- Discover available categories for filtering [Optional]SENDGRID_RETRIEVE_EMAIL_STATISTICS_FOR_CATEGORIES- Get stats broken down by category [Optional]SENDGRID_FILTER_ALL_MESSAGES- Search email activity feed by recipient, status, or date [Optional]SENDGRID_FILTER_MESSAGES_BY_MESSAGE_ID- Get detailed events for a specific message [Optional]SENDGRID_REQUEST_CSV- Export activity data as CSV for large datasets [Optional]SENDGRID_DOWNLOAD_CSV- Download the exported CSV file [Optional]
Key parameters for SENDGRID_RETRIEVE_GLOBAL_EMAIL_STATISTICS:
start_date: Start date YYYY-MM-DD (required)end_date: End date YYYY-MM-DDaggregated_by: "day", "week", or "month"limit/offset: Pagination (default 500)
Key parameters for SENDGRID_FILTER_ALL_MESSAGES:
query: SQL-like query string, e.g.,status="delivered",to_email="user@example.com", date ranges withBETWEEN TIMESTAMPlimit: 1-1000 (default 10)
Pitfalls:
SENDGRID_FILTER_ALL_MESSAGESrequires the "30 Days Additional Email Activity History" paid add-on; returns 403 without it- Global statistics are nested under
details[].stats[0].metrics, not a flat structure - Category statistics are only available for the previous 13 months
- Maximum 10 categories per request in
SENDGRID_RETRIEVE_EMAIL_STATISTICS_FOR_CATEGORIES - CSV export is limited to one request per 12 hours; link expires after 3 days
5. Manage Suppressions
When to use: User wants to check or manage unsubscribe groups for email compliance.
Tool sequence:
SENDGRID_GET_SUPPRESSION_GROUPS- List all suppression groups [Required]SENDGRID_RETRIEVE_ALL_SUPPRESSION_GROUPS_FOR_AN_EMAIL_ADDRESS- Check suppression status for a specific email [Opti