Initial WatchLink scaffold
This commit is contained in:
83
README.md
Normal file
83
README.md
Normal file
@@ -0,0 +1,83 @@
|
||||
# WatchLink
|
||||
|
||||
WatchLink is a self-hosted shared-watch web app with persistent user rooms, local accounts, friends, role-based administration, and realtime playback state.
|
||||
|
||||
<p align="center"><img src="https://raw.githubusercontent.com/andreasbm/readme/master/assets/lines/rainbow.png" alt="-----------------------------------------------------" width="100%"></p>
|
||||
|
||||
## Features
|
||||
|
||||
- First-run setup creates the first admin user.
|
||||
- Username/password accounts with bcrypt password hashing.
|
||||
- Every user gets a stable personal room like `/rooms/@username`.
|
||||
- Friend requests and room access are modeled for friends-only, public, role-restricted, and explicit access.
|
||||
- Admin surface for rooms, users, roles, and permissions.
|
||||
- Shared playback state via Socket.IO.
|
||||
- Media URL normalization for YouTube, Twitch, and direct video URLs.
|
||||
- Uptime Kuma/Dockge-inspired app shell with system light/dark theme.
|
||||
- Docker Compose stack for app and Postgres.
|
||||
|
||||
<p align="center"><img src="https://raw.githubusercontent.com/andreasbm/readme/master/assets/lines/rainbow.png" alt="-----------------------------------------------------" width="100%"></p>
|
||||
|
||||
## Development
|
||||
|
||||
```bash
|
||||
npm install
|
||||
cp .env.example .env
|
||||
npm run db:push
|
||||
npm run dev
|
||||
```
|
||||
|
||||
Open `http://localhost:3000/setup` on a clean database to create the first admin.
|
||||
|
||||
Useful commands:
|
||||
|
||||
```bash
|
||||
npm run typecheck
|
||||
npm run test
|
||||
npm run build
|
||||
npm run audit
|
||||
```
|
||||
|
||||
<p align="center"><img src="https://raw.githubusercontent.com/andreasbm/readme/master/assets/lines/rainbow.png" alt="-----------------------------------------------------" width="100%"></p>
|
||||
|
||||
## Docker
|
||||
|
||||
```bash
|
||||
docker compose up --build
|
||||
```
|
||||
|
||||
The Compose stack exposes the web app on `http://localhost:3000` and uses a Postgres volume named `watchlink_postgres-data`.
|
||||
|
||||
Build and publish the Gitea image:
|
||||
|
||||
```bash
|
||||
docker build -t git.wilkensxl.de/MrSphay/watchlink:latest .
|
||||
docker login git.wilkensxl.de
|
||||
docker push git.wilkensxl.de/MrSphay/watchlink:latest
|
||||
```
|
||||
|
||||
<p align="center"><img src="https://raw.githubusercontent.com/andreasbm/readme/master/assets/lines/rainbow.png" alt="-----------------------------------------------------" width="100%"></p>
|
||||
|
||||
## Gitea
|
||||
|
||||
Target repository:
|
||||
|
||||
```text
|
||||
git@git.wilkensxl.de:MrSphay/WatchLink.git
|
||||
```
|
||||
|
||||
Target container image:
|
||||
|
||||
```text
|
||||
git.wilkensxl.de/MrSphay/watchlink:latest
|
||||
```
|
||||
|
||||
CI expects `REGISTRY_TOKEN` to be configured as a repository or organization secret when image publishing should run.
|
||||
|
||||
<p align="center"><img src="https://raw.githubusercontent.com/andreasbm/readme/master/assets/lines/rainbow.png" alt="-----------------------------------------------------" width="100%"></p>
|
||||
|
||||
## Project Info
|
||||
|
||||
- Stack: Next.js, React, TypeScript, Prisma, Postgres, Socket.IO, Docker
|
||||
- Repository baseline: `codex-agent-repository-kit`
|
||||
- License: not declared yet
|
||||
Reference in New Issue
Block a user