mirror of
https://git.luna-app.eu/50n50/sources
synced 2025-12-21 21:26:19 +01:00
Add youtube/youtube.js
This commit is contained in:
parent
4b52f5455b
commit
e138012141
1 changed files with 123 additions and 0 deletions
123
youtube/youtube.js
Normal file
123
youtube/youtube.js
Normal file
|
|
@ -0,0 +1,123 @@
|
|||
async function searchResults(keyword) {
|
||||
const results = [];
|
||||
try {
|
||||
const response = await fetchv2("https://api.piped.private.coffee/search?q=" + encodeURIComponent(keyword) + "&filter=all");
|
||||
const data = await response.json();
|
||||
|
||||
if (data && Array.isArray(data.items)) {
|
||||
for (const item of data.items) {
|
||||
if (item.type === "stream") {
|
||||
const videoId = item.url ? item.url.replace("/watch?v=", "") : "";
|
||||
results.push({
|
||||
title: item.title || "",
|
||||
image: item.thumbnail || "",
|
||||
href: videoId
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let nextpage = data.nextpage;
|
||||
if (nextpage) {
|
||||
try {
|
||||
const response2 = await fetchv2("https://api.piped.private.coffee/nextpage/search?nextpage=" + encodeURIComponent(nextpage) + "&q=" + encodeURIComponent(keyword) + "&filter=all");
|
||||
const data2 = await response2.json();
|
||||
|
||||
if (data2 && Array.isArray(data2.items)) {
|
||||
for (const item of data2.items) {
|
||||
if (item.type === "stream") {
|
||||
const videoId = item.url ? item.url.replace("/watch?v=", "") : "";
|
||||
results.push({
|
||||
title: item.title || "",
|
||||
image: item.thumbnail || "",
|
||||
href: videoId
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
nextpage = data2.nextpage;
|
||||
if (nextpage) {
|
||||
const response3 = await fetchv2("https://api.piped.private.coffee/nextpage/search?nextpage=" + encodeURIComponent(nextpage) + "&q=" + encodeURIComponent(keyword) + "&filter=all");
|
||||
const data3 = await response3.json();
|
||||
|
||||
if (data3 && Array.isArray(data3.items)) {
|
||||
for (const item of data3.items) {
|
||||
if (item.type === "stream") {
|
||||
const videoId = item.url ? item.url.replace("/watch?v=", "") : "";
|
||||
results.push({
|
||||
title: item.title || "",
|
||||
image: item.thumbnail || "",
|
||||
href: videoId
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
console.error("Error fetching additional pages:", err);
|
||||
}
|
||||
}
|
||||
|
||||
return JSON.stringify(results);
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return JSON.stringify([{
|
||||
title: "Error",
|
||||
image: "Error",
|
||||
href: "Error"
|
||||
}]);
|
||||
}
|
||||
}
|
||||
|
||||
async function extractDetails(ID) {
|
||||
try {
|
||||
const response = await fetchv2("https://invidious.nikkosphere.com/api/v1/videos/" + ID);
|
||||
const data = await response.json();
|
||||
|
||||
return JSON.stringify([{
|
||||
description: data.description,
|
||||
aliases: data.author,
|
||||
airdate: data.publishedText
|
||||
}]);
|
||||
} catch (err) {
|
||||
return JSON.stringify([{
|
||||
description: "Error",
|
||||
aliases: "Error",
|
||||
airdate: "Error"
|
||||
}]);
|
||||
}
|
||||
}
|
||||
|
||||
async function extractEpisodes(ID) {
|
||||
const results = [];
|
||||
try {
|
||||
|
||||
results.push({
|
||||
href: ID,
|
||||
number: 1
|
||||
});
|
||||
|
||||
return JSON.stringify(results);
|
||||
} catch (err) {
|
||||
return JSON.stringify([{
|
||||
href: "Error",
|
||||
number: "Error"
|
||||
}]);
|
||||
}
|
||||
}
|
||||
|
||||
async function extractStreamUrl(ID) {
|
||||
try {
|
||||
const response = await fetchv2("https://invidious.nikkosphere.com/api/v1/videos/" + ID);
|
||||
const data = await response.json();
|
||||
|
||||
if (data && Array.isArray(data.formatStreams) && data.formatStreams.length > 0) {
|
||||
return data.formatStreams[0].url || "https://error.org/";
|
||||
}
|
||||
|
||||
return "https://error.org/";
|
||||
} catch (err) {
|
||||
return "https://error.org/";
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue