b93f5da8d73b3325174a5a757eaf73b8e26ba8d7
Ripster
Ripster ist eine lokale Web-Anwendung für halbautomatisches Disc-Ripping mit MakeMKV + HandBrake inklusive Metadaten-Auswahl, Track-Review, Queue, Skripten/Ketten und Job-Historie.
Was Ripster kann
- Disc-Erkennung mit Pipeline-Status in Echtzeit (WebSocket)
- Medienprofil-Erkennung (
bluray/dvd/other) aus Device-/Filesystem-Heuristik - Metadaten-Suche und Zuordnung über OMDb
- MakeMKV-Analyse und Rip (
mkvoderbackup) mit profilspezifischen Settings - HandBrake-Review und Encoding mit Track-Auswahl, User-Presets, Extra-Args
- Pre- und Post-Encode-Ausführungen (Skripte und/oder Skript-Ketten)
- Pipeline-Queue mit Job- und Nicht-Job-Einträgen (
script,chain,wait) - Cron-Jobs für Skripte/Ketten (inkl. Logs und manueller Auslösung)
- Historie mit Re-Encode, Review-Neustart, File-/Job-Löschung und Orphan-Import
- Hardware-Monitoring (CPU/RAM/GPU/Storage) im Dashboard
Tech-Stack
- Backend: Node.js, Express, SQLite, WebSocket (
ws) - Frontend: React, Vite, PrimeReact
- Externe Tools:
makemkvcon,HandBrakeCLI,mediainfo
Voraussetzungen
- Linux-System mit optischem Laufwerk (oder gemounteter Quelle)
- Node.js
>= 20.19.0(siehe .nvmrc) - Installierte CLI-Tools im
PATH:makemkvconHandBrakeCLImediainfo
Schnellstart
./start.sh
start.sh erledigt:
- Node-Version prüfen/umschalten (
nvm/npx node@20Fallback) - Dependencies installieren (Root, Backend, Frontend)
- Dev-Umgebung starten (
backend+frontend)
Danach:
- Frontend:
http://localhost:5173 - Backend API:
http://localhost:3001/api
Stoppen: laufenden Prozess mit Ctrl+C im Terminal beenden.
Manueller Start
npm install
npm --prefix backend install
npm --prefix frontend install
npm run dev
Einzeln starten:
npm run dev:backend
npm run dev:frontend
Frontend Build:
npm run build:frontend
Backend (ohne Dev-Mode):
npm run start
Konfiguration
UI-Settings (empfohlen)
Die meisten Einstellungen werden in der App unter Settings gepflegt und in SQLite gespeichert:
- Pfade:
raw_dir[_bluray/_dvd/_other],movie_dir[_bluray/_dvd/_other],log_dir - Tools:
makemkv_command,handbrake_command,mediainfo_command - Profile:
*_bluray/*_dvdVarianten für Rip-/Encode-Verhalten - Queue/Monitoring:
pipeline_max_parallel_jobs,hardware_monitoring_* - Benachrichtigungen: PushOver
Umgebungsvariablen
Backend (backend/src/config.js):
PORT(Default:3001)DB_PATH(Default:backend/data/ripster.db)LOG_DIR(Default:backend/logs)CORS_ORIGIN(Default:*)LOG_LEVEL(debug|info|warn|error, Default:info)
Frontend (Vite):
VITE_API_BASE(Default:/api)VITE_WS_URL(optional, überschreibt automatische WS-URL)- optional für Remote-Dev:
VITE_PUBLIC_ORIGIN,VITE_ALLOWED_HOSTS,VITE_HMR_PROTOCOL,VITE_HMR_HOST,VITE_HMR_CLIENT_PORT
Logs und Daten
Log-Ziel ist primär der in den Settings gepflegte log_dir.
- Backend-Logs:
<log_dir>/backend/backend-latest.logund Tagesdateien - Job-Logs:
<log_dir>/job-<id>.process.log - DB:
backend/data/ripster.db
Hinweis: Beim DB-Init wird das Schema geprüft und fehlende Elemente werden migriert.
Projektstruktur
ripster/
backend/
src/
routes/
services/
db/
utils/
frontend/
src/
pages/
components/
api/
db/schema.sql
start.sh
install.sh
install-dev.sh
API-Überblick
Health
GET /api/health
Pipeline
GET /api/pipeline/statePOST /api/pipeline/analyzePOST /api/pipeline/rescan-discPOST /api/pipeline/select-metadataPOST /api/pipeline/start/:jobIdPOST /api/pipeline/confirm-encode/:jobIdPOST /api/pipeline/cancelPOST /api/pipeline/retry/:jobIdPOST /api/pipeline/reencode/:jobIdPOST /api/pipeline/restart-review/:jobIdPOST /api/pipeline/restart-encode/:jobIdPOST /api/pipeline/resume-ready/:jobIdGET /api/pipeline/queuePOST /api/pipeline/queue/reorderPOST /api/pipeline/queue/entryDELETE /api/pipeline/queue/entry/:entryId
History
GET /api/historyGET /api/history/:idGET /api/history/databaseGET /api/history/orphan-rawPOST /api/history/orphan-raw/importPOST /api/history/:id/omdb/assignPOST /api/history/:id/delete-filesPOST /api/history/:id/delete
Settings
GET /api/settingsPUT /api/settings/:keyPUT /api/settingsGET/POST/PUT/DELETE /api/settings/scripts...GET/POST/PUT/DELETE /api/settings/script-chains...GET/POST/PUT/DELETE /api/settings/user-presets...POST /api/settings/pushover/test
Cron-Jobs
GET /api/cronsPOST /api/cronsGET /api/crons/:idPUT /api/crons/:idDELETE /api/crons/:idGET /api/crons/:id/logsPOST /api/crons/:id/runPOST /api/crons/validate-expression
Troubleshooting
- WebSocket verbindet nicht:
- prüfen, ob Frontend über Vite-Proxy läuft (
/ws-> Backend) - bei Reverse-Proxy Upgrade-Header für
/wssetzen
- prüfen, ob Frontend über Vite-Proxy läuft (
- Keine Disc erkannt:
drive_mode=explicittesten unddrive_devicesetzen (z. B./dev/sr0)
- HandBrake/MakeMKV Fehler:
- CLI-Binaries im
PATHprüfen - Preset-Name mit
HandBrakeCLI -zprüfen
- CLI-Binaries im
- Startfehler wegen Schema:
db/schema.sqlvorhanden halten
Sicherheit
- Keine echten Tokens/Passwörter ins Repository committen.
- Lokale Secrets in
.envoder in Settings pflegen, aber nicht versionieren.
Description
Languages
HTML
55%
JavaScript
40.7%
Shell
2.2%
CSS
2.1%