Dear users, with the new WhatsApp Web update, a conflict prevented the app from loading. We fixed it and submitted a new version to the Chrome Store, and we're waiting for Google approval. Please stand by!
 
Install Now

As we explained in a previous post, WA Web Plus is able to act as a smart agent on your behalf, that processes the incoming messages and do custom actions with them; in this post, we will cover the details that help you set up your first Webhook with only a few steps!

Since version 4.6.7, we started supporting more trusted automation services that WA Web Plus now can integrate with:

We also included the option to receive webhook requests from outside WA Web plus, making it able to send WhatsApp messages to your contacts directly from your website, web or mobile application.

1- Outgoing Webhooks

Connecting WA Web Plus with External Automation Services

Below is a list of detailed tutorials that explain how to do this integration simlpy:

  1. Integrate WhatsApp with Pabbly Connect via WA Web Plus
  2. Integrate WhatsApp with Zapier via WA Web Plus (Soon)
  3. Integrate WhatsApp with Integromat via WA Web Plus (Soon)
  4. Integrate WhatsApp with Integrately via WA Web Plus (Soon)

Setting Up your Custom Webhook

In case you’re not using any of the above services, or in case you have your own service that you want to integrate with, you can set up your own webhook. To set up a custom webhook, you will need to use Firebase as a service in the middle between WA Web Plus and your system, Firebase is a platform managed by Google now, it provides the ability to host NodeJS applications where you can put your Webhook codes, or connect to your custom server or cloud system.

Webhook Dataflow

Webhooks are triggered by Smart Replies, when a user sends a specific keyword to your WhatsApp chat, a Smart Reply catches it, and sends all the message information to a previously selected Webhook that will process it and return the reponse to the sender.

Why Firebase?

Due to security restrictions, a static domain should be whitelisted in the extension in order to allow WA Web Plus to send the data to it, we chose Firebase because it is easy to set up, and provides a free service, or a very cheap service if you go over quota. So we’ve whitelisted the most used Firebase services domains to allow users to host their own Webhook code on Firebase.

1- If you are not a developer and you don’t have enough programing skills, you probably didn’t understand some of the terms in this post, sit back and let us do it for you, you can hire our dedicated team to setup your customized Webhook to do whatever you want it to do.

2- If you’re a developer, prepare your Caffeine source; it’s time to code!

Writing the First Webhook

  • Create your own basic Firebase Cloud Functions app, you can easily build an app that uses NodeJS to receive the request from WA Web Plus, a good a simple documentation about how to make your first app is here on this link, available in 7 different languages.

After a successful deployment of your code to Firebase cloud, your endpoint/webhook link can be easily accessed with your browser on the following link: https://us-central1-your-project-name.cloudfunctions.net

Or if you’re using the simple setup with ExpressJS, you can use Firebase Hosting to trigger the function where your link might look like: https://your-project-name.web.app/

  • We’re almost there! Now head to WA Web Plus, in the Business Tools tab you can setup a new Webhook, paste your endpoint/webhook link that we created above into the box, select the Request Payload (parameters) that you wish to send to your endpoint, and hit “SAVE”.
  • Now your Webhook is ready, and waiting for the action that will trigger it! Which is easily done with “Smart Replies“, a smart reply detects previously identified keywords in the incoming messages, and reacts with a specific action according to it, and our action here will be to trigger a Webhook!
  • Since the reply will not always be a static reply, but a dynamic one (according to the response from your Webhook endpoint), we will always use the Dynamic Variable {W} to print out the result of the Webhook response to the reply that will be sent to the user.
  • Now, that’s it! Let us test how the setup goes:
  • Congratulations! you’ve just made your first Webhook with a very little amount of codes. As you can see in the above image, a user sent a keyword to your WhatsApp, the Smart Reply triggered the Webhook, the Webhook returned the reply to the conversation.

Going Deeper

But hey, what if I want my Webhook to get information from another server/data provider? That is very easy to do with “Axios” library.

const functions = require('firebase-functions');
const express = require('express');
const axios = require('axios');
const app = express();

app.get('/get-message', async (req, res) => {
	const m_content = req.query.m_content.toLowerCase();
	axios.get("https://auto-correct-app.com/?text=" + m_content)
	.then(response => {
		res.json(response.data);
		return false;
	})
	.catch(error => {
		res.json(error.message);
		return false;
	});
});

exports.app = functions.https.onRequest(app);

