mirror of
https://git.luna-app.eu/50n50/sources
synced 2025-12-21 21:26:19 +01:00
100 lines
No EOL
3.2 KiB
JavaScript
100 lines
No EOL
3.2 KiB
JavaScript
async function searchContent(keyword, page=0) {
|
|
const results = [];
|
|
try {
|
|
const response = await fetch("https://mangabuddy.com/api/manga/search?q=" + encodeURIComponent(keyword));
|
|
const html = await response.text();
|
|
|
|
const regex = /href="([^"]*)"[^>]*>[\s\S]*?<img src="([^"]*)"[\s\S]*?<h3><a[^>]*>([\s\S]*?)<\/a><\/h3>/g;
|
|
|
|
let match;
|
|
while ((match = regex.exec(html)) !== null) {
|
|
results.push({
|
|
id: "https://mangabuddy.com" + match[1].trim(),
|
|
imageURL: "https://passthrough-worker.simplepostrequest.workers.dev/?simple=" + match[2].trim() + "?referer=https://mangabuddy.com",
|
|
title: match[3].replace(/<[^>]+>/g, '').trim()
|
|
});
|
|
}
|
|
|
|
return results;
|
|
} catch (err) {
|
|
return [];
|
|
}
|
|
}
|
|
|
|
async function getContentData(url) {
|
|
try {
|
|
const response = await fetch(url);
|
|
const html = await response.text();
|
|
|
|
const descRegex = /<meta name="description" content="([^"]+)"/i;
|
|
const descMatch = descRegex.exec(html);
|
|
const description = descMatch ? descMatch[1].trim() : "";
|
|
return {
|
|
description: description.replace(" - not found...", "").trim(),
|
|
tags: []
|
|
};
|
|
} catch (err) {
|
|
return {
|
|
description: "Error",
|
|
tags: []
|
|
};
|
|
}
|
|
}
|
|
|
|
async function getChapters(url) {
|
|
const results = [];
|
|
try {
|
|
const response = await fetch(url);
|
|
const html = await response.text();
|
|
const idRegex = /var bookId = (\d+);/;
|
|
const idMatch = idRegex.exec(html);
|
|
if (!idMatch) return { en: [] };
|
|
const manga_id = idMatch[1];
|
|
|
|
const chapUrl = `https://mangabuddy.com/api/manga/${manga_id}/chapters?source=detail`;
|
|
const chapResponse = await fetch(chapUrl);
|
|
const chapHtml = await chapResponse.text();
|
|
|
|
const regex = /<li id="c-\d+">\s*<a href="([^"]*)"[^>]*>\s*<div>\s*<strong class="chapter-title">Chapter (\d+)<\/strong>/g;
|
|
|
|
let match;
|
|
|
|
while ((match = regex.exec(chapHtml)) !== null) {
|
|
const chapterUrl = "https://mangabuddy.com" + match[1];
|
|
const chapterNum = match[2];
|
|
results.push([
|
|
String(chapterNum),
|
|
[{
|
|
id: chapterUrl,
|
|
chapter: parseInt(chapterNum),
|
|
scanlation_group: `Chapter ${chapterNum}`
|
|
}]
|
|
]);
|
|
}
|
|
|
|
results.reverse();
|
|
|
|
return { en: results };
|
|
} catch (err) {
|
|
return { en: [] };
|
|
}
|
|
}
|
|
|
|
async function getChapterImages(url) {
|
|
const results = [];
|
|
try {
|
|
const response = await fetch(url);
|
|
const html = await response.text();
|
|
const regex = /var chapImages = '([^']*)'/;
|
|
const match = regex.exec(html);
|
|
if (match) {
|
|
const images = match[1].split(',');
|
|
const processedImages = images.map(img => "https://passthrough-worker.simplepostrequest.workers.dev/?simple=" + img.trim() + "?referer=https://mangabuddy.com");
|
|
results.push(...processedImages);
|
|
}
|
|
|
|
return results;
|
|
} catch (err) {
|
|
return [];
|
|
}
|
|
} |