5b41f728c5f40389e9721b02cdcf942e4c1713a1
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.
Statushinweis: CD-Ripping (experimentell)
- Die grundlegende CD-Ripping-Funktion im ersten Durchgang funktioniert.
- Das Frontend ist dafür noch nicht vollständig angepasst.
- Funktionen wie Restart, bestimmte Ansichten und Folge-Workflows können aktuell eingeschränkt sein oder fehlschlagen.
- CD-Ripping wird weiterentwickelt und sollte derzeit als experimentell betrachtet werden.
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
Dokumentation
- Ausführliche Dokumentation: https://mboehmlaender.github.io/ripster/
Voraussetzungen
- Debian 11/12 oder Ubuntu 22.04/24.04
- root-Rechte + Internetzugang
- optisches Laufwerk (oder gemountete Quelle)
Schnellstart (install.sh)
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
Alternativ direkt per Pipe:
curl -fsSL https://raw.githubusercontent.com/Mboehmlaender/ripster/main/install.sh | sudo bash
install.sh übernimmt u. a.:
- Node.js 20 (falls nötig)
- Basistools inkl.
mediainfo - CD-Ripping-Tools (
cdparanoia,flac,lame,opus-tools,vorbis-tools) - MakeMKV
- HandBrake CLI (Auswahl Standard/CPU oder GPU/NVDEC-Binary für HW-Encoding)
- nginx
- Repository-Checkout, npm-Install, Frontend-Build, systemd-Service (
ripster-backend)
Danach ist Ripster unter http://<Server-IP> erreichbar.
Wichtige Optionen:
sudo bash install.sh --branch dev # Branch wählen (Default im Skript: dev)
sudo bash install.sh --dir /opt/ripster # Installationspfad
sudo bash install.sh --user ripster # Service-User
sudo bash install.sh --port 3001 # Backend-Port
sudo bash install.sh --host 192.168.1.10 # Host/IP für nginx/CORS
sudo bash install.sh --no-makemkv # MakeMKV überspringen
sudo bash install.sh --no-handbrake # HandBrake überspringen
sudo bash install.sh --no-nginx # nginx-Setup überspringen
sudo bash install.sh --reinstall # Update (Daten bleiben erhalten)
sudo bash install.sh --help # Hilfe anzeigen
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.
Description
Languages
HTML
55%
JavaScript
40.7%
Shell
2.2%
CSS
2.1%