mirror of
https://github.com/hydralauncher/hydra.git
synced 2025-01-23 05:24:55 +03:00
feat: implement pause and resume functionality for game seeding in DownloadManager
This commit is contained in:
parent
ea90b49604
commit
843301c8b6
@ -148,6 +148,14 @@ def action():
|
||||
downloader = downloads.get(game_id)
|
||||
if downloader:
|
||||
downloader.cancel_download()
|
||||
elif action == 'resume_seeding':
|
||||
torrent_downloader = TorrentDownloader(torrent_session)
|
||||
downloads[game_id] = torrent_downloader
|
||||
torrent_downloader.start_download(data['url'], data['save_path'], "")
|
||||
elif action == 'pause_seeding':
|
||||
downloader = downloads.get(game_id)
|
||||
if downloader:
|
||||
downloader.cancel_download()
|
||||
|
||||
else:
|
||||
return jsonify({"error": "Invalid action"}), 400
|
||||
|
@ -11,7 +11,7 @@ const pauseGameSeed = async (
|
||||
shouldSeed: false,
|
||||
});
|
||||
|
||||
await DownloadManager.cancelDownload(gameId);
|
||||
await DownloadManager.pauseSeeding(gameId);
|
||||
};
|
||||
|
||||
registerEvent("pauseGameSeed", pauseGameSeed);
|
||||
|
@ -22,7 +22,7 @@ const resumeGameSeed = async (
|
||||
shouldSeed: true,
|
||||
});
|
||||
|
||||
await DownloadManager.startDownload(game);
|
||||
await DownloadManager.resumeSeeding(game);
|
||||
};
|
||||
|
||||
registerEvent("resumeGameSeed", resumeGameSeed);
|
||||
|
@ -19,6 +19,7 @@ import { calculateETA, getDirSize } from "./helpers";
|
||||
import { QueryDeepPartialEntity } from "typeorm/query-builder/QueryPartialEntity";
|
||||
import { RealDebridClient } from "./real-debrid";
|
||||
import path from "path";
|
||||
import { logger } from "../logger";
|
||||
|
||||
export class DownloadManager {
|
||||
private static downloadingGameId: number | null = null;
|
||||
@ -164,6 +165,8 @@ export class DownloadManager {
|
||||
|
||||
if (!seedStatus.length) return;
|
||||
|
||||
logger.log(seedStatus);
|
||||
|
||||
seedStatus.forEach(async (status) => {
|
||||
const game = await gameRepository.findOne({
|
||||
where: { id: status.gameId },
|
||||
@ -219,6 +222,22 @@ export class DownloadManager {
|
||||
this.downloadingGameId = null;
|
||||
}
|
||||
|
||||
static async resumeSeeding(game: Game) {
|
||||
await PythonRPC.rpc.post("/action", {
|
||||
action: "resume_seeding",
|
||||
game_id: game.id,
|
||||
url: game.uri,
|
||||
save_path: game.downloadPath,
|
||||
});
|
||||
}
|
||||
|
||||
static async pauseSeeding(gameId: number) {
|
||||
await PythonRPC.rpc.post("/action", {
|
||||
action: "pause_seeding",
|
||||
game_id: gameId,
|
||||
});
|
||||
}
|
||||
|
||||
static async startDownload(game: Game) {
|
||||
switch (game.downloader) {
|
||||
case Downloader.Gofile: {
|
||||
|
Loading…
Reference in New Issue
Block a user