mirror of
https://git.luna-app.eu/50n50/sources
synced 2025-12-21 21:26:19 +01:00
Upload
This commit is contained in:
commit
09c423e95a
276 changed files with 54396 additions and 0 deletions
147
soaperlive/soaperlive.js
Normal file
147
soaperlive/soaperlive.js
Normal file
|
|
@ -0,0 +1,147 @@
|
|||
async function searchResults(keyword) {
|
||||
const results = [];
|
||||
const response = await fetchv2(`https://soaper.live/search.html?keyword=${keyword}`);
|
||||
const html = await response.text();
|
||||
|
||||
const regex = /<div class="img-group">\s*<a href=['"]([^'"]+)['"]><img src=['"]([^'"]+)['"][^>]*><\/a>[\s\S]*?<h5><a href=['"][^'"]+['"]>([^<]+)<\/a>/g;
|
||||
|
||||
let match;
|
||||
while ((match = regex.exec(html)) !== null) {
|
||||
results.push({
|
||||
title: match[3].trim(),
|
||||
image: "https://soaper.live" + match[2].trim(),
|
||||
href: "https://soaper.live" + match[1].trim()
|
||||
});
|
||||
}
|
||||
console.error(JSON.stringify(results));
|
||||
return JSON.stringify(results);
|
||||
}
|
||||
|
||||
async function extractDetails(url) {
|
||||
const results = [];
|
||||
const response = await fetchv2(url);
|
||||
const html = await response.text();
|
||||
|
||||
const regex = /<p id="wrap"[^>]*>\s*([\s\S]*?)\s*<\/p>/;
|
||||
const match = regex.exec(html);
|
||||
|
||||
const description = match ? match[1].trim() : 'N/A';
|
||||
|
||||
results.push({
|
||||
description: description,
|
||||
aliases: 'N/A',
|
||||
airdate: 'N/A'
|
||||
});
|
||||
|
||||
return JSON.stringify(results);
|
||||
}
|
||||
|
||||
|
||||
async function extractEpisodes(url) {
|
||||
const results = [];
|
||||
const response = await fetchv2(url);
|
||||
const html = await response.text();
|
||||
const regex = /<a href="([^"]+)">\s*(\d+)\.[^<]+<\/a>/g;
|
||||
let match;
|
||||
|
||||
while ((match = regex.exec(html)) !== null) {
|
||||
results.push({
|
||||
href: "Episode: https://soaper.live" + match[1].trim(),
|
||||
number: parseInt(match[2], 10)
|
||||
});
|
||||
}
|
||||
|
||||
if (results.length === 0) {
|
||||
const movieRegex = /<a[^>]+href="https:\/\/twitter\.com\/home\/\?status=([^"]+)"/;
|
||||
const movieMatch = movieRegex.exec(html);
|
||||
|
||||
if (movieMatch) {
|
||||
results.push({
|
||||
href: "Movie: " + movieMatch[1].trim(),
|
||||
number: 1
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
return JSON.stringify(results.reverse());
|
||||
}
|
||||
|
||||
async function extractStreamUrl(url) {
|
||||
let actualUrl;
|
||||
let isMovie = false;
|
||||
|
||||
if (url.startsWith("Episode: ")) {
|
||||
actualUrl = url.substring("Episode: ".length);
|
||||
} else if (url.startsWith("Movie: ")) {
|
||||
actualUrl = url.substring("Movie: ".length);
|
||||
isMovie = true;
|
||||
} else {
|
||||
actualUrl = url;
|
||||
}
|
||||
|
||||
if (isMovie) {
|
||||
const response = await fetchv2(actualUrl);
|
||||
const firstHtml = await response.text();
|
||||
const idRegex = /<input type="hidden" id="hId" value="([^"]+)">/;
|
||||
const idMatch = idRegex.exec(firstHtml);
|
||||
const hId = idMatch ? idMatch[1] : null;
|
||||
console.error(hId);
|
||||
|
||||
const postData = {
|
||||
pass: `${hId}`,
|
||||
param: "",
|
||||
extra: "",
|
||||
e2: "0",
|
||||
server: "0"
|
||||
};
|
||||
|
||||
const headers = {
|
||||
"Referer": "https://soaper.live",
|
||||
"Content-Type": "application/json"
|
||||
};
|
||||
|
||||
console.error(JSON.stringify(postData));
|
||||
const responseText = await fetchv2("https://soaper.live/home/index/GetMInfoAjax", headers, "POST", postData);
|
||||
const jsonResponse = await responseText.text();
|
||||
console.error(jsonResponse);
|
||||
|
||||
const hlsRegex = /"val":"([^"]+)"/;
|
||||
const hlsMatch = hlsRegex.exec(jsonResponse);
|
||||
const hlsUrl = hlsMatch ? hlsMatch[1].replace(/\\\//g, "/") : null;
|
||||
console.error(hlsUrl);
|
||||
|
||||
return hlsUrl ? `https://soaper.live${hlsUrl}` : null;
|
||||
} else {
|
||||
const response = await fetchv2(actualUrl);
|
||||
const firstHtml = await response.text();
|
||||
const idRegex = /<input type="hidden" id="hId" value="([^"]+)">/;
|
||||
const idMatch = idRegex.exec(firstHtml);
|
||||
const hId = idMatch ? idMatch[1] : null;
|
||||
console.error(hId);
|
||||
|
||||
const postData = {
|
||||
pass: `${hId}`,
|
||||
param: "",
|
||||
extra: "",
|
||||
e2: "0",
|
||||
server: "0"
|
||||
};
|
||||
|
||||
const headers = {
|
||||
"Referer": "https://soaper.live",
|
||||
"Content-Type": "application/json"
|
||||
};
|
||||
|
||||
console.error(JSON.stringify(postData));
|
||||
const responseText = await fetchv2("https://soaper.live/home/index/GetEInfoAjax", headers, "POST", postData);
|
||||
const jsonResponse = await responseText.text();
|
||||
console.error(jsonResponse);
|
||||
|
||||
const hlsRegex = /"val":"([^"]+)"/;
|
||||
const hlsMatch = hlsRegex.exec(jsonResponse);
|
||||
const hlsUrl = hlsMatch ? hlsMatch[1].replace(/\\\//g, "/") : null;
|
||||
console.error( hlsUrl);
|
||||
|
||||
return hlsUrl ? `https://soaper.live${hlsUrl}` : null;
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue