• Stars
    star
    357
  • Rank 115,190 (Top 3 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created over 7 years ago
  • Updated 11 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

WebRTC Video Room is a Single-Page App in React using React Router that provides peer-to-peer video and audio communication in a web browser with no plugins or extensions required.

WebRTC video chat app with ReactJS

Synopsis

WebRTC audio/video conferencing app with user authentication using ReactJS.

Motivation

Simple ReactJS app that interacts with the WebRTC APIs to establish audio/video conference between 2 users, without a trip through a server.

Application Logic and Implementations

To connect two users over WebRTC, we exchange information to allow browsers to talk to each other. This process is called signaling and it is facilitated by using NodeJS and socket server chained to the express 4.0 engine to provide the plumbing. Other than signaling, no data has to be sent through a server. When a connection is successfully established and authentication and authorization are complete, stream data exchanged between peers is directed to a React component for rendering.

Demo

Demo of the app can be found on Heroku: https://webrtc-video-room-34aecfad71b7.herokuapp.com/

Installation

Once you have cloned this project, go ahead and

NPM

Use npm through the command line to install all required dependecies:

npm i
npm start

Docker

Or use it with Docker:

docker build -t webvideo .
docker run -d -p 3000:3000 webvideo

Access

The app can be accessed at:

https://localhost:3000

License

MIT License

Copyright (c) 2015 Dian Dimitrov

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

More Repositories

1

express-es6-template-engine

Rendering engine for Express that uses ES6 javascript string templates as syntax.
JavaScript
193
star
2

MP3-to-Base64-Encoder-and-Decoder

Converting mp3 audio to and from base64 string
HTML
18
star
3

zombie-breakout

C / SDL2 2D game ported to WebAssembly through Emscripten.
C
15
star
4

es6-single-page-app

ES6 single page application boilerplate without a framework.
JavaScript
13
star
5

express-mongoose-passport-token-login

User session and token authentication Node.js app with express, mongoose, passport, passport-local and passport-local-mongoose.
JavaScript
5
star
6

buddyracer

Check out this realistic motorcycle physics controlling and bike maneuvering game. This game is provided in the following formats: apk, html and web app
Java
3
star
7

google-line-chart

Backbone.js and Google Line Chart API with real time - updates simulation
JavaScript
2
star
8

virtual-joystick

JavaScript
2
star
9

AlienSiege

The game itself was supposed to be a Space Invaders clone entirely conceived and developed with SVG and Javascript.
Java
2
star
10

site-plan

A site plan is a top view, bird's eye view of a property that is drawn to scale. A site plan can show: property lines. outline of existing and proposed buildings and structures
JavaScript
1
star
11

node-express-hogan-i18n-example

Simple node express hogan i18n example with responsive design. Node.js server using Express, Hogan-Express template engine and i18n multilingual translation module with layout template and default header, navigation and footers already setup.
JavaScript
1
star
12

floors

Floor plan
JavaScript
1
star