Receive WhatsApp Media Messages Using Go

Overview

This guide shows how to receive WhatsApp messages on a phone number registered to your WhatsApp business account. Typical use cases for receiving messages include customer support,  opt-in and opt-out messages and other customer interactions.

You can start receiving WhatsApp text messages using our APIs. Follow the instructions below.

Prerequisites

To get started, you need a Plivo account — sign up with your work email address if you don’t have one already. If this is your first time using Plivo APIs, follow our instructions to set up a Go development environment.

To receive incoming messages, you must have an onboarded WhatsApp account with inbound capable numbers registered against the same. If the number is in connected state, it can receive incoming messages.

Create a Go server to receive messages

Create a file called receive_whatsapp.go and paste into it this code.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
package main

import (
	"net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
	fromnumber := r.FormValue("From")
	tonumber := r.FormValue("To")
	media := r.FormValue("Media1")
	print("Message Received - ", fromnumber, " ", tonumber, " ", media)
}

func main() {
	http.HandleFunc("/receive_whatsapp/", handler)
	http.ListenAndServe(":8080", nil)
}

Configure Webhook URL in your WhatsApp Business Account

As shown below, you can very easily add/update webhook url against a WhatsApp Business Account. Once this step is concluded, you are good to receive incoming messages.

Test