jdownloader/run.sh aktualisiert

This commit is contained in:
sascha 2025-12-27 22:37:03 +00:00
parent a6b9123d95
commit 277bae3cf2

View File

@ -1,41 +1,49 @@
#!/bin/sh #!/bin/sh
# Config-Pfad von JDownloader (im antlafarge image) echo "--- Starte JDownloader (JLesage Wrapper) ---"
JD_DIR="/opt/JDownloader"
CFG_DIR="$JD_DIR/cfg"
echo "--- Starte JDownloader (Antlafarge Base) ---" # 1. ORDNERSYSTEM ANPASSEN
# Das Image nutzt /config für Einstellungen. Wir biegen das auf /data um,
# damit Einstellungen erhalten bleiben.
# 1. Ordner vorbereiten # Wenn /config ein echter Ordner ist (und kein Link), verschieben wir den Inhalt nach /data
# Wir verlinken den internen Config-Ordner auf /data, damit Einstellungen # (nur beim allerersten Start relevant)
# (wie Download-Listen) auch nach einem Addon-Neustart erhalten bleiben. if [ ! -L "/config" ]; then
if [ ! -d "/data/cfg" ]; then echo "Richte persistente Konfiguration ein..."
mkdir -p /data/cfg cp -rn /config/* /data/ 2>/dev/null
rm -rf /config
ln -s /data /config
fi fi
# Wenn der cfg Ordner im Image existiert, aber kein Link ist, löschen wir ihn # Berechtigungen korrigieren (jlesage nutzt user app:1000)
if [ -d "$CFG_DIR" ] && [ ! -L "$CFG_DIR" ]; then # Wir müssen sicherstellen, dass der User 'app' auf /data schreiben darf
rm -rf "$CFG_DIR" chown -R 1000:1000 /data
fi
# Link erstellen: Image-Config -> HA-Data-Storage # 2. DOWNLOAD ORDNER ANPASSEN
if [ ! -L "$CFG_DIR" ]; then # Das Image nutzt /output. Wir biegen das auf /share/downloads um.
ln -s /data/cfg "$CFG_DIR" mkdir -p /share/downloads
if [ -d "/output" ] && [ ! -L "/output" ]; then
rm -rf /output
fi fi
if [ ! -L "/output" ]; then
ln -s /share/downloads /output
fi
# Schreibrechte für Share sicherstellen
chmod 777 /share/downloads
# 2. Zugangsdaten aus Home Assistant lesen # 3. ZUGANGSDATEN INJIZIEREN (Optional)
EMAIL=$(jq --raw-output '.myjd_email' /data/options.json) EMAIL=$(jq --raw-output '.myjd_email // empty' /data/options.json)
PASS=$(jq --raw-output '.myjd_password' /data/options.json) PASS=$(jq --raw-output '.myjd_password // empty' /data/options.json)
DEVICE=$(jq --raw-output '.device_name' /data/options.json) DEVICE=$(jq --raw-output '.device_name' /data/options.json)
DARK_MODE=$(jq --raw-output '.dark_mode' /data/options.json)
echo "Konfiguriere MyJDownloader für: $EMAIL als '$DEVICE'" CFG_FILE="/data/cfg/org.jdownloader.api.myjdownloader.MyJDownloaderSettings.json"
mkdir -p /data/cfg
# 3. Die JDownloader Settings-Datei manuell schreiben # Nur wenn Email UND Passwort ausgefüllt sind, schreiben wir die Config
# Das ist der Trick: Wir erzeugen die Datei, die JDownloader sonst erst nach Eingabe erstellt. if [ ! -z "$EMAIL" ] && [ ! -z "$PASS" ]; then
SETTINGS_FILE="$CFG_DIR/org.jdownloader.api.myjdownloader.MyJDownloaderSettings.json" echo "Setze MyJDownloader Zugangsdaten..."
cat <<EOF > "$CFG_FILE"
# Wir schreiben ein minimales JSON File für die Anmeldung
cat <<EOF > "$SETTINGS_FILE"
{ {
"email" : "$EMAIL", "email" : "$EMAIL",
"password" : "$PASS", "password" : "$PASS",
@ -43,21 +51,19 @@ cat <<EOF > "$SETTINGS_FILE"
"autoconnectenabledmanual" : true "autoconnectenabledmanual" : true
} }
EOF EOF
# Wichtig: Datei muss dem Container-User gehören!
# 4. Download Pfad auf /share/downloads biegen chown 1000:1000 "$CFG_FILE"
mkdir -p /share/downloads
# Falls Downloads-Ordner existiert (und kein Link ist), weg damit
if [ -d "$JD_DIR/Downloads" ] && [ ! -L "$JD_DIR/Downloads" ]; then
rm -rf "$JD_DIR/Downloads"
fi fi
# Link setzen
ln -s /share/downloads "$JD_DIR/Downloads"
echo "Berechtigungen korrigieren..." # 4. DARK MODE (Optional)
chown -R root:root "$JD_DIR" # Setze Environment Variable für das jlesage Image
if [ "$DARK_MODE" = "true" ]; then
export DARK_MODE=1
else
export DARK_MODE=0
fi
# 5. Starten # 5. STARTEN
echo "Starte Java..." # Wir rufen das originale Init-System des Containers auf
# Wir nutzen direkt java, um volle Kontrolle zu haben echo "Übergabe an jlesage init..."
cd $JD_DIR exec /init
exec java -Djava.awt.headless=true -jar JDownloader.jar