mirror of
https://github.com/hydralauncher/hydra.git
synced 2026-01-21 18:13:55 +00:00
fix: merge conflict
This commit is contained in:
@@ -4,10 +4,11 @@ import { publishDownloadCompleteNotification } from "../notifications";
|
||||
import type { Download, DownloadProgress, UserPreferences } from "@types";
|
||||
import {
|
||||
GofileApi,
|
||||
QiwiApi,
|
||||
DatanodesApi,
|
||||
MediafireApi,
|
||||
PixelDrainApi,
|
||||
VikingFileApi,
|
||||
RootzApi,
|
||||
} from "../hosters";
|
||||
import { PythonRPC } from "../python-rpc";
|
||||
import {
|
||||
@@ -24,11 +25,7 @@ import { sortBy } from "lodash-es";
|
||||
import { TorBoxClient } from "./torbox";
|
||||
import { GameFilesManager } from "../game-files-manager";
|
||||
import { HydraDebridClient } from "./hydra-debrid";
|
||||
import {
|
||||
BuzzheavierApi,
|
||||
FuckingFastApi,
|
||||
VikingFileApi,
|
||||
} from "@main/services/hosters";
|
||||
import { BuzzheavierApi, FuckingFastApi } from "@main/services/hosters";
|
||||
import { JsHttpDownloader } from "./js-http-downloader";
|
||||
|
||||
export class DownloadManager {
|
||||
@@ -546,8 +543,6 @@ export class DownloadManager {
|
||||
return this.getGofileDownloadOptions(download, resumingFilename);
|
||||
case Downloader.PixelDrain:
|
||||
return this.getPixelDrainDownloadOptions(download, resumingFilename);
|
||||
case Downloader.Qiwi:
|
||||
return this.getQiwiDownloadOptions(download, resumingFilename);
|
||||
case Downloader.Datanodes:
|
||||
return this.getDatanodesDownloadOptions(download, resumingFilename);
|
||||
case Downloader.Buzzheavier:
|
||||
@@ -564,6 +559,8 @@ export class DownloadManager {
|
||||
return this.getHydraDownloadOptions(download, resumingFilename);
|
||||
case Downloader.VikingFile:
|
||||
return this.getVikingFileDownloadOptions(download, resumingFilename);
|
||||
case Downloader.Rootz:
|
||||
return this.getRootzDownloadOptions(download, resumingFilename);
|
||||
default:
|
||||
return null;
|
||||
}
|
||||
@@ -608,23 +605,6 @@ export class DownloadManager {
|
||||
);
|
||||
}
|
||||
|
||||
private static async getQiwiDownloadOptions(
|
||||
download: Download,
|
||||
resumingFilename?: string
|
||||
) {
|
||||
const downloadUrl = await QiwiApi.getDownloadUrl(download.uri);
|
||||
const filename = this.resolveFilename(
|
||||
resumingFilename,
|
||||
download.uri,
|
||||
downloadUrl
|
||||
);
|
||||
return this.buildDownloadOptions(
|
||||
downloadUrl,
|
||||
download.downloadPath,
|
||||
filename
|
||||
);
|
||||
}
|
||||
|
||||
private static async getDatanodesDownloadOptions(
|
||||
download: Download,
|
||||
resumingFilename?: string
|
||||
@@ -768,6 +748,23 @@ export class DownloadManager {
|
||||
);
|
||||
}
|
||||
|
||||
private static async getRootzDownloadOptions(
|
||||
download: Download,
|
||||
resumingFilename?: string
|
||||
) {
|
||||
const downloadUrl = await RootzApi.getDownloadUrl(download.uri);
|
||||
const filename = this.resolveFilename(
|
||||
resumingFilename,
|
||||
download.uri,
|
||||
downloadUrl
|
||||
);
|
||||
return this.buildDownloadOptions(
|
||||
downloadUrl,
|
||||
download.downloadPath,
|
||||
filename
|
||||
);
|
||||
}
|
||||
|
||||
private static async getDownloadPayload(download: Download) {
|
||||
const downloadId = levelKeys.game(download.shop, download.objectId);
|
||||
|
||||
@@ -799,15 +796,6 @@ export class DownloadManager {
|
||||
save_path: download.downloadPath,
|
||||
};
|
||||
}
|
||||
case Downloader.Qiwi: {
|
||||
const downloadUrl = await QiwiApi.getDownloadUrl(download.uri);
|
||||
return {
|
||||
action: "start",
|
||||
game_id: downloadId,
|
||||
url: downloadUrl,
|
||||
save_path: download.downloadPath,
|
||||
};
|
||||
}
|
||||
case Downloader.Datanodes: {
|
||||
const downloadUrl = await DatanodesApi.getDownloadUrl(download.uri);
|
||||
return {
|
||||
@@ -925,6 +913,15 @@ export class DownloadManager {
|
||||
download.downloadPath
|
||||
);
|
||||
}
|
||||
case Downloader.Rootz: {
|
||||
const downloadUrl = await RootzApi.getDownloadUrl(download.uri);
|
||||
return {
|
||||
action: "start",
|
||||
game_id: downloadId,
|
||||
url: downloadUrl,
|
||||
save_path: download.downloadPath,
|
||||
};
|
||||
}
|
||||
default:
|
||||
return undefined;
|
||||
}
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
export * from "./gofile";
|
||||
export * from "./qiwi";
|
||||
export * from "./datanodes";
|
||||
export * from "./mediafire";
|
||||
export * from "./pixeldrain";
|
||||
export * from "./buzzheavier";
|
||||
export * from "./fuckingfast";
|
||||
export * from "./vikingfile";
|
||||
export * from "./rootz";
|
||||
|
||||
@@ -1,15 +0,0 @@
|
||||
import { requestWebPage } from "@main/helpers";
|
||||
|
||||
export class QiwiApi {
|
||||
public static async getDownloadUrl(url: string) {
|
||||
const document = await requestWebPage(url);
|
||||
const fileName = document.querySelector("h1")?.textContent;
|
||||
|
||||
const slug = url.split("/").pop();
|
||||
const extension = fileName?.split(".").pop();
|
||||
|
||||
const downloadUrl = `https://spyderrock.com/${slug}.${extension}`;
|
||||
|
||||
return downloadUrl;
|
||||
}
|
||||
}
|
||||
58
src/main/services/hosters/rootz.ts
Normal file
58
src/main/services/hosters/rootz.ts
Normal file
@@ -0,0 +1,58 @@
|
||||
import axios, { AxiosError } from "axios";
|
||||
import { logger } from "../logger";
|
||||
|
||||
interface RootzApiResponse {
|
||||
success: boolean;
|
||||
data?: {
|
||||
url: string;
|
||||
fileName: string;
|
||||
size: number;
|
||||
mimeType: string;
|
||||
expiresIn: number;
|
||||
expiresAt: string | null;
|
||||
downloads: number;
|
||||
canDelete: boolean;
|
||||
fileId: string;
|
||||
isMirrored: boolean;
|
||||
sourceService: string | null;
|
||||
adsEnabled: boolean;
|
||||
};
|
||||
error?: string;
|
||||
}
|
||||
|
||||
export class RootzApi {
|
||||
public static async getDownloadUrl(uri: string): Promise<string> {
|
||||
try {
|
||||
const url = new URL(uri);
|
||||
const pathSegments = url.pathname.split("/").filter(Boolean);
|
||||
|
||||
if (pathSegments.length < 2 || pathSegments[0] !== "d") {
|
||||
throw new Error("Invalid rootz URL format");
|
||||
}
|
||||
|
||||
const id = pathSegments[1];
|
||||
const apiUrl = `https://www.rootz.so/api/files/download-by-short/${id}`;
|
||||
|
||||
const response = await axios.get<RootzApiResponse>(apiUrl);
|
||||
|
||||
if (response.data.success && response.data.data?.url) {
|
||||
return response.data.data.url;
|
||||
}
|
||||
|
||||
throw new Error("Failed to get download URL from rootz API");
|
||||
} catch (error) {
|
||||
if (axios.isAxiosError(error)) {
|
||||
const axiosError = error as AxiosError<RootzApiResponse>;
|
||||
if (axiosError.response?.status === 404) {
|
||||
const errorMessage =
|
||||
axiosError.response.data?.error || "File not found";
|
||||
logger.error(`[Rootz] ${errorMessage}`);
|
||||
throw new Error(errorMessage);
|
||||
}
|
||||
}
|
||||
|
||||
logger.error("[Rootz] Error fetching download URL:", error);
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user