udevadm media flags are not propagated in VM/passthrough scenarios. When blkid and udevadm both return nothing, try cdparanoia -Q to detect audio CDs directly via TOC read. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
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 (Blu-ray/DVD/Sonstiges) 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)
- Aktivitäts-Tracking: Laufende und abgeschlossene Aktionen (Skripte, Ketten, Cron, Tasks) in Echtzeit im Dashboard
- 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
- Produktion (empfohlen mit
install.sh):- unterstütztes Debian/Ubuntu-System
- root-Rechte + Internetzugang
- optisches Laufwerk (oder gemountete Quelle)
install.shinstalliert Node.js und die benötigten Tools automatisch
- Entwicklung (
./start.sh,npm run dev):- Node.js
>= 20.19.0(siehe .nvmrc) - installierte CLI-Tools im
PATH:makemkvconHandBrakeCLImediainfo
- Node.js
Schnellstart (Produktion)
Auf Debian 11/12 oder Ubuntu 22.04/24.04 (root erforderlich):
wget -qO install.sh https://raw.githubusercontent.com/Mboehmlaender/ripster/main/install.sh
sudo bash install.sh
Das Skript fragt interaktiv, ob HandBrake als Standard-Version (apt) oder mit GPU/NVDEC-Unterstützung (gebündeltes Binary) installiert werden soll.
Danach ist Ripster unter http://<Server-IP> erreichbar.
Wichtige Optionen:
sudo bash install.sh --branch dev # anderen Branch installieren
sudo bash install.sh --no-makemkv # MakeMKV überspringen
sudo bash install.sh --reinstall # Update (Daten bleiben erhalten)
Entwicklungsumgebung
Für lokale Entwicklung mit Hot-Reload:
./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 Ausgabeordner,Film Ausgabeordner,Log Ordner(jeweils mit Blu-ray/DVD/Sonstiges-Varianten) - Tools:
MakeMKV Kommando,HandBrake Kommando,Mediainfo Kommando - Profile: medientyp-spezifische Felder für Blu-ray/DVD/Sonstiges (z. B. Preset, Zusatzargumente, Ausgabeformat)
- Queue/Monitoring:
Parallele Jobs,Hardware Monitoring aktiviert,Hardware Monitoring Intervall (ms) - 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
Runtime-Aktivitäten
GET /api/activitiesPOST /api/activities/:id/cancelPOST /api/activities/:id/next-stepPOST /api/activities/clear-recent
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:
- in den Settings
LaufwerksmodusaufExplizites Devicestellen undDevice Pfadsetzen (z. B./dev/sr0)
- in den Settings
- 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.