Files
tvbox/drpy2.yl.js
2026-05-17 06:13:13 +02:00

109 lines
5.5 KiB
JavaScript

let host = 'https://www.ylys.tv';
let headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36",
"Referer": host + "/",
"Accept-Language": "zh-CN,zh;q=0.9"
};
const init = async () => {};
const extractVideos = html => {
if (!html) return [];
return pdfa(html, '.module-item,.module-card-item').map(it => {
const href = pdfh(it, 'a&&href') || '';
const id = href.match(/voddetail\/(\d+)/)?.[1];
const name = pdfh(it, 'a&&title') || pdfh(it, 'strong&&Text') || pdfh(it, '.module-item-title&&Text') || "";
const pic = pdfh(it, 'img&&data-original') || pdfh(it, 'img&&src') || "";
const remarks = pdfh(it, '.module-item-text&&Text') || pdfh(it, '.module-item-note&&Text') || "";
if (!id || !name) return null;
return {
vod_id: id,
vod_name: name.trim(),
vod_pic: pic.startsWith('/') ? host + pic : pic,
vod_remarks: remarks.trim()
};
}).filter(Boolean);
};
const generateFilters = () => {
const currentYear = new Date().getFullYear();
const years = [{n:"全部",v:""}, ...Array.from({length:15},(_,i)=>{const y=currentYear-i;return{n:y+"",v:y+""}})];
return {
"1": [{"key":"class","name":"类型","value":[{"n":"全部","v":""},{"n":"动作片","v":"6"},{"n":"喜剧片","v":"7"},{"n":"爱情片","v":"8"},{"n":"科幻片","v":"9"},{"n":"恐怖片","v":"11"}]},{"key":"year","name":"年份","value":years}],
"2": [{"key":"class","name":"类型","value":[{"n":"全部","v":""},{"n":"国产剧","v":"13"},{"n":"港台剧","v":"14"},{"n":"日剧","v":"15"},{"n":"韩剧","v":"33"},{"n":"欧美剧","v":"16"}]},{"key":"year","name":"年份","value":years}],
"3": [{"key":"class","name":"类型","value":[{"n":"全部","v":""},{"n":"内地综艺","v":"27"},{"n":"港台综艺","v":"28"},{"n":"日本综艺","v":"29"},{"n":"韩国综艺","v":"36"}]},{"key":"year","name":"年份","value":years}],
"4": [{"key":"class","name":"类型","value":[{"n":"全部","v":""},{"n":"国产动漫","v":"31"},{"n":"日本动漫","v":"32"},{"n":"欧美动漫","v":"42"},{"n":"其他动漫","v":"43"}]},{"key":"year","name":"年份","value":years}]
};
};
const homeVod = async () => {
const resp = await req(host, { headers });
return JSON.stringify({ list: extractVideos(resp?.content || '') });
};
const home = async () => {
const { list } = JSON.parse(await homeVod());
return JSON.stringify({
class: [
{type_id:"1",type_name:"电影"},
{type_id:"2",type_name:"剧集"},
{type_id:"3",type_name:"综艺"},
{type_id:"4",type_name:"动漫"}
],
filters: generateFilters(),
list
});
};
const category = async (tid, pg, _, extend) => {
const cat = extend?.class || tid;
const year = extend?.year || '';
const url = `${host}/vodshow/${cat}--------${pg}---${year}/`;
const html = (await req(url, { headers }))?.content || '';
const list = extractVideos(html);
const pagecount = html.match(/page\/(\d+)\/[^>]*>尾页/) ? +RegExp.$1 : 999;
return JSON.stringify({ list, page: +pg, pagecount, limit: 20 });
};
const detail = async id => {
const html = (await req(`${host}/voddetail/${id}/`, { headers }))?.content || '';
if (!html) return JSON.stringify({ list: [] });
let tabs = pdfa(html, '.module-tab-item');
const lists = pdfa(html, '.module-play-list-content');
if (tabs.length === 0 && lists.length > 0) tabs = ["默认"];
const playFrom = tabs.map(t => pdfh(t, 'span&&Text') || "线路").join('$$$');
const playUrl = lists.slice(0, tabs.length).map(l =>
pdfa(l, 'a').map(a => {
const name = pdfh(a, 'span&&Text') || "播放";
const vid = (pdfh(a, 'a&&href') || "").match(/play\/([^\/]+)/)?.[1];
return vid ? `${name}$${vid}` : null;
}).filter(Boolean).join('#')
).join('$$$');
if (!playFrom || !playUrl) return JSON.stringify({ list: [] });
return JSON.stringify({
list: [{
vod_id: id,
vod_name: (html.match(/<h1>(.*?)<\/h1>/) || ["", ""])[1],
vod_pic: (() => {
const pic = (html.match(/data-original="(.*?)"/) || ["", ""])[1];
return pic?.startsWith('/') ? host + pic : pic || "";
})(),
vod_content: ((html.match(/introduction-content">.*?<p>(.*?)<\/p>/s) || ["", ""])[1]?.replace(/<.*?>/g, "") || ""),
vod_year: (html.match(/href="\/vodshow\/\d+-----------(\d{4})\//) || ["", ""])[1] || "",
vod_director: (html.match(/导演:.*?<a[^>]*>([^<]+)<\/a>/) || ["", ""])[1] || "",
vod_actor: [...html.matchAll(/主演:.*?<a[^>]*>([^<]+)<\/a>/g)]
.map(m => m[1])
.filter(Boolean)
.join(" / "),
vod_play_from: playFrom,
vod_play_url: playUrl
}]
});
};
const search = async (wd, _, pg = 1) => {
const url = `${host}/vodsearch/${encodeURIComponent(wd)}----------${pg}---/`;
const resp = await req(url, { headers });
return JSON.stringify({ list: extractVideos(resp?.content || '') });
};
const play = async (_, id) => {
const url = `${host}/play/${id}/`;
const resp = await req(url, { headers });
const m3u8 = resp?.content?.match(/"url":"([^"]+\.m3u8)"/);
if (m3u8) return JSON.stringify({ parse: 0, url: m3u8[1].replace(/\\/g, ""), header: headers });
return JSON.stringify({ parse: 1, url, header: headers });
};
export default { init, home, homeVod, category, detail, search, play };