Skip to content

Send WhatsApp Call Button Messages and Deep Links

Updated: Jun 26, 2026

Overview

After you adopt Cloud API Calling features, you can raise awareness with your customers in two core ways:

  • Send them a message with a WhatsApp call button
  • Embed a calling deep link into your brand surfaces (website, application, and so on)

Send interactive message with a WhatsApp call button

Use this endpoint to send a free-form interactive message with a WhatsApp call button during a customer service window or an open conversation window.

When a WhatsApp user clicks the call button, the click initiates a WhatsApp call to the business number that sent the message.

WhatsApp sends a standard message status webhook in response to this message send.

Screenshot showing WhatsApp call button message on mobile device

Request syntax

POST <PHONE_NUMBER_ID>/messages
PlaceholderDescriptionSample value
<PHONE_NUMBER_ID> IntegerRequired The business phone number from which you are sending messages. Learn more about formatting phone numbers in Cloud API+12784358810

Request body

{  
  "messaging_product": "whatsapp",  
  "recipient_type": "individual",  
  "to": "14085551234",  
  "recipient": "US.13491208655302741918",  
  "type": "interactive",  
  "interactive" : {  
    "type" : "voice_call",  
    "body" : {  
      "text": "You can call us on WhatsApp now for faster service!"  
    },  
    "action": {  
      "name": "voice_call",  
      "parameters": {  
        "display_text": "Call on WhatsApp",  
        "ttl_minutes": 100,  
        "payload": "payload data"  
      }  
    }  
  }  
}

Body parameters

Learn more about sending interactive free form messages

ParameterDescriptionSample value
to IntegerRequired (unless recipient is provided) The phone number of the WhatsApp user you are messaging. Learn more about formatting phone numbers in Cloud API"17863476655"
recipient StringOptional The WhatsApp user's business-scoped user ID (BSUID) or parent BSUID. Use this instead of, or in addition to, to. If you include both, to takes precedence. Learn more about business-scoped user IDs"US.13491208655302741918"
type StringRequired The type of interactive message you are sending. In this case, you are sending a voice_call. Learn more about interactive messages"voice_call"
action StringRequired The action of your interactive message. Must be voice_call."voice_call"
parameters JSON ObjectOptional Optional parameters for the WhatsApp calling button sent to the user. Contains three values: display_text, ttl_minutes, and payload. display_text — (String) Optional The display text on the WhatsApp calling button sent to the user. Default is Call Now. Max length: 20 characters. ttl_minutes — (Integer) Optional Time to live for the call-to-action (CTA) button in minutes. Must be between 1 and 43200 (30 days). Default value is 10080 (7 days). payload — (String) Optional An arbitrary string, useful for tracking. Any app subscribed to the calls webhook field on the WhatsApp Business account can get this string. The string is included in the connect and terminate webhook payloads under the cta_payload field. Cloud API does not process the cta_payload field; it returns the value in webhook payloads. Maximum 512 characters. Payload is only available to WhatsApp clients starting on version 2.25.27."parameters": { "display_text": "Call on WhatsApp", "ttl_minutes": 100, "payload": "payload data" }

Usernames and business-scoped user IDs: The recipient field lets you identify the WhatsApp user by their BSUID instead of, or in addition to, their phone number in to. For details, see Business-scoped user IDs.

Success response

Learn more about messaging success responses

Error response

Possible errors:

If you send this message to users on older app versions, Cloud API returns an error webhook with error code 131026.

View general Cloud API error codes

Create and send WhatsApp call button template message

Use these endpoints to create and send a WhatsApp call button template message.

Once your call button template message is created, you can send a message to a WhatsApp user, inviting them to call your business.

Learn more about creating and managing message templates

Create call button message template

Use this endpoint to create a call button message template.

Request syntax

POST /<WHATSAPP_BUSINESS_ACCOUNT_ID>/message_templates
ParameterDescriptionSample value
<WHATSAPP_BUSINESS_ACCOUNT_ID> StringRequired Your WhatsApp Business account ID. Learn how to find your WABA ID"waba-90172398162498126"

Request body

{  
  "name": "<NAME>",  
  "category": "<CATEGORY>",  
  "language": "<LANGUAGE>",  
  "components": [  
    {  
      "type": "BODY",  
      "text": "You can call us on WhatsApp now for faster service!"  
    },  
    {  
      "type": "BUTTONS",  
      "buttons": [  
        {  
          "type": "voice_call",  
          "text": "Call Now",  
          "ttl_minutes": 1440  
        },  
        {  
          "type": "URL",  
          "text": "Contact Support",  
          "url": "https://www.luckyshrub.com/support"  
        }  
      ]  
    }  
  ]  
}

Body parameters

You can create and manage template messages through both Cloud API and the Meta Business Suite interface.

When creating your call button template, ensure you configure type as voice_call.

Learn more about creating and managing message templates

ParameterDescriptionSample value
type StringRequired The type of template message you are creating. In this case, you are creating a voice_call."voice_call"
text StringOptional The display text on the WhatsApp calling button sent to the user. Default is Call Now. Max length: 20 characters."Call Now"
ttl_minutes IntegerOptional Time to live for the CTA button in minutes. Must be between 1440 (1 day) and 43200 (30 days). You can override this value when sending the message.1440

Success response

{  
  "id": "<ID>",  
  "status": "<STATUS>",  
  "category": "<CATEGORY>"  
}

Learn more about messaging success responses

Error response

Possible errors:

  • Invalid whatsapp-business-account-id
  • Permissions/Authorization errors
  • Template structure/component validation alerts

View general Cloud API error codes

Send call button message template

Use this endpoint to send a call button message template.

The following is a simplified sample of the send template message request. You can also learn more about how to send message templates.

Request syntax

POST /<PHONE_NUMBER_ID>/messages
ParameterDescriptionSample value
<PHONE_NUMBER_ID> StringRequired The business phone number from which you are sending messages. Learn more about formatting phone numbers in Cloud API+18762639988

Request body

{  
  "to": "14085551234",  
  "recipient": "US.13491208655302741918",  
  "messaging_product": "whatsapp",  
  "type": "template",  
  "recipient_type": "individual",  
  "template": {  
    "name": "wa_voice_call",  
    "language": {  
      "code": "en"  
    },  
    "components": [  
      {  
        "type": "button",  
        "sub_type" : "voice_call",  
        "parameters": [  
          {  
            "type": "ttl_minutes",  
            "ttl_minutes": 100  
          },  
          {  
            "type": "payload",  
            "payload": "payload data"  
          }  
        ]  
      }  
    ]  
  }  
}

Request parameters

ParameterDescriptionSample value
recipient StringOptional The WhatsApp user's business-scoped user ID (BSUID) or parent BSUID. Use this instead of, or in addition to, to. If you include both, to takes precedence. Learn more about business-scoped user IDs"US.13491208655302741918"
ttl_minutes IntegerOptional Time to live for the CTA button in minutes. Must be between 1 and 43200 (30 days). Default value is 10080 (7 days).10800
payload StringOptional An arbitrary string, useful for tracking. Any app subscribed to the calls webhook field on the WhatsApp Business account can get this string. The string is included in the connect and terminate webhook payloads under the cta_payload field. Cloud API does not process this field; it returns the value in webhook payloads. Maximum 512 characters. Payload is only available to WhatsApp clients starting on version 2.25.27.payload data

Usernames and business-scoped user IDs: The recipient field lets you identify the WhatsApp user by their BSUID instead of, or in addition to, their phone number in to. For details, see Business-scoped user IDs.

Success response

Screenshot showing successful WhatsApp call button template message

Learn more about messaging success responses

Calling deep links are hyperlinks that route WhatsApp users to call your business.

The process to create a calling deep link is similar to a chat deep link⁠, except the format for the call deep link is wa.me/call/<BUSINESS_PHONE_NUMBER>

Deep links are not supported on WhatsApp desktop clients.

You can use calling deep links to advertise WhatsApp calling for your business.

Use these links anywhere calling is useful, such as your website, primary application, or a QR code to be shared.

Example of calling deep link embedded on a business website

You can also send messages to WhatsApp users with a calling deep link.

Since deep links can be made per business phone number, you can use calling deep links to prompt WhatsApp users to contact a different phone number with voice enabled.

The wa.me/call/<BUSINESS_PHONE_NUMBER> format is easy to copy, paste, and send, and does not require you to make a template in Meta Business Suite.

Screenshot showing WhatsApp message with calling deep link

You can also send a payload with the deep link. You can use the biz_payload query string when sending the call deep link to any user (wa.me/call/<BUSINESS_PHONE_NUMBER>?biz_payload=payload).

When a user calls using the provided deep link with the biz_payload, any app subscribed to the calls webhook field on the WhatsApp Business account can get this string. The string is included in the connect and terminate webhook payloads under the deeplink_payload field.

Payload in call deep link is only available to WhatsApp clients starting on version 2.25.27.

Unofficial mirror for reference/search purposes. All content originates from developers.facebook.com — see the source link at the top of each page. Machine-readable indexes: llms.txt · llms-full.txt · About