Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fallenastaroth/varus
Web application with synchronized player for watching YouTube, Anime and other videos with friends.
https://github.com/fallenastaroth/varus
aiohttp anilibria playerjs socket-io vuejs watch-together youtube
Last synced: 2 months ago
JSON representation
Web application with synchronized player for watching YouTube, Anime and other videos with friends.
- Host: GitHub
- URL: https://github.com/fallenastaroth/varus
- Owner: FallenAstaroth
- Created: 2023-06-06T16:06:56.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-10T08:08:07.000Z (4 months ago)
- Last Synced: 2024-09-10T10:21:14.061Z (4 months ago)
- Topics: aiohttp, anilibria, playerjs, socket-io, vuejs, watch-together, youtube
- Language: Vue
- Homepage:
- Size: 4.46 MB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## πΊοΈ Navigation
* [Current features](#-current-features)
* [Deployment](#%EF%B8%8F-deployment)
* [Backend](#%EF%B8%8F-backend)
* [Frontend](#%EF%B8%8F-frontend)
* [Service creation](#-service-creation)### π Current features
1. Sites that the player supports:
- [YouTube](https://www.youtube.com)
- [Anilibria](https://www.anilibria.tv/pages/catalog.php)
2. Synchronization of the following actions:
- Play
- Pause
- Rewind
3. Synchronization of the video player time during playback and rewind events.
4. Chat, as well as its overlay version (pc only) when the player is opened full screen.### π οΈ Deployment
#### βοΈ Backend
1. Open `cmd`.
2. Type in the command:
```
pip install virtualenv
```
3. Go to the `backend` folder:
```
cd path/to/folder
```
4. Create a virtual environment:
```
virtualenv venv
```
5. Activate the virtual environment:Windows:
```
call venv/Scripts/activate
```
Linux:
```
source venv/bin/activate
```
6. Install dependencies:
```
pip install -r requirements.txt
```
7. Replace the host, port, and origin fields with your own in the file `backend/src/misc.py`.
8. Start the server with the command:Windows:
```
set PYTHONPATH=path/to/varus/project && python path/to/app.py
```
Linux:
```
PYTHONPATH=path/to/varus/project python path/to/app.py
```
#### ποΈ Frontend
1. Open `cmd`.
2. Go to the `frontend` folder:
```
cd path/to/folder
```
3. Install the modules:
```
npm install
npm install --global serve
```
4. Replace the backend url field in the file `frontend/src/globals.js`.
5. Create an application build:
```
npm run build
```
6. Start the application:
```
serve -s path/to/frontend/folder/dist -l 5000
```
### π» Service creation
To avoid starting the application manually after every server reboot, you can create services.1. Open `cmd`.
2. Go to the `system` folder:
```
cd /etc/systemd/system/
```
3. Create a backend service file:
```
nano varus.backend.service
```
4. Paste the service code and replace the paths in it:
```
[Unit]
Description=Varus backend service
After=network.target[Service]
User=root
Group=root
WorkingDirectory=/root/varus
Environment="PATH=/root/varus/backend/venv/bin"
Environment="PYTHONPATH=/root/varus"
ExecStart=/root/varus/backend/venv/bin/python /root/varus/backend/src/app.py[Install]
WantedBy=multi-user.target
```
5. Save all and close the file.
6. Create a frontend service file:
```
nano varus.frontend.service
```
7. Paste the service code and replace the paths in it:
```
[Unit]
Description=Varus frontend service
After=network.target[Service]
User=root
Group=root
WorkingDirectory=/root/varus/frontend/dist
ExecStart=/usr/bin/serve -s /root/varus/frontend/dist -l 80[Install]
WantedBy=multi-user.target
```
8. Save all and close the file.
9. Reload daemon:
```
systemctl daemon-reload
```
10. Enable services:
```
systemctl enable varus.backend.service
```
```
systemctl enable varus.frontend.service
```
11. Start services:
```
systemctl start varus.backend.service
```
```
systemctl start varus.frontend.service
```
12. Check if services are running:
```
systemctl status varus.backend.service
```
```
systemctl status varus.frontend.service
```