import { genericUserAgent, maxVideoDuration } from "../../config.js"; // TO-DO: quality picking, bilibili.tv support, and higher quality downloads (currently requires an account) export default async function({ id, shortLink }) { if (shortLink) { id = await fetch(`https://b23.tv/${shortLink}`, { redirect: 'manual' }) .then(r => r.status > 300 && r.status < 400 && r.headers.get('location')) .then(url => { const path = new URL(url).pathname; if (path.startsWith('/video/')) return path.split('/')[2]; }) .catch(() => {}) } if (!id) { return { error: 'ErrorCouldntFetch' }; } let html = await fetch(`https://bilibili.com/video/${id}`, { headers: { "user-agent": genericUserAgent } }).then((r) => { return r.text() }).catch(() => { return false }); if (!html) return { error: 'ErrorCouldntFetch' }; if (!(html.includes('')[0]); if (streamData.data.timelength > maxVideoDuration) return { error: ['ErrorLengthLimit', maxVideoDuration / 60000] }; let video = streamData["data"]["dash"]["video"].filter(v => !v["baseUrl"].includes("https://upos-sz-mirrorcosov.bilivideo.com/") ).sort((a, b) => Number(b.bandwidth) - Number(a.bandwidth)); let audio = streamData["data"]["dash"]["audio"].filter(a => !a["baseUrl"].includes("https://upos-sz-mirrorcosov.bilivideo.com/") ).sort((a, b) => Number(b.bandwidth) - Number(a.bandwidth)); return { urls: [video[0]["baseUrl"], audio[0]["baseUrl"]], audioFilename: `bilibili_${id}_audio`, filename: `bilibili_${id}_${video[0]["width"]}x${video[0]["height"]}.mp4` }; }