You have unlimited access as a PRO member
You are receiving a free preview of 3 lessons
Your free preview as expired - please upgrade to PRO
Contents
Recent Posts
- Object Oriented Programming With TypeScript
- Angular Elements Advanced Techniques
- TypeScript - the Basics
- The Real State of JavaScript 2018
- Cloud Scheduler for Firebase Functions
- Testing Firestore Security Rules With the Emulator
- How to Use Git and Github
- Infinite Virtual Scroll With the Angular CDK
- Build a Group Chat With Firestore
- Async Await Pro Tips
SMS Texting With Twilio and Firebase Cloud Functions
Episode 48 written by Jeff DelaneySending SMS text messages to users can push the user experience to the next level. In this lesson, we are going to use the Programmable SMS API from Twilio to notify users when their pizza order has been updated.
Initial Setup
We’re going to build a confirmation page for a pizza ordering app. After a customer orders a pizza, they want to stay updated its status. Our feature will send them an SMS text message whenever the status is updated in the Firebase database.
Prerequisites
This lesson assumes you have an Angular app with firebase configured via AngularFire2. You should also have basic knowledge of Firebase Cloud Functions.
Sign up for Twilio
First, you will need to have a Twilio account, which uses pay-by-volume pricing model. You can sign up for a free preview and they will give you a $15 USD credit to play around with the API.
Angular Component
Our component is just a hard coded mockup of an order status page. You can think of this as a page where an admin user would update the status of an order.
ng g component pizza-status |
Data Structure
I have added an orders collection to the database with some dummy data.
Add Reactive Forms to NgModule
Make sure you import the Reactive forms module in the NgModule associated with this component. In this example it is the app.module.ts
file.
import { PizzaStatusComponent } from './pizza-status/pizza-status.component'; |
pizza-status.component.ts
The Angular component will use a reactive form to collect and validate a phone number for the user. We are required to format this number to an E164 string (looks like +19165551234) before sending it to Twilio. The form validations will be handled with the reactive forms module in Angular.
The order status will be updated on the confirmation page asychronously. At that exact moment, we will also trigger a Firebase Cloud Function that tells Twilio to send the text.
import { Component, OnInit } from '@angular/core'; |
pizza-status.component.html
This demo is using ngClass
with CSS classes from the Bulma framework to change the background of the order status.
<h1>Order Status: |
Twilio Cloud Function
Now the fun can begin. Our goal is to send the user a text message whenever their order status has been updated. When the pizza goes from cooking to on its way, the user should get a SMS text message from Twilio saying “Your order is on its way with the driver”.
Initialize Firebase Cloud Functions
If you’re not already using Firebase Cloud Functions, you can get started by running:
firebase init functions |
Then we will add the Twilio API key to the cloud function environment.
firebase functions:config:set twilio.sid="YOUR_ACCOUNT_SID" twilio.token="YOUR_AUTH_TOKEN" |
Make sure you are in the functions directory, then install the twilio helper for NodeJS.
cd functions |
Database Cloud Function that Sends SMS Texts
The cloud function uses the onUpdate
trigger to run code when the order status changes. Here’s a step by step breakdown of how the function works.
You need to have billing enabled on your Firebase account to send 3rd party API calls.
- Initialize Firebase and Twilio with API credentials.
- Listen to the
/orders/$orderKey/status
ref in the database, run function on changes. - Get the full order from the database.
- If order has a valid E164 number, make API call to Twilio.
- Wait from Twilio’s response and we’re done.
const functions = require('firebase-functions'); |
Deploy the Function
The final step is to deploy the function.
firebase deploy --only functions |
When you update the status property on the order, you should get a text to the supplied phone number each time you update the associated order status. If you run into problems, check the FCF logs or reach out to our Slack team. Good luck!
The End
Twilio combined with Firebase Cloud Functions makes it easy to send text messages to users. Let me know what you want to see next in the comments or via Slack.