Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tannergabriel/webrtc-video-broadcast
WebRTC video/audio broadcast
https://github.com/tannergabriel/webrtc-video-broadcast
socket-io webrtc webrtc-call webrtc-video
Last synced: 4 days ago
JSON representation
WebRTC video/audio broadcast
- Host: GitHub
- URL: https://github.com/tannergabriel/webrtc-video-broadcast
- Owner: TannerGabriel
- License: mit
- Created: 2020-01-01T17:53:06.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2025-01-12T00:17:04.000Z (10 days ago)
- Last Synced: 2025-01-18T07:04:46.969Z (4 days ago)
- Topics: socket-io, webrtc, webrtc-call, webrtc-video
- Language: JavaScript
- Homepage:
- Size: 63.5 KB
- Stars: 524
- Watchers: 9
- Forks: 193
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# WebRTC Video/Audio Broadcast
WebRTC PeerToPeer broadcast application that allows the broadcaster to send a video and audio stream to all connected users (watchers).
You can find the tutorial that explains the code and functionality on my [website](https://gabrieltanner.org/blog/webrtc-video-broadcast).
## Getting started
### Starting the application
Start the application using Node:
```bash
# Install dependencies for server
npm install# Run the server
node server
```Start the application using Docker:
```bash
# Building the image
docker build --tag webrtcvideobroadcast .# Run the image in a container
docker run -d -p 4000:4000 webrtcvideobroadcast
```### Testing the application
The application should now be running on your localhost:4000 and you test it by connecting to localhost:4000/broadcast.html to add a new broadcaster.
After that, you just need to visit localhost:4000 to connect to the server as a client and you should get the video that is streamed from the broadcaster.
## Adding a TURN server
A TURN server is used to relay traffic if a direct peer-to-peer connection fails and is required for most WebRTC applications since a direct connection is often not possible between two clients that aren't on the same network. This repository doesn't include the usage of a TURN server by default, but you can add one by commenting in the turn configuration in the `broadcast.js` and `watch.js` file and filling in your TURN credentials.
There are several options on how you can create your own TURN server. Here are just two common ones:
- [Coturn](https://github.com/coturn/coturn)
- [Golang WebRTC pion library TURN examples](https://github.com/pion/turn/tree/master/examples)You can also use TURN servers from cloud providers or other companies. Here is a [tutorial](https://gabrieltanner.org/blog/turn-server) that shows you how to set up Coturn and add a domain to your TURN server.
## Author
Gabriel Tanner
## Support me
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE) file for details