Grant Video Access Tokens with Your Express + TypeScript Video API
So you've built a video API with Twilio Programmable Video, Node.js, TypeScript, and Express. You've added CORS support so that your future video app will be able to access resources on your server. What's next?
In order for users to actually be able to connect to video rooms in your app, they will need to be authenticated using an access token. In this tutorial, you'll update your Express + TypeScript video API to add a new route that grants access tokens to the users who will be using your video app. Let's get started!
Prerequisites
You will need:
- A free Twilio account. (If you register here, you'll receive $10 in Twilio credit when you upgrade to a paid account!)
- Node.js (version 14.16.1 or higher) and npm installed on your machine.
- HTTPie or cURL.
- The code from the previous tutorial (see below).
The rest of this tutorial builds on the code you wrote in the previous tutorial for adding CORS support to your video API. If you don't already have that code, you can find it in this GitHub repository on the added-cors branch. Follow the instructions in the repository's README.md file to get up and running.
Once you've run the command npm run start
, you should see a log in your terminal telling you that your server is running on port 5000:
You’re ready to begin!
Create an auth router
You already have a router in your code for handling video-room-related requests. It’s time to create a new router that will handle your authorization requests. In the case of your video API, this will be the part of the API that generates a signed access token and returns it to the client side so that your users can join a video room.
Navigate to the src directory and create a new file called auth.ts. This is where your auth router will live.
Open this file in your code editor and add the following imports at the top of the file:
Then, create a new router to handle authorization requests:
Next, add the constants below. These constants represent the access token you will create for the user, the video grant that will be attached to that token, and the maximum amount of time a participant's session in a video room can last:
Now, create the route that will generate your access token:
Inside your new route, write some code to get the user's unique identifier (userId
) and the video room's unique identifier (roomSid
) from the incoming API request:
Make sure to handle the case where any environment variables may be missing. They shouldn't be missing, but it's good to handle situations like this just in case. If an environment variable is missing, return an error response early, letting the client side know that the server was not able to generate an access token:
Next, add the following code to create a new AccessToken
, associate it with the user, and grant access to the specific video room whose roomSid
was passed into the API request:
Return the access token to the client in the JSON response:
The completed route should look like the code below:
Finally, export your authRouter
so it can be used by other parts of your server:
Your auth router is complete!
Import and test your auth router
Open src/index.ts in your code editor. Import your authRouter
by adding the following line just below the other imports at the top of the file:
Then, just above the roomsRouter
line, add the following code that will let your server use this authRouter
for all requests to the /auth
URI:
Alright! You've got all the code you need. It's time to test out retrieving an access token!
For testing purposes, try to generate an access token for a user with the username Beyoncé
who wants to join a video room in your app that has a roomSid
of RM12345678901234567890123456789012
.
If you are using HTTPie, run the following command in your terminal:
If using cURL, run this command instead:
In the response, you will see that an access token was created and returned to you!
Awesome!
If you would like to see the code for this tutorial in its entirety, feel free to check it out on the access-token-added branch of this GitHub repository.
What to build next with your Express + TypeScript video API and Twilio Programmable Video
Your video API is now able to provide access tokens for your users. You're all set to connect this API to the client-side app of your choice. What kind of exciting app will you be adding video to? A chat app perhaps? A screen-sharing app? Or perhaps you want to try your hand at using Twilio Functions to generate your access tokens instead? The sky's the limit! ⭐️
I can't wait to see what you build!
Mia Adjei is a Software Developer on the Developer Voices team. They love to help developers build out new project ideas and discover aha moments. Mia can be reached at madjei [at] twilio.com.
Related Posts
Related Resources
Twilio Docs
From APIs to SDKs to sample apps
API reference documentation, SDKs, helper libraries, quickstarts, and tutorials for your language and platform.
Resource Center
The latest ebooks, industry reports, and webinars
Learn from customer engagement experts to improve your own communication.
Ahoy
Twilio's developer community hub
Best practices, code samples, and inspiration to build communications and digital engagement experiences.