Build your Own Notification System
This guide helps you build your own Notification System through making use of Gameball Notifications Webhook.
Notifications play a huge role in strengthening the bond between you and your customers (a.k.a. customers) as it helps them remain engaged with your service.
Gameball offers you some default ways for sending notifications to your customers such as having in-app notifications for web applications, and push notifications by integrating with firebase for mobile applications.
But what if you have your own notification system that you use to contact your customers. Maybe an SMS messaging system or a WhatsApp bot you own or any other services you use for this purpose such as firebase messaging, Amazon SNS or Twilio.
Gameball uses webhooks to notify your application when an event happens and a notification is needed to be delivered to your customer.
The webhook endpoint is just more code on your server, which could be written in Ruby, PHP, Node.js, or whatever you use. The webhook endpoint has an associated URL (e.g., https://yourdomain.com/webhookEndPoint ).
You will provide Gameball with your endpoint URL and whenever a customer should receive a notification, a POST request will be sent to your endpoint with required data in the request body.
In this tutorial we will walkthrough how to set up your own notification system with Gameball.
To begin using notification webhooks with Gameball you should follow these steps:
Build a notification webhook endpoint on your server.
Subscribe to the notification webhook in your dashboard.
Verify the webhook signature.
Build your own logic for sending notifications to your customer.
Code snippets used here are just for illustrations and they might not actually work.
Let's assume that you own a store that excels in selling video games and gift cards for gamers all over the world. You want to send notifications to your customers via your own notification channels that you use to communicate with your customers.
Configurations
There are some configuration steps that you need to do to set up your way for having webhooks.
Step 1: Build Notifications Endpoint On Your Server
First of all, you will need to prepare an endpoint on your server that Gameball notification webhook will POST generated notifications to.
The above function will be invoked when a POST request is sent to /GameballHooks/notification.
Step 2: Activate Notifications Webhook
In your Gameball dashboard, navigate to Admin Settings > Account Integration > Gameball Webhooks and add your notification endpoint URL (www.yourdomain.com/GameballHooks/notification in this example) to Notification Webhook.
and then click Update Webhook. Now, a POST request will be sent to your endpoint every time a notification is to be sent to your customer.
Step 3: Verifying Webhooks
You should verify that the incoming request is a legit request from Gameball and not a malicious request that tries to spam your system. You can achieve this by calculating a digital signature which is BASE64 encoded in X-GB-Signature header. You can get more information about webhook verification in this section.
Build Your Own Logic
Step 4: Write Your Own Logic
In the webhook request body, you will get all the needed data for you to send your customized notifications designated customers. Each notification item in the posted data will contain the playerUniqueId and locales with their titles and bodies. You can check the full data specification and example in the documentation here.
Here is an example of a notification data:
After receiving the notification, you can process it according to your preferences and you should have the flexibility of building whatever logic you need.
The below example demonstrates how SMS integration can be done with notification webhooks. Once a notification event is received, you will find the playerUniqueId
in the request body. You can use the received playerUniqueId
it to retrieve your customer's mobile number or any other required data from your database, then use an SMS Gateway to send an SMS to your customer.
And now your customers should receive an SMS message when they get a notification from Gameball.
Whatsapp Example
The next day your boss requested a slight change, that you need to also send WhatsApp messages to your customers in addition to sending SMSes.
You will need to have an integration with WhatsApp business API or any communication API as Twilio.
In your “/GameballHooks/notification” endpoint you will add the logic that sends WhatsApp message to your customer.
AWS SNS Push Notification Example
In addition to SMS and Whatsapp you are asked to send push notifications to your customers’ mobile devices as push notifications. There are some services that provide this service, we will use AWS SNS for this example.
AWS SNS uses device tokens to identify mobile devices. You store each customer's device token in your database.
In your “/GameballHooks/notification” endpoint you will add the logic that sends push notification to your customer mobile device.
By the end of this tutorial you should now be able to implement your own notification system using notifications hooks.
Last updated