Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mateusaquino/watchparty
▶️ [WIP] Start a Stremio session with friends: watch party, chat (soon) and share controls!
https://github.com/mateusaquino/watchparty
betterstremio plugin stremio
Last synced: 10 days ago
JSON representation
▶️ [WIP] Start a Stremio session with friends: watch party, chat (soon) and share controls!
- Host: GitHub
- URL: https://github.com/mateusaquino/watchparty
- Owner: MateusAquino
- License: mit
- Created: 2024-06-04T10:46:10.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-06-05T19:19:40.000Z (8 months ago)
- Last Synced: 2025-01-01T09:06:15.391Z (17 days ago)
- Topics: betterstremio, plugin, stremio
- Language: JavaScript
- Homepage:
- Size: 3.96 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
▶️ WatchParty is a BetterStremio session sharing plugin.
## 🎉 WatchParty
**WatchParty** is the first [BetterStremio](https://github.com/MateusAquino/BetterStremio) plugin ever made. It was developed to connect multiple Stremio sessions at once. You can use it to start a Stremio session with friends: create and join watch party, chat and share controls. No addon sharing required.
This Plugin works by intercepting events on the Stremio HTML5 Player and sharing to everyone in the party through a websocket connection. Currently there are two available servers to connect from: [Hugging Face (H)](https://mateusaquino-watchparty.hf.space) and [Hugging Face (U)](https://mateusaqb-watchparty.hf.space).
This repository is currently accepting contributions and suggestions, feel free to do so :)
Now we also feature a realtime chat with party members and you're allowed to use emojis and color codes in your name and messages.
## ▶️ Demo
This is a demo of WatchParty synchronizing three instances:
- Instance 1 (black): Patched `Stremio.exe` app with **MPV Player**
- Instance 2 (red): Patched Stremio Webapp (`127.0.0.1:11470`) with **HTML5 Player**
- Instance 3 (green): Patched Stremio Webapp (`127.0.0.1:11470`) with **HTML5 Player**https://github.com/user-attachments/assets/15bb9c95-692a-4150-973f-84bf9d33b2ab
Note: All instances were running on the same `server.js` (same Windows machine), which improved buffering. In a real scenario, use a high-availability stream and ensure everyone has a stable internet connection.
Chat features include:
- Colored messages
- Styled messages (bold, italic, underline, mts, ...)
- Emojis
- Message history (navigate using the up and down arrow keys)## 🌐 WatchParty Server
WatchParty is meant to be open for the public, but if you need to work on something locally you can also setup your own server.
### Local server
You can Setup a local server by running:
```bash
git clone https://github.com/MateusAquino/WatchParty
npm i
npm start
```A WatchParty server instance will be up at `localhost:3000`.
You may also change the env variables if needed: `PORT` and `SERVER_PREFIX` (single letter, defaults to `L`).This repository also contains the `Dockerfile` used to host the websocket server at [Hugging Face](https://huggingface.co/spaces/MateusAquino/WatchParty/tree/main).
### Server Connection
Connection protocol params must be separated by `#` and encoded (`encodeURIComponent`):
#### Create Party
- protocol: `c`
- `param[1]`: WatchParty protocol version
- `param[2]`: Username (string)
- `param[3]`: Party Password (string)
- `param[4]`: Party Name (string)
- `param[5]`: Join as Host? (1/0)Usage example: `c#1#John#123#Example%20Party#1`
#### Join Party
- protocol: `j`
- `param[1]`: WatchParty protocol version
- `param[2]`: Username (string)
- `param[3]`: Party Code (string)
- `param[4]`: Party Password (string)Usage example: `c#1#Jane#LJ7HLC#123`
### Packets
#### Server Packets
```elixir
upgrade -> Sent if protocol version mismatch
party: -> Returns a JSON party whenever there is a host/clients update
msg:: -> Returns the user id and the message broadcasted to the party
cmd:: -> Returns a JSON command used by WatchParty to sync actions and the sum of latencies from one client to another (example `cmd:130:go:["player", {...}]`)
badroom -> Sent if room code/password is wrong
ping -> Awaits for pong message (30s timeout)
```Note: party packet returns the generated code, the first letter should be unique for each server (or "L" for local)
#### Client Packets
```elixir
msg: -> Broadcasts message to party
toggle: -> Toggles user host privileges (must be a host & > 1 host in the party)
cmd: -> Broadcasts JSON command to party (must be a host)
pong -> Ping response
```