2026-03-11 13:07:05 +00:00
2026-03-08 21:52:21 +00:00
2026-03-05 11:04:20 +00:00
2026-03-11 12:54:43 +00:00
2026-03-09 20:37:56 +00:00
2026-03-09 20:37:56 +00:00
2026-03-10 13:12:57 +00:00
2026-03-11 12:27:01 +00:00
2026-03-10 13:12:57 +00:00
2026-03-10 13:12:57 +00:00
2026-03-04 14:18:33 +00:00
2026-03-11 13:07:05 +00:00
2026-03-11 13:07:05 +00:00
2026-03-09 13:40:48 +00:00
2026-03-10 13:12:57 +00:00

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 (mkv oder backup) 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:
    • makemkvcon
    • HandBrakeCLI
    • mediainfo

Schnellstart

./start.sh

start.sh erledigt:

  1. Node-Version prüfen/umschalten (nvm/npx node@20 Fallback)
  2. Dependencies installieren (Root, Backend, Frontend)
  3. 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 / *_dvd Varianten 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.log und 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/state
  • POST /api/pipeline/analyze
  • POST /api/pipeline/rescan-disc
  • POST /api/pipeline/select-metadata
  • POST /api/pipeline/start/:jobId
  • POST /api/pipeline/confirm-encode/:jobId
  • POST /api/pipeline/cancel
  • POST /api/pipeline/retry/:jobId
  • POST /api/pipeline/reencode/:jobId
  • POST /api/pipeline/restart-review/:jobId
  • POST /api/pipeline/restart-encode/:jobId
  • POST /api/pipeline/resume-ready/:jobId
  • GET /api/pipeline/queue
  • POST /api/pipeline/queue/reorder
  • POST /api/pipeline/queue/entry
  • DELETE /api/pipeline/queue/entry/:entryId

History

  • GET /api/history
  • GET /api/history/:id
  • GET /api/history/database
  • GET /api/history/orphan-raw
  • POST /api/history/orphan-raw/import
  • POST /api/history/:id/omdb/assign
  • POST /api/history/:id/delete-files
  • POST /api/history/:id/delete

Settings

  • GET /api/settings
  • PUT /api/settings/:key
  • PUT /api/settings
  • GET/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/crons
  • POST /api/crons
  • GET /api/crons/:id
  • PUT /api/crons/:id
  • DELETE /api/crons/:id
  • GET /api/crons/:id/logs
  • POST /api/crons/:id/run
  • POST /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 /ws setzen
  • Keine Disc erkannt:
    • drive_mode=explicit testen und drive_device setzen (z. B. /dev/sr0)
  • HandBrake/MakeMKV Fehler:
    • CLI-Binaries im PATH prüfen
    • Preset-Name mit HandBrakeCLI -z prüfen
  • Startfehler wegen Schema:
    • db/schema.sql vorhanden halten

Sicherheit

  • Keine echten Tokens/Passwörter ins Repository committen.
  • Lokale Secrets in .env oder in Settings pflegen, aber nicht versionieren.
Description
No description provided
Readme 18 MiB
Languages
HTML 56.2%
JavaScript 41.5%
CSS 2.1%
Shell 0.2%