hutatools / fnc /test.js
fullpwerr's picture
p
d145b59
const {
fileTypeFromBuffer
} = require("file-type");
const twit = require("../lib/twt")
const {
ttt
} = require("../lib/skrep");
const {
soundcloud
} = require("../lib/soundcloud");
const ig = require("../lib/ig");
const {
spotifyTrack,
spotifyPlaylist
} = require("../lib/spotify");
const yt = require("../lib/ytdl");
const kwaii = require("../lib/kuaishou");
const qq = require("../lib/qqm");
const fesnuk = require("../lib/fb");
const IGr = /^(https?:\/\/)?(www\.)?instagram\.com\/.*$/i;
const SCr = /^(https?:\/\/)?(www\.|m\.)?(on\.|)soundcloud\.com\/[^\s]+$/i;
const TTr = /https?:\/\/(www\.|v(t|m)\.|t\.)?tiktok\.com/i;
const Sr = /https?:\/\/open\.spotify\.com\/track\/([a-zA-Z0-9]+)(\?.*)?/i;
const Ser = /https?:\/\/open\.spotify\.com\/playlist\/([a-zA-Z0-9]+)(\?.*)?/i;
const YTr = /(?:http(?:s|):\/\/|)(?:(?:www\.|)?(?:music\.)?youtube(?:-nocookie|)\.com\/(?:shorts\/)?(?:watch\?.*(?:|&)v=|embed\/|v\/)?|youtu\.be\/)([-_0-9A-Za-z]{11})/i;
const Kr = /^https?:\/\/v\.kuaishou\.com\/[a-zA-Z0-9]+$/i;
const QQMr = /^https:\/\/c6\.y\.qq\.com\/base\/fcgi-bin\/u\?__=[a-zA-Z0-9]+$/;
const TwTr = /^https?:\/\/(www\.)?(twitter|x)\.com\/[^\/]+\/status\/\d+\/?$/i;
// Daftar domain yang diperbolehkan untuk Facebook
const allowX = [
"x.com",
"www.x.com",
"twitter.com",
"www.twitter.com"
]
const allowedFacebookHosts = [
"facebook.com",
"www.facebook.com",
"m.facebook.com",
"fb.com"
];
/**
* @param {string} response
* @returns {Promise<{ success: boolean, challenge_ts: string, hostname: string, score: number, action: string, "error-codes": ("missing-input-secret"|"invalid-input-secret"|"missing-input-response"|"invalid-input-response"|"bad-request"|"timeout-or-duplicate")[] }>}
*/
async function checkCaptcha(response) {
const url = new URL("https://www.google.com/recaptcha/api/siteverify");
url.searchParams.set("secret", "6Ldr6_cqAAAAAApmQtOImEUOVLq8cAIFUZuuRSrM");
url.searchParams.set("response", response);
const res = await fetch(url, {
method: "POST"
});
return await res.json();
}
/** @type {Map<string, any>} */
const yt_info = new Map();
module.exports = async function(req, res) {
const {
url
} = req.body;
//const ip = req._ip;
if(!url) {
return res.status(400).json({
error: "URL diperlukan."
});
}
let parsedUrl;
try {
parsedUrl = new URL(url);
} catch (error) {
return res.status(400).json({ error: "URL tidak valid." });
}
/*const authHeader = req.headers.authorization;
if (!authHeader || !authHeader.startsWith("Bearer ")) {
return res.status(401).json({ message: "Unauthorized: Token is missing or invalid" });
}
const token = authHeader.split(" ")[1];
const { success: isValid, "error-codes": errors } = await checkCaptcha(token);
if (!isValid) {
return res.status(400).send({ message: "Invalid captcha", errors });
}*/
console.log(parsedUrl);
let ress;
try {
if(IGr.test(url)) {
ress = await ig(url);
ress.type = "instagram";
} else if(SCr.test(url)) {
ress = await soundcloud(url);
ress.type = "soundcloud";
} else if(Ser.test(url)) {
ress = await spotifyPlaylist(url);
ress.type = "spotifyPlaylist";
} else if(TTr.test(url)) {
ress = await ttt(url);
ress.type = "tiktok";
} else if(Sr.test(url)) {
ress = await spotifyTrack(url);
ress.type = "spotify";
} else if(QQMr.test(url)) {
ress = await qq(url);
ress.type = "qq";
} else if(allowedFacebookHosts.includes(parsedUrl.hostname)) {
ress = await fesnuk(url);
ress.type = "facebook"
} else if(allowX.includes(parsedUrl.hostname)) {
ress = await twit(url);
ress.type = "twitter"
} else if(YTr.test(url)) {
const format = String(
req.headers["x-selected-format"] ||
""
).trim();
const [, id] = YTr.exec(url);
if(!format) {
ress = (
yt_info.has(id)
? yt_info.get(id)
: await yt.getInfo(url)
);
yt_info.set(id, ress);
ress.type = "yt_info";
} else {
const type = (
format === "audio"
? "Audio"
: "Video"
);
ress = await yt[`get${type}`](url, format);
}
} else if(Kr.test(url)) {
ress = await kwaii(url);
ress.type = "kwaii";
} else {
ress = {
status: 400,
message: "failed request"
};
}
} catch (e) {
console.log(e);
ress = {
status: 404,
message: e.message
};
}
if(Buffer.isBuffer(ress)) {
const { mime } = await fileTypeFromBuffer(ress);
res.setHeader("Content-Type", mime);
res.setHeader("Content-Length", ress.length);
}
return res.status(ress.status || 200).send(ress.data || ress);
};