We used “Axios” to send another “GET” request to a service provider that will auto correct the received message for us, and return it to the user.

Available Parameters

The Webhook request can send a pre-selected list of variables that includes useful information about the message that has been received. This makes it easy for you to receive the data from those parameters and process them in your Firebase app.

Parameter NameValue
m_typeMessage type
m_timestampMessage timestamp
m_userMessage sender phone number
m_contentMessage content (Text only)
m_cnameMessage sender phone book name
m_unameMessage sender WhatsApp account name
m_gnameMessage group name

Allowed/Whitelisted Domain Names

Only the list of domains below are allowed to interact (send/receive) data from/to WA Web Plus upon setting up your webhook.

    "*://*.web.app/*",
    "*://*.firebaseio.com/*",
    "*://*.firebaseapp.com/*",
    "*://*.cloudfunctions.net/*",
    "*://*.zapier.com/*",
    "*://*.pabbly.com/*",
    "*://*.integrately.com/*",
    "*://*.integromat.com/*",
    "*://apiway.ai/*",
    "*://*.paddle.com/*"

More Examples

Now that you have learned how to setup your first Webhook with WA Web Plus, you can easily replicate those simple Webhooks and play with them:

Google Translate Webhook
A function that uses Google Translate to translate the incoming message to any language.

// install this library
// https://github.com/statickidz/node-google-translate-skidz
const translate = require('node-google-translate-skidz');
app.get('/translate', async (req, res) => {
	const m_content = req.query.m_content.toLowerCase();
	translate({
		text: m_content.includes('translate:') ? m_content.split("translate:")[1] : m_content,
		source: 'auto', // automatically detect text langauge
		target: 'en' // put your target language here
	}, function(result) {
		res.json(result.translation || 'Sorry :(');
	});
});

Covid-19 Statistics Webhook
A function that will return Covid-19 official statistics about any country.

app.get('/corona', async (req, res) => {
	const m_content = req.query.m_content.toLowerCase();
	const country = m_content.includes('corona:') ? m_content.split("corona:")[1] : m_content;

	axios.get("https://api.covid19api.com/dayone/country/" + country.replace(/\s/g, ''))
	.then(response => {
		let lastKey = response.data.length - 1;
		res.json("🦠 COVID-19 Statistics in " + response.data[lastKey].Country + " until today:\n\n" + "Confirmed: " + response.data[lastKey].Confirmed + "\n" + "Deaths: " + response.data[lastKey].Deaths + "\n" + "Recovered: " + response.data[lastKey].Recovered + "\n" + "Active: " + response.data[lastKey].Active + "\n\n" + "Stay home! 😷🏠");
		return false;
	})
	.catch(error => {
		res.json(error.message);
		return false;
	});
});

Weather Webhook
A function that returns today’s weather conditions for any given country or city.

// register here to get your API key that you need to include in the URL
// https://openweathermap.org/api
app.get('/weather', async (req, res) => {
	const m_content = req.query.m_content.toLowerCase();
	const city = m_content.includes('weather:') ? m_content.split("weather:")[1] : m_content;

	axios.get("http://api.openweathermap.org/data/2.5/weather?q=" + encodeURI(city) + "&appid=<YOUR API KEY HERE>&lang=en")
	.then(response => {
		res.json("🌍 The weather in " + response.data.name + " is " + response.data.weather[0].main + ", the temperature is 🌡 " + Math.round(response.data.main.temp - 273.15) + "°C and the wind speed is 🌀 " + response.data.wind.speed + ".");
		return false;
	})
	.catch(error => {
		res.json(error.message);
		return false;
	});
});

Wikipedia Webhook
A function that will return short description about any information on Wikipedia.

app.get('/wiki', async (req, res) => {
	const m_content = req.query.m_content.toLowerCase();
	const search = m_content.includes('wiki:') ? m_content.split("wiki:")[1] : m_content;

	axios.get("https://en.wikipedia.org/w/api.php?format=json&action=query&prop=description&exintro&explaintext&redirects=1&titles=" + encodeURI(search))
	.then(response => {
		let obj = response.data.query.pages;
		let data = obj[Object.keys(obj)[0]] !== "-1" ? obj[Object.keys(obj)[0]].description : 'Sorry, I don\'t know 🥺';
		res.json(data);
		return false;
	})
	.catch(error => {
		res.json(error.message);
		return false;
	});
});

