async function searchResults(keyword) { const results = []; try { const response = await fetchv2("https://eng.animeapps.top/api/search2.php?keyword=" + encodeURIComponent(keyword) + "&page=1&limit=200"); const json = await response.json(); if (json.status === "success" && json.data) { json.data.forEach(item => { let title = item.postname.trim(); title = title.replace(/\s*\(Uncensored\)\s*$/i, ''); title = title.replace(/\s*BD\s*$/i, ''); title = title.trim(); results.push({ title: title, image: item.ani_cover_large, href: "https://anibd.app/" + item.postid + "?anilist=" + item.anilist }); }); } return JSON.stringify(results); } catch (err) { return JSON.stringify([{ title: "Error", image: "Error", href: "Error" }]); } } async function extractDetails(url) { try { const html = await (await fetchv2(url)).text(); const match = html.match(/
]*>/g, '').replace(/<\/p>/g, ' ').replace(/
/gi, ' ')
.replace(/<[^>]*>/g, '').replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"')
.replace(/&/g, '&').replace(/'/g, "'").replace(/ /g, ' ')
.replace(/\(Source:.*?\)\s*/gi, '').replace(/\s+/g, ' ').trim();
}
return JSON.stringify([{ description, aliases: "N/A", airdate: "N/A" }]);
} catch (err) {
return JSON.stringify([{ description: "Error", aliases: "Error", airdate: "Error" }]);
}
}
async function extractEpisodes(url) {
try {
const postid = url.match(/(\d+)/)?.[1];
if (!postid) return JSON.stringify([]);
let anilist = url.match(/anilist=([\d]+)/)?.[1];
if (!anilist) {
const html = await (await fetchv2(url)).text();
anilist = html.match(/const\s+EP_ID\s*=\s*["'](\d+)["']/)?.[1];
}
if (!anilist) return JSON.stringify([]);
const json = await (await fetchv2("https://epeng.animeapps.top/api2.php?epid=" + anilist)).json();
const results = [];
if (Array.isArray(json)) {
json.forEach(server => {
server.server_data?.forEach(ep => {
results.push({
number: parseInt(ep.name, 10),
href: "https://epeng.animeapps.top/apilink.php?data=" + ep.link
});
});
});
}
return JSON.stringify(results);
} catch (err) {
return JSON.stringify([]);
}
}
async function extractStreamUrl(url) {
try {
const response = await fetchv2(url);
const servers = await response.json();
const headers = {
"Referer": "https://anibd.app/"
};
const promises = servers.map(async (server) => {
try {
const res = await fetchv2(server.link, headers);
const html = await res.text();
const match = html.match(/url:\s*['"]([^'"]+)['"]/);
if (match) {
let streamUrl = match[1];
if (!streamUrl.startsWith("http")) {
const baseUrl = server.link.substring(0, server.link.lastIndexOf("/") + 1);
streamUrl = baseUrl + streamUrl;
}
return {
title: server.server,
streamUrl: streamUrl
};
}
} catch (err) {}
return null;
});
const results = await Promise.all(promises);
const streams = results.filter(s => s !== null);
return JSON.stringify({
type: "servers",
streams: streams,
subtitle: null
});
} catch (err) {
return JSON.stringify({
type: "servers",
streams: [],
subtitle: null
});
}
}