Skip to content

Complete one-to-one WebRTC example with VanillaJS. FrontEnd + Signaling. 100% test coverage.

Notifications You must be signed in to change notification settings

0xc14m1z/webrtc-one-to-one

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

86 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

webrtc-one-to-one

Run locally

Make sure that you have node installed, the server depends on it.

Run npm install to install dev dependencies.

Run the server

npm run server:start

Run the application

Before running the client, the server needs to be run as described before.

npm start

After the build, visit http://localhost:1234/index.html

Check the layout

After starting the application as described before, there are 4 pages to check different permutations of horizontal and vertical videos.

Protocol


CALLER                           SIGNALING SERVER                        RECIPIENT
--------------------------------------------------------------------------------------------------

CONNECT ----------------------->
{ as }

       <------------------------ USERNAME_TAKEN

       <------------------------ CONNECTED

REQUEST_CALL ------------------> CALL_REQUESTED ----------------------->
{ to }                           { from }

       <------------------------ UNKNOWN_RECIPIENT

       <------------------------ CALL_ACCEPTED <------------------------ ACCEPT_CALL
                                 { by }                                  { from }

       <------------------------ CALL_REJECTED <------------------------ REJECT_CALL
                                 { by }                                  { from }

SEND_CALLER_DESCRIPTOR --------> CALLER_DESCRIPTOR_RECEIVED ----------->
{ to, sdp }                      { from, sdp }

       <------------------------ RECIPIENT_DESCRIPTOR_RECEIVED <-------- SEND_RECIPIENT_DESCRIPTOR
                                 { from, sdp }                           { to, sdp }

SEND_ICE_CANDIDATE ------------> ICE_CANDIDATE_RECEIVED --------------->
{ to, candidate }                { from, candidate }

       <------------------------ ICE_CANDIDATE_RECEIVED <--------------- SEND_ICE_CANDIDATE
                                 { from, candidate }                     { to, candidate }

Layers

Signal

An object that provides a nice interface for handling the above protocol with json-encoded comunications with the signaling server.

Client

This object shall use the Signal one to handle the protocol messages exchange taking care of the RTC* stuff. This object is the interface to the application.

About

Complete one-to-one WebRTC example with VanillaJS. FrontEnd + Signaling. 100% test coverage.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published