copyright | lastupdated | subcollection | ||
---|---|---|---|---|
|
2025-01-09 |
watson-assistant |
{{site.data.keyword.attribute-definition-list}}
{: #deploy-whatsapp}
[IBM Cloud]{: tag-ibm-cloud}
Integrate with WhatsApp messaging so your assistant can exchange messages with your customers where they are. {: shortdesc}
Many customers use WhatsApp because it provides fast, simple, secure messaging for free, and is available on phones all over the world. WhatsApp uses the phone Internet connection to send messages so customers can avoid SMS fees.
This integration creates a connection between your assistant and WhatsApp by using Twilio as a provider.
{: #deploy-whatsapp-twilio-setup}
To integrate Whatsapp with your assistant, you must have access to Twilio and at least a Developer role. For more information, see the difference in roles for Twilio{: external}.
-
Go to the Twilio website{: external}.
-
Create an account.
-
From the Develop tab, click Phone numbers.
-
Follow the instructions to get a phone number.
When you get a Twilio phone number, it supports voice, SMS, and MMS automatically. Your new phone number is listed as an active number. Consider provisioning more than one phone number and going through the process of getting permission for the numbers in parallel. If your number was used by a different business previously (because Twilio assigned you a number that was used before, for example), WhatsApp will reject it.
Keep the Twilio web page open in a web browser tab so you can refer to it again later. {: tip}
{: #deploy-whatsapp-prereqs}
WhatsApp has a rigorous process to review all businesses that want to interact with customers over their network. WhatsApp, which is owned by Meta (formerly called Facebook), requires that you register your business with the Meta business directory.
-
To register, go to the Meta Business Tools{: external} page, and click Create new account. Follow the instructions to create an account.
-
Get your Meta Business Manager ID. In Settings, click the Business info tab. The Business Manager ID is at the top of the page.
-
Enable your Twilio numbers for WhatsApp using the WhatsApp Tech Provider Program{: external} web page, which is the only officially supported path by Meta to onboard your customers to WhatsApp as of January 1, 2025. For more information, see WhatsApp Tech Provider Program Overview{: external}.
Tips for specifying the following values:
-
Twilio Account SID: From the Twilio site, click the home icon to go to your project dashboard to find the SID.
-
Meta Business Manager ID: Add the ID for the account that you created in the previous step.
-
Do you offer self-service onboarding for your customers?: Select No. By adopting the Tech Provider Program, your customers will onboard to WhatsApp using Meta's WhatsApp Embedded Signup product.
-
-
Click Submit.
Give WhatsApp time to evaluate and approve your submission. It can take up to 7 days for your request to be approved.
{: #deploy-whatsapp-setup}
To set up the integration, complete the following steps:
-
Go to the Integrations page by clicking the integrations icon () in the left menu.
-
Click Add on the WhatsApp with Twilio tile.
-
Click Confirm.
-
From the Twilio site, click on your account name in the upper left menu to go to your account dashboard.
Copy the following values and store them temporarily, so you can paste them into the WhatsApp with Twilio integration setup page in the upcoming steps.
- Account SID
- Auth token
-
Return to the WhatsApp with Twilio integration setup page. Click Next to go to Step 1 of your WhatsApp with Twilio integration setup.
-
Enter your Account SID information. Click Next to go to Step 2 of your WhatsApp with Twilio integration setup.
-
Enter your Auth token information. Click Next to go to Step 3 of your WhatsApp with Twilio integration setup.
-
Copy the value from the Webhook URI field.
You can use this webhook URI to test your integration in the following section.
-
Click Finish.
If a field required for authentication is changed, then all entries in related fields must be filled and validated again. {: note}
{: #deploy-whatsapp-sandbox}
While you wait for WhatsApp to approve your submission, you can test the integration by using the Twilio sandbox. With the sandbox, you can send and receive preapproved template messages to numbers that join your sandbox, using a shared, pre-provisioned Twilio test number.
Do not use the Twilio sandbox in production. Sandbox sessions expire after 3 days.
-
To create a sandbox, go to the Twilio Console{: external} web page and log in with your Twilio credentials. An Activate your sandbox prompt is displayed. Agree to have a sandbox created, and confirm your choice.
-
Follow the instructions to create the sandbox.
-
Connect to the sandbox by sending a WhatsApp message from your device to the sandbox phone number.
-
From the Develop tab, click Messaging > Settings > WhatsApp sandbox settings.
-
In the Sandbox Configuration section, paste the webhook URI that you copied earlier into the When a message comes in field. Click Save.
-
You can test the integration by sending a message from WhatsApp to the shared phone number that is assigned to your Twilio sandbox.
For complete and detailed information, see Get started with the Twilio Sandbox for WhatsApp{: external}.
{: #deploy-whatsapp-finish}
After WhatsApp grants permission and access to the WhatsApp network, update the integration to use your dedicated Twilio phone number instead of the sandbox number.
-
From the WhatsApp with Twilio integration setup page, scroll to the Webhook section of the Basic setup tab. Copy the value from the WhatsApp webhook field.
-
Go to your Twilio account web page and add the webhook that you copied to the Twilio configuration to complete the connection to the WhatsApp integration in Twilio.
{: #deploy-whatsapp-click-to-chat}
You can add an icon to your web page that customers can click to start a conversation over WhatsApp with your assistant.
To add an icon to your web page, complete the following steps:
-
From the WhatsApp with Twilio integration setup page, click the Click to chat tab.
-
In the Pre-filled message field, add text that you want WhatsApp to send to your assistant on the customer's behalf to get the conversation started.
Specify a message that you know your assistant can answer in a useful way.
-
Copy the Embed link and add it to your web page. Consider adding text in front of the icon that explains what the icon does. For example, you might add a
<span>
HTML tag in front of the icon's<span>
element that saysHave a question? Ask {{site.data.keyword.conversationshort}} for help
.When a user clicks the icon on your web page, it opens a WhatsApp messaging session that is connected to your assistant, and adds the text you specify into the user's text field, ready to be submitted.
{: #deploy-whatsapp-action}
For the best customer experience, design your actions with the capabilities of the WhatsApp integration in mind:
- A text response that contains more than 1,600 characters is broken up into multiple responses.
- Do not include HTML elements in your text responses.
- The WhatsApp with Twilio integration does not support chat transfers that are initiated with the Connect to agent response type.
- If you use Markdown syntax, see the Supported Markdown syntax table.
- To include a hypertext link in a text response, specify the URL directly. Do not use markdown syntax for links. For example, specify
Contact us at https://www.ibm.com.
Format | Syntax | Example |
---|---|---|
Italics | We're talking about _practice_. |
We're talking about practice. |
Bold | There's *no* crying in baseball. |
There's no crying in baseball. |
{: caption="Supported Markdown syntax" caption-side="top"} |