Giter VIP home page Giter VIP logo

sunilgitb / zoom-clone-python Goto Github PK

View Code? Open in Web Editor NEW

This project forked from miroslavpejic85/mirotalksfu

0.0 0.0 0.0 10.66 MB

๐Ÿ† WebRTC - SFU - Simple, Secure, Scalable Real-Time Video Conferences Up to 4k, compatible with all browsers and platforms.

Home Page: https://sfu.mirotalk.com

License: GNU Affero General Public License v3.0

Shell 0.27% JavaScript 84.57% Python 0.07% PHP 0.10% CSS 4.12% HTML 10.82% Dockerfile 0.04%

zoom-clone-python's Introduction

MiroTalk SFU

Free WebRTC - SFU - Simple, Secure, Scalable Real-Time Video Conferences Up to 4k, compatible with all browsers and platforms.


sfu.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.
  • Desktop and Mobile compatible.
  • Translated in 133 languages.
  • Optimized Room URL Sharing for mobile.
  • Possibility to Password protect the Room for the meeting.
  • Lobby mode lets you protect your meeting by only allowing people to enter after a formal approval by a moderator.
  • Webcam Streaming up to 4K quality (Front - Rear for mobile).
  • Echo cancellation and noise suppression that makes your audio crystal clear.
  • Screen Sharing to present documents, slides, and more ...
  • File Sharing (with drag-and-drop), share any files to your participants in the room.
  • Take a snapshot from the video frame(screen/cam) to save it as an image on your device.
  • 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, execute the app features simply with your voice.
  • Push to talk, like a walkie-talkie.
  • Advance collaborative whiteboard for the teachers.
  • Select Microphone - Speaker and Video source.
  • Recording your Screen, Audio, or Video.
  • Share any YouTube video in real-time to your participants.
  • Share any mp4, webm, ogg video in real-time to your participants with possibility to download it.
  • Full-Screen Mode on mouse click on the Video element, Zoom In/Out on video mouse wheel.
  • Possibility to Change UI Themes.
  • Possibility to protect your Host with username and password (default disabled).
  • Supports REST API (Application Programming Interface).
  • Slack API integration.
  • Sentry for error reporting.
About
Direct Join

Note

When host protection is enabled the host needs to provide a valid username and password as specified in the app/src/config.js.

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://sfu.mirotalk.com/newroom"
    style="height: 100vh; width: 100vw; border: 0px;"
></iframe>
Quick Start
  • You will need to have NodeJS and all requirements installed, this project has been tested with Node version 16.X and 18.X.

  • Requirements install example for Ubuntu 20.04

# Gcc g++ make
$ apt-get update
$ apt-get install -y build-essential
# Python 3.8 and pip
$ DEBIAN_FRONTEND=noninteractive apt-get install -y tzdata
$ apt install -y software-properties-common
$ add-apt-repository -y ppa:deadsnakes/ppa
$ apt update
$ apt install -y python3.8 python3-pip
# NodeJS 18.X and npm
$ apt install -y curl dirmngr apt-transport-https lsb-release ca-certificates
$ curl -sL https://deb.nodesource.com/setup_18.x | bash -
$ apt-get install -y nodejs
$ npm install -g npm@latest
  • Start the server
# Clone this repo
$ git clone https://github.com/miroslavpejic85/mirotalksfu.git
# Go to to dir mirotalksfu
$ cd mirotalksfu
# Copy app/src/config.template.js in app/src/config.js and edit it if needed
$ cp app/src/config.template.js app/src/config.js
# Install dependencies - be patient, the first time will take a few minutes, in the meantime have a good coffee ;)
$ npm install
# Start the server
$ npm start
# If you want to start the server on a different port than the default use an env var
$ PORT=3011 npm start

Note To run MiroTalk SFU on a Windows operating system, you can follow the instructions provided in this documentation.

Docker

docker

# Copy app/src/config.template.js in app/src/config.js IMPORTANT (edit it according to your needs)
$ cp app/src/config.template.js app/src/config.js
# Copy docker-compose.template.yml in docker-compose.yml and edit it if needed
$ cp docker-compose.template.yml docker-compose.yml
# (Optional) Get official image from Docker Hub
$ docker-compose pull
# 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 following these documentation.

Self Hosting

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

Notes
  • Run the project on a Linux or Mac system as the mediasoup installation could have issues on Windows.
Rest API
# The response will give you a entrypoint / Room URL for your meeting.
$ curl -X POST "http://localhost:3010/api/v1/meeting" -H "authorization: mirotalksfu_default_secret" -H "Content-Type: application/json"
$ curl -X POST "https://sfu.mirotalk.com/api/v1/meeting" -H "authorization: mirotalksfu_default_secret" -H "Content-Type: application/json"
# The response will give you a entrypoint / URL for the direct join to the meeting.
$ curl -X POST "http://localhost:3010/api/v1/join" -H "authorization: mirotalksfu_default_secret" -H "Content-Type: application/json" --data '{"room":"test","password":"false","name":"mirotalksfu","audio":"false","video":"false","screen":"false","notify":"false"}'
$ curl -X POST "https://sfu.mirotalk.com/api/v1/join" -H "authorization: mirotalksfu_default_secret" -H "Content-Type: application/json" --data '{"room":"test","password":"false","name":"mirotalksfu","audio":"false","video":"false","screen":"false","notify":"false"}'
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 SFU instance on your dedicated cloud server, or for other needs, don't hesitate to contact us at [email protected]

DigitalOcean

DigitalOcean Referral Badge

For personal use, you can start with a single $5 a month cloud server and scale up as needed. You can use this link to get a $100 credit for the first 60 days.

If you need help to deploy MiroTalk SFU instance on your dedicated cloud server, or for other needs, don't hesitate to contact us at [email protected]

Live Demo

https://sfu.mirotalk.com

mirotalksfu-qr

Credits
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 [email protected] 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 P2P

Try also MiroTalk P2P, 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.

zoom-clone-python's People

Contributors

miroslavpejic85 avatar loranger avatar rogerdz avatar danghieu90 avatar armanism24 avatar philippdormann avatar iconio avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.