Set up the WhatsApp Echo Bot
The WhatsApp Echo Bot is a sample webhook server application that echoes back to you whatever you send it. It can serve as a basic reference for how to set up webhooks and reply to incoming messages.
Last updated
The WhatsApp Echo Bot is a sample webhook server application that echoes back to you whatever you send it. It can serve as a basic reference for how to set up webhooks and reply to incoming messages.
Last updated
To test out the echo bot, we assume you have a Meta developer app with the WhatsApp product added already. Follow the getting started workflow to onboard as a developer and send your first test message.
After you send your test message, configure webhooks with the WhatsApp Echo Bot:
Using Glitch
Go to our starter webhook project on Glitch:Remix on Glitch
Click Remix to edit. A new copy of the project will be created for you.
Back in App Dashboard > WhatsApp > Getting Started, copy your access token from the developer portal:
Save it into the .env
file in the Glitch app under WHATSAPP_TOKEN
.
Now, set the other .env
variable called VERIFY_TOKEN
. This can be any string you choose. In our case, we picked "blue_panda"
.
At this point, the .env
file in the Glitch app will look like this:
To get the webhook url from Glitch click the Share button (you need to be logged in to see it) copy the live site link. Make sure to append /webhook
to the end of the URL.
Use this URL as the Webhook URL when setting up webhooks on the Meta Developer portal (also enter matching verify token, blue_panda
in our case):
Click Verify and Save. Back in the Configuration screen, click Manage and subscribe to the messages webhooks field:
Now, when you send a message to the API number on WhatsApp, it should send back your message in the following format "Ack: {your message}".
Before you start, make sure to register and sign into an AWS development account.
In AWS:
Open the AWS Lambda console. AWS operates in several regional data centers and this example is set up in the US East (N. Virginia) us-east-1
region. So the actual link is https://us-east-1.console.aws.amazon.com/lambda/home.
Click Create Function > Author from scratch and create your function. For this example, we have added and/or selected the following options:
Function name: cloudEcho
Runtime: Node.js 16.x
, since we're implementing Javascript-based Lambda function
Execution role: Create a new role with basic Lambda permissions
Advanced Settings: Enable function URL
has been checked and Auth type
was set to None
.
The Advanced Settings look like this:
Click Create Function.
Once the function is created, you are redirected to the function page. There, you can see the following information:
The function's URL ending in .lambda-url.AWS_REGION.on.aws/
. Save that for later use.
The Code source tab for that function.
Once you paste the code, you will see the Changes not deployed banner pop up. Do not deploy your function yet! We need to set verify token and access token before that.
In Meta for Developers:
Open Meta for Developers > My Apps and select the app you have created while following the getting started workflow. Click WhatsApp > Getting started.
Copy the temporary access token:
In AWS:
Paste the access token into your Lambda function. Then, set up the VERIFY_TOKEN
field in your Lambda function. For this example, we're using blue_panda
.
Click Deploy.
In Meta for Developers:
Open Meta for Developers > My Apps and select the app you have created while following the getting started workflow. Click WhatsApp > Configuration > Configure a webhook.
Under Callback URL, paste your Lambda function URL (this is the URL that was generated immediately after the function was created). Under Verify Token, paste the token you created after pasting your access token (for our example, we're using blue_panda
):
Click Verify and Save.
Once verification is successful, click Manage back in the Configuration page:
A new dialog module opens up with all available objects you can subscribe to. Click Subscribe for the messages
object. Then, click Done.
You are done setting up the echo bot! Now, when you send a message to the API number on WhatsApp, it should send back your message in the following format "Ack from AWS lambda: {your message}".