Skip to content

Relaxpuke/relaxp

 
 

Repository files navigation

MiroTalk P2P

Free WebRTC - P2P - Simple, Secure, Fast Real-Time Video Conferences Up to 4k and 60fps, compatible with all browsers and platforms.


p2p.mirotalk.com



For questions, discussions, help & support, join with us on discord


Features
  • Is 100% Free - Open Source - Self Hosted and PWA!
  • No download, plug-in, or login required, entirely browser-based
  • Unlimited number of conference rooms without call time limitation
  • Translated in 133 languages
  • Host protection to ensure unauthorized access to your host
  • Possibility to Password protect the Room for the meeting
  • Desktop and Mobile compatible
  • Optimized Room URL Sharing for mobile
  • Webcam Streaming (Front - Rear for mobile)
  • Audio Streaming crystal clear with detect speaking and volume indicator
  • Screen Sharing to present documents, slides, and more...
  • File Sharing (with drag-and-drop), share any files to your participants in the room
  • Select Audio Input - Output and Video source
  • Ability to set video quality up to 4K and 60 FPS
  • Recording your Screen, Audio and Video
  • Snapshot the video frame and save it as image png
  • Chat with Emoji Picker to show you feeling, private messages, Markdown support, possibility to Save the conversations, and many more
  • ChatGPT (openAI), designed to answer users' questions, provide relevant information, and connect them with relevant resources
  • Speech recognition to send the speeches
  • Push to talk, like a walkie-talkie.
  • Advance collaborative whiteboard for the teachers
  • Share any YT Embed video, video mp4, webm, ogg and audio mp3 in real-time
  • Full-Screen Mode on mouse click on the Video element, Pin/Unpin, Zoom in-out video element
  • Possibility to Change UI Themes
  • Right-click on the Video elements for more options
  • Direct peer-to-peer connection ensures the lowest latency thanks to WebRTC
  • Supports REST API (Application Programming Interface)
  • Slack API integration
  • Sentry for error reporting
  • ...
About
Start videoconference
Direct Join

Note

When host protection is enabled the host needs to provide a valid username and password as specified in the .env.

After host authentication, participants can join the room using any of the following URL formats:

Embed a meeting

Embedding a meeting into a service or app using an iframe.

<iframe
    allow="camera; microphone; display-capture; fullscreen; clipboard-read; clipboard-write; autoplay"
    src="https://p2p.mirotalk.com/newcall"
    style="height: 100vh; width: 100vw; border: 0px;"
></iframe>
Quick start
  • You will need to have Node.js installed, this project has been tested with Node versions 12.X, 14.X, 16.X and 18.x.
# clone this repo
$ git clone https://github.com/miroslavpejic85/mirotalk.git
# go to mirotalk dir
$ cd mirotalk
# copy .env.template to .env (edit it according to your needs)
$ cp .env.template .env
# install dependencies
$ npm install
# start the server
$ npm start
Docker

docker

# copy .env.template to .env (edit it according to your needs)
$ cp .env.template .env
# Copy docker-compose.template.yml in docker-compose.yml (edit it according to your needs)
$ cp docker-compose.template.yml docker-compose.yml
# Get official image from Docker Hub
$ docker pull mirotalk/p2p:latest
# create and start containers
$ docker-compose up # -d
# to stop and remove resources
$ docker-compose down
Ngrok - Https

You can start videoconferencing directly from your Local PC, and be reachable from any device outside your network, simply by reading these documentation, or expose it directly on HTTPS

Stun & Turn

Install your own Stun & Turn by following this steps.

Rest API
# The response will give you a entrypoint / Room URL for your meeting, where authorization: API_KEY_SECRET.
$ curl -X POST "http://localhost:3000/api/v1/meeting" -H "authorization: mirotalk_default_secret" -H "Content-Type: application/json"
$ curl -X POST "https://p2p.mirotalk.com/api/v1/meeting" -H "authorization: mirotalk_default_secret" -H "Content-Type: application/json"
$ curl -X POST "https://mirotalk.up.railway.app/api/v1/meeting" -H "authorization: mirotalk_default_secret" -H "Content-Type: application/json"

API Documentation

The API documentation uses swagger at http://localhost:3000/api/v1/docs. Or check it out on live.

Hetzner

Hetzner

This application is running for demonstration purposes on Hetzner, one of the best cloud providers and dedicated root servers.


Use my personal link to receive €⁠20 IN CLOUD CREDITS.


If you need help to deploy MiroTalk P2P instance on your dedicated cloud server, or for other needs, don't hesitate to contact us at p2p.mirotalk@gmail.com

Live Demos

https://p2p.mirotalk.com

hetzner-qr


https://mirotalk.up.railway.app

railway-qr

Self Hosting

To Self-Host MiroTalk P2P on Your dedicated Server, read this documentation.

Security

For Security concerning, please follow this documentation.

Credits
  • ianramzy (html template)
  • vasanthv (webrtc-logic)
  • fabric.js (whiteboard)
Contributing
  • Contributions are welcome and greatly appreciated!
  • Just run before npm run lint
License

AGPLv3

MiroTalk is free and can be modified and forked. But the conditions of the AGPLv3 (GNU Affero General Public License v3.0) need to be respected. In particular modifications need to be free as well and made available to the public. Get a quick overview of the license at Choose an open source license.

For a MiroTalk license under conditions other than AGPLv3, please contact us at license.mirotalk@gmail.com or purchase directly from CodeCanyon.

Support the project

Do you find MiroTalk useful?

Support the project by becoming a backer or sponsor. Your logo will show up here with a link to your website.

BroadcastX Hetzner
LuvLounge QuestionPro
BrowserStack CrystalSound

MiroTalk SFU

Try also MiroTalk SFU, the difference between the two projects you can found here.

MiroTalk C2C

Try also MiroTalk C2C cam 2 cam.

MiroTalk WEB

Try also MiroTalk WEB rooms scheduler.

This project is tested with BrowserStack.

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 56.9%
  • HTML 27.1%
  • CSS 15.1%
  • Shell 0.5%
  • Makefile 0.1%
  • PHP 0.1%
  • Other 0.2%