mirror of
https://github.com/qist/tvbox.git
synced 2025-01-24 03:04:56 +08:00
153 lines
4.4 KiB
JavaScript
153 lines
4.4 KiB
JavaScript
|
import { load, _ } from 'assets://js/lib/cat.js';
|
|||
|
import { log } from './lib/utils.js';
|
|||
|
import { initAli, detailContent, playContent } from './lib/ali.js';
|
|||
|
|
|||
|
let siteKey = 'zhaozy';
|
|||
|
let siteType = 0;
|
|||
|
let siteUrl = 'https://zhaoziyuan.pw';
|
|||
|
let patternAli = /(https:\/\/www\.(aliyundrive|alipan)\.com\/s\/[^"]+)/;
|
|||
|
let patternVid = /(\\S+)/;
|
|||
|
let username = '';
|
|||
|
let password = '';
|
|||
|
let cookie = '';
|
|||
|
|
|||
|
const UA = 'Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1';
|
|||
|
|
|||
|
async function requestRaw(reqUrl, headers, method, data) {
|
|||
|
let res = await req(reqUrl, {
|
|||
|
method: method || 'get',
|
|||
|
headers: headers,
|
|||
|
data: data,
|
|||
|
postType: method === 'post' ? 'form' : '',
|
|||
|
});
|
|||
|
return res;
|
|||
|
}
|
|||
|
|
|||
|
async function request(reqUrl, headers) {
|
|||
|
let resRaw = await requestRaw(reqUrl, headers);
|
|||
|
return resRaw.content;
|
|||
|
}
|
|||
|
|
|||
|
// cfg = {skey: siteKey, ext: extend}
|
|||
|
async function init(cfg) {
|
|||
|
try {
|
|||
|
siteKey = _.isEmpty(cfg.skey) ? '' : cfg.skey;
|
|||
|
siteType = _.isEmpty(cfg.stype) ? '' : cfg.stype;
|
|||
|
const ext = _.isEmpty(cfg.ext) ? '' : cfg.ext;
|
|||
|
const configs = ext.split('$$$');
|
|||
|
if (configs.length == 3) {
|
|||
|
username = configs[1];
|
|||
|
password = configs[2];
|
|||
|
}
|
|||
|
await initAli(configs[0]);
|
|||
|
} catch (e) {
|
|||
|
await log('init:' + e.message + ' line:' + e.lineNumber);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
async function home(filter) {
|
|||
|
return '{}';
|
|||
|
}
|
|||
|
|
|||
|
async function homeVod() {}
|
|||
|
|
|||
|
async function category(tid, pg, filter, extend) {
|
|||
|
return '{}';
|
|||
|
}
|
|||
|
|
|||
|
async function detail(id) {
|
|||
|
try {
|
|||
|
let matches = id.match(patternAli);
|
|||
|
if (!_.isEmpty(matches)) return await detailContent(matches[1]);
|
|||
|
const headers = await getHeaders();
|
|||
|
const data = await request(siteUrl + '/' + id, headers);
|
|||
|
matches = data.match(patternAli);
|
|||
|
if (!_.isEmpty(matches)) return await detailContent(matches[1]);
|
|||
|
return '';
|
|||
|
} catch (e) {
|
|||
|
await log('detail:' + e.message + ' line:' + e.lineNumber);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
async function play(flag, id, flags) {
|
|||
|
try {
|
|||
|
return await playContent(flag, id, flags);
|
|||
|
} catch (e) {
|
|||
|
await log('play:' + e.message + ' line:' + e.lineNumber);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
async function search(wd, quick, pg) {
|
|||
|
if (pg <= 0) pg = 1;
|
|||
|
const limit = 15;
|
|||
|
const headers = await getHeaders();
|
|||
|
const html = await request(siteUrl + '/so?filename=' + encodeURIComponent(wd) + '&page=' + pg, headers);
|
|||
|
const $ = load(html);
|
|||
|
const elements = $('div.li_con div.news_text');
|
|||
|
const videos = _.map(elements, (item) => {
|
|||
|
const element = $(item);
|
|||
|
const href = element.find('div.news_text a').attr('href');
|
|||
|
if (!href) return undefined;
|
|||
|
const matches = href.match(patternVid);
|
|||
|
if (!_.isEmpty(matches)) return undefined;
|
|||
|
const name = element.find("div.news_text a h3").text();
|
|||
|
const remark = element.find("div.news_text a p").text().split("|")[1].split(":")[1];
|
|||
|
return {
|
|||
|
vod_id: href,
|
|||
|
vod_name: name,
|
|||
|
vod_pic: "https://inews.gtimg.com/newsapp_bt/0/13263837859/1000",
|
|||
|
vod_remarks: remark
|
|||
|
};
|
|||
|
});
|
|||
|
const nextPage = $('.page a li:contains(下一页)');
|
|||
|
const hasMore = _.isEmpty(nextPage) ? false : nextPage.attr('class') != 'disabled';
|
|||
|
const pgCount = hasMore ? parseInt(pg) + 1 : parseInt(pg);
|
|||
|
return JSON.stringify({
|
|||
|
page: parseInt(pg),
|
|||
|
pagecount: pgCount,
|
|||
|
limit: limit,
|
|||
|
total: limit * pgCount,
|
|||
|
list: videos.filter(item => item !== undefined),
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
async function getHeaders() {
|
|||
|
if (!cookie) {
|
|||
|
cookie = await getCookie();
|
|||
|
}
|
|||
|
return {
|
|||
|
'User-Agent': UA,
|
|||
|
'Referer': siteUrl,
|
|||
|
'Cookie': cookie,
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
async function getCookie() {
|
|||
|
const params = {
|
|||
|
"username": username,
|
|||
|
"password": password,
|
|||
|
};
|
|||
|
const headers = {
|
|||
|
"User-Agent": UA,
|
|||
|
"Referer": siteUrl + "/stop.html",
|
|||
|
"Origin": siteUrl,
|
|||
|
};
|
|||
|
const res = await requestRaw(siteUrl + "/logiu.html", headers, 'post', params);
|
|||
|
let result = '';
|
|||
|
for (const cookie of res.headers['set-cookie']) {
|
|||
|
result += cookie.split(";")[0] + ";";
|
|||
|
}
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
export function __jsEvalReturn() {
|
|||
|
return {
|
|||
|
init: init,
|
|||
|
home: home,
|
|||
|
homeVod: homeVod,
|
|||
|
category: category,
|
|||
|
detail: detail,
|
|||
|
play: play,
|
|||
|
search: search,
|
|||
|
};
|
|||
|
}
|