2- Incoming Webhooks

To send data to your customers directly from your website or web/mobile application, WA Web Plus is using Firebase as a realtime processor for the incoming requests, it’s easy to set up, and it will become even easier a few versions later when we get rid of Firebase and connect directly to WA Web Plus. However, you have to deal with Firebase Realtime Database for now.

Seting up the Realtime Database:

Go to console.firebase.google.com and setup a new project with any name you choose. Note down the slug that you see below the name beside the pencile icon, this is your project ID and we will need to use it later.

Follow this 3 simple steps to create the project, once your project is ready, click “Continue”.

On the left siebar, click “Realtime Databases” and then click “Create Database” button.

When creating the Database, you will be asked about the security rules of your database, click “Enable” and let’s move to the database “Rules” tab to change them from “false” to “true”, so that the connections can go through.

In the “Rules” tab, simply change the “false” values to “true” and hit the “Publish” button.

It’s all set up now, only one thing more is needed, which is an API key that tells the database that we’re authorized to access it remotely.

Luckily, Google Cloud Console creates the API Key automatically for you, all you need to do is go and copy it.

Select your project that we recently created, navigate to “APIs & Services” then go to “Credentials”, there you can find an API key that you can easily copy.

Now, we have everything we need. Let’s go back to WA Web Plus and fill all the required information. Go to the Webhooks section and click “Firebase Settings” button.

API KEY: AIzaSyAe_IYmS21kQw0t8ul0LOOF23CImvk_rFgw
Project ID: wa-web-plus-realtime-database

All we need to do is filling the information in the correct boxes. However, there is one required field missing, which is the “Data Child Node”, what is that? 🤔

We thought that you might use this Firebase project to manage multiple incoming webhooks, so in order to keep the data tidy and sorted correctly, you can create folders “nodes” inside your database to hold the data of your webhook, every webhook can have one node/folder to process the data inside it.

Add a new incoming Webhook, and put any folder name you want to handle your messages:

In our case, we will name our folder as “store“, because we will build a webhook that sends a confirmation message to the user WhatsApp account whenever he purchases a product from our store. 😊

Start Receving Incoming Requests

There are a lot of ways that you can send the request to WA Web Plus, you can do it with any automation service, or with your own code (if you’re a developer), or you can even trigger it manually from within your browser. In this example, we will cover sending the requests from automation services, such as Pabbly Connect, and it’s good to know that all of the automation services are similar when it comes to sending API requests. And we will also cover the custom coding part in case you want to do it manually with your own software.

1- Receiving Request via API URL

To send a WhatsApp message from outside WhatsApp to somebody, like sending a purchase confirmation message when a user checkout process is completed in your store, or when a form is submitted in your website, you will need to send this request in the following structure:

Endpoint URL: https://{your-project-id}.firebaseio.com/{data child node}.json

Request Parameters: {“phone”: “905366365288”, “content”: “Hi, this is a new message!”}

So, in our case, if you want to send a message to me from outside WhatsApp, your POST request must be sent to this URL:

https://wa-web-plus-realtime-database.firebaseio.com/store.json

An example with Pabbly Connect is:

Sending Files / Media Messages

To send media files, your image/video/file must be sent in base64 format, change your request parameters to the following structure:

{
  "phone": "905366365288",
  "content":   "....."
  "text": "Hi, this is a new message!",
  "type": "media"
}

Please note that the base64 string must include your file MIME type. There are thousands of online websites that convert your images/files to base64 format, you can use one of the following services to get the base64 string:

2- Receiving Request via Native JavaScript API

Useful details about Firebase JavaScript API can be found here. However, you can also use other languages, or using the native libraries for Android and iOS to control requests from within your mobile application.

The simplest code to send the request with JavaScript:

var config = {
	apiKey: "AIzaSyAe_IYmS21kQw0t8ul0LOOF23CImvk_rFgw",
	authDomain: "wa-web-plus-realtime-database.firebaseapp.com",
	databaseURL: "https://wa-web-plus-realtime-database.firebaseio.com",
	projectId: "wa-web-plus-realtime-database",
	storageBucket: "wa-web-plus-realtime-database.appspot.com",
};
firebase.initializeApp(config);
var database = firebase.database();

// Run this function on a button click or after a successfull purchase/signup
firebase.database()
.ref('store')
.set([{'phone': '905366365288', 'content': 'Hi, this is a new message!'}]);

Was this page useful?