This is a sample one to one video calling client application written in JavaScript that allows developers to implement video calling capabilities empowered with Face AI in their websites. The application runs on the web browsers (referred as client end point) and utilizes EnableX Web SDK to conduct an RTC session with its peers through EnableX Video Services.The client application performs the following tasks to facilitate an RTC session:
Get token from the application server Connect to the room using the token Publish audio/video streams in the room Subscribe to remote audio/video streams in the room Listen to any session related events This sample client application also demonstrates the following features:
Mute/Unmute video Mute/Unmute audio Session Recording Chat face AI Screen share Disconnect
- Create a free account on EnableX [https://www.enablex.io/free-trial/]
- Create your Project
- Get the App ID and App Key generated against the Project
- Check your browser compatibility with EnableX [https://developer.enablex.io/docs/quickstart/video/browser-compatibility/index/]
- Download latest copy of Web SDK (EnxRtc.js) [https://developer.enablex.io/downloads/EnxRtc.js.v2.3.30.zip] and replace client/js/EnxRtc.js
- Install all project modules. Run
npm install
- Install the project package dependencies. Run
yarn install
Use a valid SSL Certificate for your Domain and use it to configure your Web Service to make your domain accessible on HTTPS.
While this GitHub repository provides sample client code, you require an application server to provision video room on EnableX server. Use any of the Repository listed below to setup your application server:
- Laravel [https://github.com/EnableX/WebRTC-Open-Source-One-To-One-Video-Chat-Application-in-Laravel]
- PHP [https://github.com/EnableX/One-to-One-Video-Calling-Open-Source-PHP-Application]
- Nodejs [https://github.com/EnableX/One-to-One-Video-Chat-Sample-Web-Application]
- Python [https://github.com/EnableX/WebRTC-Python-Open-Source-Application-for-1-to-1-video-chat]
- C# [https://github.com/EnableX/One-to-One-Video-Calling-C-Sharp-Application]
Clone or download repository of your choice and configure the server as per the instructions given in the respective README document.
To directly try the sample code without having to configure an application server, you can also use the EnableX test server as explained in section 2. However, it is recommended to configure your own application server to build a video calling web app.
- Open the web browser and go to https://your-domain-name/path/client/ to load the application.
- If you don't have a Room ID, then create by clicking on the “Create Room” button. The Room ID will get prefilled in the form.
- Save the Room ID and share it with others along with the URL to join the Same Room.
- Enter your Name and choose your role, either as a Moderator or a Participant
- Allow access to the microphone when prompted.
- You are now in a video call with others, who have joined the same room.
Note: This sample application creates a virtual room with limited Participants and 1 Moderator for demonstration purposes.
As mentioned in section 1.1.4 above, you have an option to run your client application on EnableX pre-configured environment [https://try.enablex.io/] instead of setting up your own application server.
This allows you to quickly test the performance of EnableX audio calls before getting into the development of your application.
As the EnableX test server has been configured for demonstration purpose only, it only allows to:
- Conduct a single session with a duration lesser than 10 minutes.
- Host a multiparty call with less than 3 participants.
Refer to the Demo App Server [https://developer.enablex.io/docs/guides/video-guide/content/sample-codes/] for more information.
Once you have successfully tested your application on the test server, you can set up your application server as explained in section 1.1.4 above.
FaceAI allows you to add facial expression and facial emotion recognition AI to any website or app. The Face AI Web SDK [https://developer.enablex.io/docs/references/sdks/face-ai-sdk/face-ai-web-sdk/index/] offers APIs to detect a face in a video, assess the person’s age, gender, mood, and thought process based on subtle facial expressions.
Learn about How to implement Face AI in your application here [https://developer.enablex.io/docs/references/sdks/face-ai-sdk/face-ai-web-sdk/face-ai-web-sdk-3-1/how-to-use/].
The client APIs are called from the EnableX Web SDK (EnxRtc.js) which runs on the client browser. The client APIs are used to communicate with the EnableX video services and monitor the client-side state of the RTC session.
The client APIs are typically used to:
- Connect to the desired room using the token received from the application server
- Manage local audio and video
- Handle room and stream related events initiated by the user
The client APIs handle four major entities:
- EnableX Room: It handles room/session related events like connection, local stream publication, and remote stream subscription.
- EnableX Stream: It identifies audio/video/data stream published by the user.
- Events: It represents the events related to the room and the stream.
- Player: It represents the customizable UI element used to render the audio/video stream in the DOM.
In addition to the features demonstrated in this sample program, the SDK has many helpful APIs available for the developers to utilize like:
- File sharing
- Streaming
- Annotation
- Canvas
And many more such exciting features.
Read Web Toolkit Documentation [https://developer.enablex.io/docs/references/sdks/video-sdk/web-sdk/index/] for more details.
Download Web Toolkit [https://developer.enablex.io/downloads/EnxRtc.js.v2.3.30.zip] to get the latest version of Web SDK.
EnableX provides a library of Documentations, How-to Guides, and Sample Codes to help software developers, interested in embedding RTC in their applications.
Refer to the Complete Developer’s Guide [https://developer.enablex.io/] for more details.
You may also write to us for additional support at support@enablex.io.