Get the FREE Ultimate OpenClaw Setup Guide →

whatsapp-automation

npx machina-cli add skill davepoon/buildwithclaude/whatsapp-automation --openclaw
Files (1)
SKILL.md
8.2 KB

WhatsApp Business Automation via Rube MCP

Automate WhatsApp Business operations through Composio's WhatsApp toolkit via Rube MCP.

Toolkit docs: composio.dev/toolkits/whatsapp

Prerequisites

  • Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
  • Active WhatsApp connection via RUBE_MANAGE_CONNECTIONS with toolkit whatsapp
  • Always call RUBE_SEARCH_TOOLS first to get current tool schemas
  • WhatsApp Business API account required (not regular WhatsApp)

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.

  1. Verify Rube MCP is available by confirming RUBE_SEARCH_TOOLS responds
  2. Call RUBE_MANAGE_CONNECTIONS with toolkit whatsapp
  3. If connection is not ACTIVE, follow the returned auth link to complete WhatsApp Business setup
  4. Confirm connection status shows ACTIVE before running any workflows

Core Workflows

1. Send a Text Message

When to use: User wants to send a text message to a WhatsApp contact

Tool sequence:

  1. WHATSAPP_GET_PHONE_NUMBERS - List available business phone numbers [Prerequisite]
  2. WHATSAPP_SEND_MESSAGE - Send a text message [Required]

Key parameters:

  • to: Recipient phone number in international format (e.g., '+14155551234')
  • body: Message text content
  • phone_number_id: Business phone number ID to send from

Pitfalls:

  • Phone numbers must be in international E.164 format with country code
  • Messages outside the 24-hour window require approved templates
  • The 24-hour window starts when the customer last messaged you
  • Business-initiated conversations require template messages first

2. Send Template Messages

When to use: User wants to send pre-approved template messages for outbound communication

Tool sequence:

  1. WHATSAPP_GET_MESSAGE_TEMPLATES - List available templates [Prerequisite]
  2. WHATSAPP_GET_TEMPLATE_STATUS - Check template approval status [Optional]
  3. WHATSAPP_SEND_TEMPLATE_MESSAGE - Send the template message [Required]

Key parameters:

  • template_name: Name of the approved template
  • language_code: Template language (e.g., 'en_US')
  • to: Recipient phone number
  • components: Template variable values and parameters

Pitfalls:

  • Templates must be approved by Meta before use
  • Template variables must match the expected count and format
  • Sending unapproved or rejected templates returns errors
  • Language code must match an approved translation of the template

3. Send Media Messages

When to use: User wants to send images, documents, or other media

Tool sequence:

  1. WHATSAPP_UPLOAD_MEDIA - Upload media to WhatsApp servers [Required]
  2. WHATSAPP_SEND_MEDIA_BY_ID - Send media using the uploaded media ID [Required] OR
  3. WHATSAPP_SEND_MEDIA - Send media using a public URL [Alternative]

Key parameters:

  • media_url: Public URL of the media (for SEND_MEDIA)
  • media_id: ID from upload response (for SEND_MEDIA_BY_ID)
  • type: Media type ('image', 'document', 'audio', 'video', 'sticker')
  • caption: Optional caption for the media

Pitfalls:

  • Uploaded media IDs are temporary and expire after a period
  • Media size limits vary by type (images: 5MB, videos: 16MB, documents: 100MB)
  • Supported formats: images (JPEG, PNG), videos (MP4, 3GPP), documents (PDF, etc.)
  • SEND_MEDIA requires a publicly accessible HTTPS URL

4. Reply to Messages

When to use: User wants to reply to an incoming WhatsApp message

Tool sequence:

  1. WHATSAPP_SEND_REPLY - Send a reply to a specific message [Required]

Key parameters:

  • message_id: ID of the message being replied to
  • to: Recipient phone number
  • body: Reply text content

Pitfalls:

  • message_id must be from a message received within the 24-hour window
  • Replies appear as quoted messages in the conversation
  • The original message must still exist (not deleted) for the quote to display

5. Manage Business Profile and Templates

When to use: User wants to view or manage their WhatsApp Business profile

Tool sequence:

  1. WHATSAPP_GET_BUSINESS_PROFILE - Get business profile details [Optional]
  2. WHATSAPP_GET_PHONE_NUMBERS - List registered phone numbers [Optional]
  3. WHATSAPP_GET_PHONE_NUMBER - Get details for a specific number [Optional]
  4. WHATSAPP_CREATE_MESSAGE_TEMPLATE - Create a new template [Optional]
  5. WHATSAPP_GET_MESSAGE_TEMPLATES - List all templates [Optional]

Key parameters:

  • phone_number_id: Business phone number ID
  • template_name: Name for the new template
  • category: Template category (MARKETING, UTILITY, AUTHENTICATION)
  • language: Template language code

Pitfalls:

  • New templates require Meta review before they can be used
  • Template names must be lowercase with underscores (no spaces)
  • Category affects pricing and approval criteria
  • Templates have specific formatting requirements for headers, body, and buttons

6. Share Contacts

When to use: User wants to send contact information via WhatsApp

Tool sequence:

  1. WHATSAPP_SEND_CONTACTS - Send contact cards [Required]

Key parameters:

  • to: Recipient phone number
  • contacts: Array of contact objects with name, phone, email details

Pitfalls:

  • Contact objects must follow the WhatsApp Business API contact schema
  • At least a name field is required for each contact
  • Phone numbers in contacts should include country codes

Common Patterns

24-Hour Messaging Window

  • Customers must message you first to open a conversation window
  • Within 24 hours of their last message, you can send free-form messages
  • After 24 hours, only approved template messages can be sent
  • Template messages can re-open the conversation window

Phone Number Resolution

1. Call WHATSAPP_GET_PHONE_NUMBERS
2. Extract phone_number_id for your business number
3. Use phone_number_id in all send operations

Media Upload Flow

1. Call WHATSAPP_UPLOAD_MEDIA with the file
2. Extract media_id from response
3. Call WHATSAPP_SEND_MEDIA_BY_ID with media_id
4. OR use WHATSAPP_SEND_MEDIA with a public URL directly

Known Pitfalls

Phone Number Format:

  • Always use E.164 format: +[country code][number] (e.g., '+14155551234')
  • Do not include dashes, spaces, or parentheses
  • Country code is required; local numbers without it will fail

Messaging Restrictions:

  • Business-initiated messages require templates outside the 24-hour window
  • Template messages cost money per conversation
  • Rate limits apply per phone number and per account

Media Handling:

  • Uploaded media expires; use promptly after upload
  • Media URLs must be publicly accessible HTTPS
  • Stickers have specific requirements (WebP format, 512x512 pixels)

Template Management:

  • Template review can take up to 24 hours
  • Rejected templates need to be fixed and resubmitted
  • Template variables use double curly braces: {{1}}, {{2}}, etc.

Quick Reference

TaskTool SlugKey Params
Send messageWHATSAPP_SEND_MESSAGEto, body
Send templateWHATSAPP_SEND_TEMPLATE_MESSAGEtemplate_name, to, language_code
Upload mediaWHATSAPP_UPLOAD_MEDIA(file params)
Send media by IDWHATSAPP_SEND_MEDIA_BY_IDmedia_id, to, type
Send media by URLWHATSAPP_SEND_MEDIAmedia_url, to, type
Reply to messageWHATSAPP_SEND_REPLYmessage_id, to, body
Send contactsWHATSAPP_SEND_CONTACTSto, contacts
Get mediaWHATSAPP_GET_MEDIAmedia_id
List phone numbersWHATSAPP_GET_PHONE_NUMBERS(none)
Get phone numberWHATSAPP_GET_PHONE_NUMBERphone_number_id
Get business profileWHATSAPP_GET_BUSINESS_PROFILEphone_number_id
Create templateWHATSAPP_CREATE_MESSAGE_TEMPLATEtemplate_name, category, language
List templatesWHATSAPP_GET_MESSAGE_TEMPLATES(none)
Check template statusWHATSAPP_GET_TEMPLATE_STATUStemplate_id

Powered by Composio

Source

git clone https://github.com/davepoon/buildwithclaude/blob/main/plugins/all-skills/skills/whatsapp-automation/SKILL.mdView on GitHub

Overview

Automate WhatsApp Business tasks using Composio's toolkit via Rube MCP. It covers sending text and template messages, uploading media, and managing contacts, with a requirement to fetch current tool schemas first.

How This Skill Works

Connect and verify Rube MCP, ensure RUBE_SEARCH_TOOLS is available, and establish an ACTIVE WhatsApp connection using RUBE_MANAGE_CONNECTIONS with the whatsapp toolkit. Then execute workflows using specific tools like WHATSAPP_SEND_MESSAGE, WHATSAPP_SEND_TEMPLATE_MESSAGE, WHATSAPP_UPLOAD_MEDIA, and WHATSAPP_SEND_MEDIA_BY_ID, always loading current schemas first as outlined.

When to Use It

  • Respond to a customer support inquiry with a direct text message within the chat
  • Send outbound notifications using pre-approved template messages (e.g., order updates)
  • Share media assets such as product images or documents via WhatsApp
  • Reply to incoming messages to continue conversations
  • Onboard new contacts and run language-specific template campaigns

Quick Start

  1. Step 1: Verify Rube MCP is available by calling RUBE_SEARCH_TOOLS and confirm the whatsapp toolkit is ready
  2. Step 2: Connect to WhatsApp with RUBE_MANAGE_CONNECTIONS for the whatsapp toolkit and complete activation if required
  3. Step 3: Choose a workflow: send a text with WHATSAPP_SEND_MESSAGE, send a template with WHATSAPP_SEND_TEMPLATE_MESSAGE, or upload and send media with WHATSAPP_UPLOAD_MEDIA and SEND_MEDIA_BY_ID

Best Practices

  • Always call RUBE_SEARCH_TOOLS to fetch the latest tool schemas before building workflows
  • Format phone numbers in international E.164 format
  • Use text messages within the 24-hour window; for beyond, use approved templates
  • Ensure template approvals are in place and language_code matches the template translation
  • Understand media lifecycles: uploaded media IDs expire and media_size limits apply

Example Use Cases

  • An online store sends order confirmations via a pre-approved template message
  • A support agent provides status updates using a text message within the 24-hour window
  • A retailer shares a product image with a caption via a media message
  • A business replies to a customer inquiry with a targeted follow-up message
  • A marketing team sends language-localized templates to new leads

Frequently Asked Questions

Add this skill to your agents

Related Skills

Sponsor this space

Reach thousands of developers