Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coloquium/kollokvium
Online meetings made easy, secure and private for everyone!
https://github.com/coloquium/kollokvium
audio chat conference e2ee fileshare filesharing p2p-streams realtime-messaging recording translation typescript video webrtc
Last synced: 3 months ago
JSON representation
Online meetings made easy, secure and private for everyone!
- Host: GitHub
- URL: https://github.com/coloquium/kollokvium
- Owner: coloquium
- License: mit
- Created: 2020-03-09T15:02:05.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-02-19T14:15:31.000Z (11 months ago)
- Last Synced: 2024-08-03T17:12:34.273Z (6 months ago)
- Topics: audio, chat, conference, e2ee, fileshare, filesharing, p2p-streams, realtime-messaging, recording, translation, typescript, video, webrtc
- Language: TypeScript
- Homepage: https://kollokvium.se/
- Size: 35.2 MB
- Stars: 42
- Watchers: 11
- Forks: 13
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-webrtc - kollokvium - Online meetings made easy, secure and private for everyone. (Projects / Video Conference)
README
# Kollokvium (colloquium)
## About
Engaging in digital meetings should be simple, secure and not require installation of software, just a browser and an internet connection.
Unnecessary logins, user registrations and data should not flow through third parties, but between the peers involved in the meeting, this makes the connection private and also resilient against overloaded servers that applications like skype and discord may experience under high load, which often happens in a crisis.
> Our digital meetings should be flexible, resilient and protected!
Kollokvium target companies, associations and individuals, both young and old, perhaps especially those without any deeper computer experience as it requires no installation or signup and can be started simply by following a link and clicking start.
Unlike many other video conferencing technologies we passes everyone’s Media Streams to all participants, rather than sending the to a central media server for mixing the streams, The result is lower latency, better quality, privacy and security, as data flow P2P , there is now middleman involved, except in the setup phase of the room's (negotiation), not nothing is stored at server(s) and data is ofcourse encrypted, our server is just a message broker (signaling and state of rooms) .
The system uses standardized native technologies such as WebRTC, the open standard for Web communication. We also leverage the power of the technology already in our end-users hands - don't reinvent the wheel again!
Our implementation adds advanced video routing concepts such as stream forwarding, bandwidth estimations and many other things.
## Feature list (current)
1. 1-many participants ( P2P Streams )
2. Instanet messages/Chat (P2P DataChannels) with **immediate translation**
3. Share files (P2P DataChannels) - fast and secure **no uploads**.
4. Screen sharing, Chooose between tab's, windows or the desktop. - P2P Streams
5. Random room generator or user-defined room names
6. No login and registration required
7. Multiple stream recording ( record the meeting or single participant ), Recording done locally.
8. Lock / unlock rooms
9. Subtitles / captions (Speech recognition)
10. Auto translate of Subtitles / captions ( from source to prefered language)
11. Picture-In-Picture support (renders all streams into PiP element)
12. Active speaker - Indication of who is talking
13. Active speaker view and grid view
14. E2EE , Currently disabled
15. Electron clients ( can be found in this repo https://github.com/coloquium/kollokvium-electron )
16. Virtual backgrounds (secure) - Predefined or custom virtual backgrounds - **clientside only**..and more
## Hotkeys aka keyboard shortcuts
`ctrl-l` Request low resolution media streams from all connected participanyts.
`ctrl-r` Start / stop recording of meeting ( applies to recoring of everyone participating)
`ctrl-g` Toogle active-speaker vide / grid view (default).
`ctrl-m` Mute / un-mute microphone.
`ctrl-v` Mute / un-mute camera.
`ctrl+q` Mute / un-mute all audio.
`ctrl+s` Enable / disable subtitles (captions).
`ctrl+i` Hide / show chat & fileshare window.
`ctrl-u` Get statistics for each RTCPeerConnection. Generate 1-n HTML based reports that is passedf back to client as downloadable files.
`ctrl-b` Start/stop recording of each stream individually.
## Planned features / addons
`broadcast mode` - A view/mode where user can create a room/space for 1-many broadcasts for lectures, presentations and such scenarios
`advanced mode` - A view/mode that let's the "organizer" (meeting creator) mute video/audio remotly,kick, ban, lock and set meeting pin-codes etc. **2022-01-31 - Currently developing ***
## Install
Clone the repository and run `npm install` see package.json for build scripts.## Build scripts
See package.json ( scripts section/object)
## Quick deploy guides
## Local development
Build and and launch using `npm start` and then browse to `localhost:1337` or for frontend only development use `npm start:debug` which is much smoother. Pleaase note
that npm start:debug is using a shared wss server hosted by us by default. please study scripts sections of `package.json` for futher information.### Azure deploy
To deploy to Azure you need an Azure account, and you need to create an Azure Wep Application, and a storage account to host the Static Website.### Heroku apps
Fork the repository and connect to Heroku and run deploy, modify settings.json### Deploy front end only
If you want to deploy only the front-end as a static site, build the application and copy all the files from dist/client folder to the root of you web application.## Issues & Questions
Good Luck, and if run into problems, bugs or questions or just have ideas to share. post them here under issues (https://github.com/coloquium/kollokvium/issues)
## Other
Thanks to Sami Anas, https://www.pexels.com/sv-se/@samianas for greate background image we currently use.
Regards
Team Kollokvium (colloquium)