From fea59514bc9958eda2fe36b39f6248875a023968 Mon Sep 17 00:00:00 2001 From: tuesday Date: Wed, 26 Jun 2024 17:58:05 +0200 Subject: [PATCH] Fixing downloads by replacing the torrent client --- src/main/services/aria2c.ts | 56 ++++++++++++++------------- src/main/services/download-manager.ts | 44 ++++++++++----------- 2 files changed, 51 insertions(+), 49 deletions(-) diff --git a/src/main/services/aria2c.ts b/src/main/services/aria2c.ts index 2095e283..17e8eaaf 100644 --- a/src/main/services/aria2c.ts +++ b/src/main/services/aria2c.ts @@ -3,35 +3,37 @@ import { spawn } from "node:child_process"; import { app } from "electron"; export const startAria2 = () => { - const binaryPath = app.isPackaged - ? path.join(process.resourcesPath, "aria2", "aria2c") - : path.join(__dirname, "..", "..", "aria2", "aria2c"); + const binaryPath = app.isPackaged + ? path.join(process.resourcesPath, "aria2", "aria2c") + : path.join(__dirname, "..", "..", "aria2", "aria2c"); - const aria2Process = spawn( - binaryPath, - [ - "--enable-rpc", - "--rpc-listen-all", - "--file-allocation=none", - "--allow-overwrite=true", - "--log-level=debug", - "--no-conf", - "--disk-cache=128M" - ], - { stdio: "inherit", windowsHide: true } - ); + const aria2Process = spawn( + binaryPath, + [ + "--enable-rpc", + "--rpc-listen-all", + "--file-allocation=none", + "--allow-overwrite=true", + "--log-level=debug", + "--no-conf", + "--disk-cache=128M", + ], + { stdio: "inherit", windowsHide: true } + ); - aria2Process.on("error", (err) => { - console.error("Aria2 process error:", err); - }); + aria2Process.on("error", (err) => { + console.error("Aria2 process error:", err); + }); - aria2Process.on("exit", (code, signal) => { - if (code !== 0) { - console.error(`Aria2 process exited with code ${code} and signal ${signal}`); - } else { - console.log("Aria2 process exited successfully"); - } - }); + aria2Process.on("exit", (code, signal) => { + if (code !== 0) { + console.error( + `Aria2 process exited with code ${code} and signal ${signal}` + ); + } else { + console.log("Aria2 process exited successfully"); + } + }); - return aria2Process; + return aria2Process; }; diff --git a/src/main/services/download-manager.ts b/src/main/services/download-manager.ts index ed70b4be..379e25cd 100644 --- a/src/main/services/download-manager.ts +++ b/src/main/services/download-manager.ts @@ -55,9 +55,9 @@ export class DownloadManager { } private static getETA( - totalLength: number, - completedLength: number, - speed: number + totalLength: number, + completedLength: number, + speed: number ) { const remainingBytes = totalLength - completedLength; @@ -80,7 +80,7 @@ export class DownloadManager { private static async getRealDebridDownloadUrl() { if (this.realDebridTorrentId) { const torrentInfo = await RealDebridClient.getTorrentInfo( - this.realDebridTorrentId + this.realDebridTorrentId ); const { status, links } = torrentInfo; @@ -107,9 +107,9 @@ export class DownloadManager { numSeeds: torrentInfo.seeders, downloadSpeed: torrentInfo.speed, timeRemaining: this.getETA( - torrentInfo.bytes, - totalDownloaded, - torrentInfo.speed + torrentInfo.bytes, + totalDownloaded, + torrentInfo.speed ), isDownloadingMetadata: status === "magnet_conversion", game: { @@ -120,8 +120,8 @@ export class DownloadManager { } as DownloadProgress; WindowManager.mainWindow.webContents.send( - "on-download-progress", - JSON.parse(JSON.stringify(payload)) + "on-download-progress", + JSON.parse(JSON.stringify(payload)) ); } } @@ -156,7 +156,7 @@ export class DownloadManager { } const progress = - Number(status.completedLength) / Number(status.totalLength); + Number(status.completedLength) / Number(status.totalLength); if (!isDownloadingMetadata) { const update: QueryDeepPartialEntity = { @@ -168,12 +168,12 @@ export class DownloadManager { if (!isNaN(progress)) update.progress = progress; await gameRepository.update( - { id: this.game.id }, - { - ...update, - status: status.status, - folderName: this.getFolderName(status), - } + { id: this.game.id }, + { + ...update, + status: status.status, + folderName: this.getFolderName(status), + } ); } @@ -190,17 +190,17 @@ export class DownloadManager { numSeeds: Number(status.numSeeders ?? 0), downloadSpeed: Number(status.downloadSpeed), timeRemaining: this.getETA( - Number(status.totalLength), - Number(status.completedLength), - Number(status.downloadSpeed) + Number(status.totalLength), + Number(status.completedLength), + Number(status.downloadSpeed) ), isDownloadingMetadata: !!isDownloadingMetadata, game, } as DownloadProgress; WindowManager.mainWindow.webContents.send( - "on-download-progress", - JSON.parse(JSON.stringify(payload)) + "on-download-progress", + JSON.parse(JSON.stringify(payload)) ); } @@ -292,7 +292,7 @@ export class DownloadManager { if (game.downloader === Downloader.RealDebrid) { this.realDebridTorrentId = await RealDebridClient.getTorrentId( - game!.uri! + game!.uri! ); } else { this.gid = await this.aria2.call("addUri", [game.uri!], options);