Added readme

This commit is contained in:
2025-10-21 19:53:32 +03:00
parent a9d23441cb
commit f68cc0ca27

113
Readme.md Normal file
View File

@@ -0,0 +1,113 @@
# dupe — Simple, Fast & Lightweight Torrent Server ⚡📦
A **self-hosted torrent-based file manager and media player**, similar to Put.io — fast, minimal, and elegant.
Add torrents, monitor downloads, and instantly stream videos through a clean web interface! 🖥️🎬
---
## ✨ Features
- 🧲 **Add Torrents**
- Upload `.torrent` files (via form)
- Add magnet links (via prompt)
- 📥 **Download Management**
- View active torrents
- See progress, speed, and remaining time
- Browse file trees within torrents
- 🔴 **Real-Time Updates**
- Live progress updates via WebSocket
- 🎞️ **Instant Playback**
- Stream video files directly in the browser
- ffmpeg-ready structure for Safari/codec compatibility
- 🗂️ **Clean & Modern Web Interface**
- Svelte-powered fast and lightweight UI
- Search bar, torrent list, detailed view
- Custom modal video player: title, progress bar, volume, subtitles, and download icons
- Mobile-friendly layout with hamburger menu support
- 🐳 **Easy Docker Setup**
- One-command deployment with `docker-compose.yml`
> 📝 Login and user authentication are not yet implemented — planned in the roadmap.
---
## 🏗️ Architecture
```
root
├─ client/ # Svelte-based Web UI
├─ server/ # Node.js (Express) API + WebSocket + WebTorrent
└─ docker-compose.yml
```
- **client**
- Developed and built using Vite
- Backend API configured via `VITE_API` (e.g., `http://192.168.x.x:3001`)
- **server**
- Express REST endpoints (list, add, stream torrents)
- Real-time updates via WebSocket (`progress` events)
- WebTorrent for downloading and seeding
- Optional ffmpeg integration for video transcoding
---
## 🚀 Quick Start
### 🐳 Docker Compose (Recommended)
```bash
docker compose up -d --build
```
**Default Ports:**
- Server (API): `http://localhost:3001`
- Client (UI): `http://localhost:5173`
---
## ⚙️ Environment Variables
### Client
| Variable | Description |
|-----------|--------------|
| `VITE_API` | Backend API root URL (e.g., `http://localhost:3001`) |
### Server
| Variable | Description |
|-----------|--------------|
| `PORT` | API port (default: `3001`) |
---
## 🔌 API & WebSocket Endpoints
| Method | URL | Description |
|--------|-----|-------------|
| `GET` | `/api/torrents` | Returns active torrents |
| `POST` | `/api/transfer` | Adds a torrent via `.torrent` file upload |
| `POST` | `/api/magnet` | Adds a torrent via magnet link |
| `GET` | `/stream/:infoHash/:fileIndex` | Streams a video or file |
| `WS` | `ws://<API_HOST>:3001/` | Torrent progress updates (`type: progress`) |
---
## 🧠 Developer Notes
- **Safari Compatibility:** Some codecs may cause issues. Its recommended to remux files (`.mkv → .mp4`) with ffmpeg if needed.
---
## 🛣️ Roadmap
- 🔐 Authentication (JWT or session-based)
- 🧩 TheMovieDB / TVDB / MusicBrainz integrations
- 🎛️ Advanced player features (subtitle selection, quality control)
- 🧹 File management, trash bin, and history
- 🧪 Automated testing and CI setup
---