twilio-video-app-react
A collaboration application built with the twilio-video.js SDK and React.js
Top Related Projects
Jitsi Meet - Secure, Simple and Scalable Video Conferences that you use as a standalone app or embed in your web application.
RTCMultiConnection is a WebRTC JavaScript library for peer-to-peer applications (screen sharing, audio/video conferencing, file sharing, media streaming etc.)
WebRTC Web demos and samples
Quick Overview
The twilio/twilio-video-app-react
repository is a React-based application that provides a sample implementation of a video conferencing application using Twilio's Video API. It serves as a starting point for developers who want to build their own video conferencing solutions using Twilio's platform.
Pros
- Fully Open-Source: The project is open-source, allowing developers to inspect, modify, and contribute to the codebase.
- Twilio Integration: The application is built on top of Twilio's Video API, providing a reliable and feature-rich video conferencing solution.
- React-based: The application is built using React, a popular and widely-adopted JavaScript library for building user interfaces.
- Customizable: The application is designed to be easily customizable, allowing developers to modify the UI, add new features, and integrate it with their own applications.
Cons
- Dependency on Twilio: The application is heavily dependent on Twilio's services, which may not be suitable for all use cases or budgets.
- Limited Documentation: While the project has some documentation, it may not be comprehensive enough for all developers, especially those new to Twilio or React.
- Potential Learning Curve: Developers who are not familiar with React or Twilio's Video API may face a steeper learning curve when working with this project.
- Potential Performance Issues: Depending on the scale and complexity of the video conferencing application, the application may face performance challenges, which may require additional optimization efforts.
Code Examples
N/A (This is not a code library)
Getting Started
N/A (This is not a code library)
Competitor Comparisons
Jitsi Meet - Secure, Simple and Scalable Video Conferences that you use as a standalone app or embed in your web application.
Pros of jitsi-meet
- Open-source and self-hostable, providing more control over data and infrastructure
- Supports larger group calls with up to 100 participants
- Includes built-in features like screen sharing, chat, and recording
Cons of jitsi-meet
- May require more technical expertise to set up and maintain
- Less streamlined integration with other services compared to Twilio's ecosystem
- Can be more resource-intensive, especially for self-hosted instances
Code Comparison
jitsi-meet (JavaScript):
import { Jitsi } from 'react-jitsi'
<Jitsi
roomName="MyConferenceRoom"
displayName="John Doe"
onApiReady={(api) => console.log('Jitsi Meet API', api)}
/>
twilio-video-app-react (JavaScript):
import { Room, Participant } from 'twilio-video'
<Room roomName="MyConferenceRoom" token={twilioToken}>
{participants.map(participant => (
<Participant key={participant.sid} participant={participant} />
))}
</Room>
Both repositories provide React components for video conferencing, but jitsi-meet offers a more comprehensive, standalone solution, while twilio-video-app-react integrates tightly with Twilio's services for a more managed experience.
RTCMultiConnection is a WebRTC JavaScript library for peer-to-peer applications (screen sharing, audio/video conferencing, file sharing, media streaming etc.)
Pros of RTCMultiConnection
- More flexible and customizable, allowing for greater control over WebRTC implementation
- Supports a wider range of features, including screen sharing and file transfer
- Free and open-source, with no usage limits or costs
Cons of RTCMultiConnection
- Requires more setup and configuration compared to the Twilio-based solution
- Less robust documentation and support compared to Twilio's offerings
- May require more maintenance and updates to keep up with WebRTC standards
Code Comparison
RTCMultiConnection:
connection.socketURL = 'https://rtcmulticonnection.herokuapp.com:443/';
connection.session = {
audio: true,
video: true
};
connection.sdpConstraints.mandatory = {
OfferToReceiveAudio: true,
OfferToReceiveVideo: true
};
twilio-video-app-react:
const { connect, createLocalTracks } = require('twilio-video');
const room = await connect(token, {
name: 'my-room-name',
audio: true,
video: { width: 640, height: 480 }
});
The RTCMultiConnection code shows more granular control over the connection setup, while the Twilio-based solution offers a simpler, more abstracted approach to creating a video connection.
WebRTC Web demos and samples
Pros of samples
- Comprehensive collection of WebRTC examples covering various use cases
- Pure WebRTC implementation, providing a deeper understanding of the technology
- Regularly updated with the latest WebRTC standards and best practices
Cons of samples
- Requires more setup and configuration for production use
- Less abstraction, potentially leading to more complex code for beginners
- Limited built-in features compared to Twilio's solution
Code Comparison
samples:
const peerConnection = new RTCPeerConnection(configuration);
const dataChannel = peerConnection.createDataChannel("myChannel");
peerConnection.onicecandidate = event => {
if (event.candidate) {
sendToSignalingServer({ candidate: event.candidate });
}
};
twilio-video-app-react:
const room = await connect(token, {
name: roomName,
audio: true,
video: { width: 640, height: 480 }
});
room.on('participantConnected', participant => {
console.log(`Participant ${participant.identity} connected`);
});
The samples code shows raw WebRTC setup, while twilio-video-app-react abstracts much of the complexity, providing a higher-level API for video conferencing functionality.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Twilio Video React App
What is it
This application demonstrates a multi-party video application built with Twilio's Programmable Video JS SDK, Twilio's Conversations JS SDK, and Create React App.
- Deploy to Twilio Serverless in just a few minutes
- No other infrastructure is required
- No code changes are required before your first deploy
- There is no cost associated with deploying the app
- Standard usage charges apply for Twilio Video when using the app for video calls. The chat feature is built using the Conversations API and is free-of-cost up to 200 monthly active users, standard usage charges apply thereafter.
Prerequisites
You must have the following installed:
- Node.js v14+
- NPM v6+ (comes installed with newer Node versions)
You can check which versions of Node.js and NPM you currently have installed with the following commands:
node --version
npm --version
Clone the repository
Clone this repository and cd into the project directory:
git clone https://github.com/twilio/twilio-video-app-react.git
cd twilio-video-app-react
Install Dependencies
Run npm install
inside the main project folder to install all dependencies from NPM.
If you want to use yarn
to install dependencies, first run the yarn import command. This will ensure that yarn installs the package versions that are specified in package-lock.json
.
Add Noise Cancellation
Twilio Video has partnered with Krisp Technologies Inc. to add noise cancellation to the local audio track. This feature is licensed under the Krisp Plugin for Twilio. In order to add this feature to your application, please run npm run noisecancellation:krisp
immediately after the previous step.
Install Twilio CLI and RTC Plugin
Install the Twilio CLI
The app is deployed to Twilio using the Twilio CLI. You can install the Twilio CLI using Homebrew on a Mac or npm.
To install twilio-cli using npm, run the following command:
npm install -g twilio-cli
Note: If you run into permissions errors when installing the twilio-cli globally with the npm install -g
command, you might need to change the permissions of your global node_modules
directory or configure npm to use a different directory for globally installed npm packages. See this StackOverflow thread, which has more information about both options. This code sample in GitHub is also a helpful guide for how to install npm packages globally without needing to change directory permissions and without sudo.
Login to the Twilio CLI
Login to the Twilio CLI. You will be prompted for your Account SID and Auth Token, both of which you can find on the dashboard of your Twilio console.
twilio login
Note: If you installed the Twilio CLI using npm and you receive an error that the twilio
command is not found, you might need to update your Node install prefix. See this StackOverflow thread for more information.
Install the RTC Plugin
This app requires an additional plugin. Install the CLI plugin with:
twilio plugins:install @twilio-labs/plugin-rtc
Note: If you have previously installed the @twilio-labs/plugin-rtc
plugin, please make sure that you are using the most recent version. You can upgrade the plugin by running twilio plugins:update
. The chat feature requires version 0.8.1 or greater of @twilio-labs/plugin-rtc
.
Deploy the app to Twilio
Before deploying the app, make sure you are using the correct account on the Twilio CLI (using the command twilio profiles:list
to check).
The app is deployed to Twilio with a single command:
npm run deploy:twilio-cli
This performs the following steps:
- Builds the React app in the
src
directory - Generates a random code used to access the Video app
- Deploys the React app and token server function as a Twilio Serverless service.
- Prints the URL for the app and the passcode.
NOTE: The Twilio Function that provides access tokens via a passcode should NOT be used in a production environment. This token server supports seamlessly getting started with the collaboration app, and while convenient, the passcode is not secure enough for production environments. You should use an authentication provider to securely provide access tokens to your client applications. You can find more information about Programmable Video access tokens in this tutorial. As a precaution, the passcode will expire after one week. To generate a new passcode, redeploy the app:
npm run deploy:twilio-cli -- --override
View app details
View the URL and passcode for the Video app with
twilio rtc:apps:video:view
Delete the app
Delete the app with
twilio rtc:apps:video:delete
This removes the Serverless app from Twilio. This will ensure that no further cost are incurred by the app.
Troubleshooting The Twilio CLI
If any errors occur after running a Twilio CLI RTC Plugin command, then try the following steps.
- Run
twilio plugins:update
to update the rtc plugin to the latest version. - Run
twilio rtc:apps:video:delete
to delete any existing video apps. - Run
npm run deploy:twilio-cli
to deploy a new video app.
Features
The Video app has the following features:
- Video calling with real-time video and audio
- Chat support for textual and file-based messaging
- Enable/disable camera
- Mute/unmute mic
- Screen sharing
- Dominant speaker indicator
- Network quality indicator
- Defines participant bandwidth usage with the Bandwidth Profile API
- Start and stop recording with the Recording Rules API
- Virtual backgrounds with Video Processor library
Browser Support
See browser support table for twilio-video.js SDK.
Deeper dive
Running a local token server
This application requires an access token to connect to a Room for Video and a Conversation for Chat. The included local token server provides the application with access tokens. This token server can be used to run the app locally, and it is the server that is used when this app is run in development mode with npm start
. Perform the following steps to setup the local token server:
- Create an account in the Twilio Console.
- Click on 'Settings' and take note of your Account SID.
- Create a new API Key in the API Keys Section under Programmable Video Tools in the Twilio Console. Take note of the SID and Secret of the new API key.
- Create a new Conversations service in the Services section under the Conversations tab in the Twilio Console. Take note of the SID generated.
- Store your Account SID, API Key SID, API Key Secret, and Conversations Service SID in a new file called
.env
in the root level of the application (example below).
TWILIO_ACCOUNT_SID=ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_API_KEY_SID=SKxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_API_KEY_SECRET=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_CONVERSATIONS_SERVICE_SID=ISxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Now the local token server (see server/index.ts) can dispense Access Tokens to connect to a Room and a Conversation. See .env.example for information on additional environment variables that can be used.
Note: the use of Twilio Conversations is optional. If you wish to opt out, simply run or build this app with the REACT_APP_DISABLE_TWILIO_CONVERSATIONS
environment variable set to true
.
Running the App locally
Run the app locally with
npm start
This will start the local token server and run the app in the development mode. Open http://localhost:3000 to see the application in the browser.
The page will reload if you make changes to the source code in src/
.
You will also see any linting errors in the console. Start the token server locally with
npm run server
The token server runs on port 8081 and expects a POST
request at the /token
route with the following JSON parameters:
{
"user_identity": string, // the user's identity
"room_name": string, // the room name
}
The response will be a token that can be used to connect to a room. The server provided with this application uses the same endpoints as the plugin-rtc Twilio CLI plugin that is used to deploy the app. For more detailed information on the server endpoints, please see the plugin-rtc README.
Multiple Participants in a Room
If you want to see how the application behaves with multiple participants, you can simply open localhost:3000
in multiple tabs in your browser and connect to the same room using different user names.
Additionally, if you would like to invite other participants to a room, each participant would need to have their own installation of this application and use the same room name and Account SID (the API Key and Secret can be different).
Building
Build the React app with
npm run build
This script will build the static assets for the application in the build/
directory.
Tests
This application has unit tests (using Jest) and end-to-end tests (using Cypress). You can run the tests with the following scripts.
Unit Tests
Run unit tests with
npm test
This will run all unit tests with Jest and output the results to the console.
E2E Tests
Run end to end tests with
npm run cypress:open
This will open the Cypress test runner. When it's open, select a test file to run.
Note: Be sure to complete the 'Getting Started' section before running these tests. These Cypress tests will connect to real Twilio rooms and real Twilio conversations, so you may be billed for any time that is used.
Application Architecture
The state of this application (with a few exceptions) is managed by the room object that is supplied by the SDK. The room
object contains all information about the room that the user is connected to. The class hierarchy of the room
object can be viewed here.
One great way to learn about the room object is to explore it in the browser console. When you are connected to a room, the application will expose the room object as a window variable: window.twilioRoom
.
Since the Twilio Video SDK manages the room
object state, it can be used as the source of truth. It isn't necessary to use a tool like Redux to track the room state. The room
object and most child properties are event emitters, which means that we can subscribe to these events to update React components as the room state changes.
React hooks can be used to subscribe to events and trigger component re-renders. This application frequently uses the useState
and useEffect
hooks to subscribe to changes in room state. Here is a simple example:
import { useEffect, useState } from 'react';
export default function useDominantSpeaker(room) {
const [dominantSpeaker, setDominantSpeaker] = useState(room.dominantSpeaker);
useEffect(() => {
room.on('dominantSpeakerChanged', setDominantSpeaker);
return () => {
room.off('dominantSpeakerChanged', setDominantSpeaker);
};
}, [room]);
return dominantSpeaker;
}
In this hook, the useEffect
hook is used to subscribe to the dominantSpeakerChanged
event emitted by the room
object. When this event is emitted, the setDominantSpeaker
function is called which will update the dominantSpeaker
variable and trigger a re-render of any components that are consuming this hook.
For more information on how React hooks can be used with the Twilio Video SDK, see this tutorial: https://www.twilio.com/blog/video-chat-react-hooks. To see all of the hooks used by this application, look in the src/hooks
directory.
The VideoProvider component contains much of the logic that relates to connecting to video rooms and acquiring local input devices. The VideoProvider component exposes many properties and methods to the rest of the application through the useVideoContext hook. Similarly, the ChatProvider contains logic that relates to connecting to a Twilio Conversation, and it exposes properties and methods through the useChatContext hook.
Configuration
The connect
function from the SDK accepts a configuration object. The configuration object for this application can be found in src/utils/useConnectionOptions/useConnectionOptions.ts. In this object, we 1) enable dominant speaker detection, 2) enable the network quality API, and 3) supply various options to configure the bandwidth profile.
Track Priority Settings
This application dynamically changes the priority of remote video tracks to provide an optimal collaboration experience. Any video track that will be displayed in the main video area will have track.setPriority('high')
called on it (see the VideoTrack component) when the component is mounted. This higher priority enables the track to be rendered at a high resolution. track.setPriority(null)
is called when the component is unmounted so that the track's priority is set to its publish priority (low).
Google Authentication using Firebase (optional)
This application can be configured to authenticate users before they use the app. Once users have signed into the app with their Google credentials, their Firebase ID Token will be included in the Authorization header of the HTTP request that is used to obtain an access token. The Firebase ID Token can then be verified by the server that dispenses access tokens for connecting to a room.
See .env.example for an explanation of the environment variables that must be set to enable Google authentication.
Related
License
See the LICENSE file for details.
Top Related Projects
Jitsi Meet - Secure, Simple and Scalable Video Conferences that you use as a standalone app or embed in your web application.
RTCMultiConnection is a WebRTC JavaScript library for peer-to-peer applications (screen sharing, audio/video conferencing, file sharing, media streaming etc.)
WebRTC Web demos and samples
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot