mirror of
https://github.com/letian1650/N3RD.git
synced 2025-01-24 11:25:14 +08:00
171 lines
6.8 KiB
JavaScript
171 lines
6.8 KiB
JavaScript
|
/**
|
|||
|
* 传参 ?type=url¶ms=../json/采集.json
|
|||
|
* [{"name":"暴风资源","url":"https://bfzyapi.com","parse_url":""},{"name":"飞刀资源","url":"http://www.feidaozy.com","parse_url":""},{"name":"黑木耳资源","url":"https://www.heimuer.tv","parse_url":""}]
|
|||
|
*/
|
|||
|
var rule = {
|
|||
|
title: '采集之王[合]',
|
|||
|
author: '道长',
|
|||
|
host: '',
|
|||
|
homeTid: '', // 首页推荐。一般填写第一个资源站的想要的推荐分类的id.可以空
|
|||
|
homeUrl: '/api.php/provide/vod/?ac=detail&t={{rule.homeTid}}',
|
|||
|
detailUrl: '/api.php/provide/vod/?ac=detail&ids=fyid',
|
|||
|
searchUrl: '/api.php/provide/vod/?wd=**&pg=fypage',
|
|||
|
classUrl: '/api.php/provide/vod/',
|
|||
|
url: '/api.php/provide/vod/?ac=detail&pg=fypage&t=fyfilter',
|
|||
|
filter_url: '{{fl.类型}}',
|
|||
|
headers: {'User-Agent': 'MOBILE_UA'},
|
|||
|
timeout: 5000, // class_name: '电影&电视剧&综艺&动漫',
|
|||
|
limit: 20,
|
|||
|
searchable: 1,//是否启用全局搜索,
|
|||
|
quickSearch: 0,//是否启用快速搜索,
|
|||
|
filterable: 1,//是否启用分类筛选,
|
|||
|
play_parse: true,
|
|||
|
parse_url: '', // 这个参数暂时不起作用。聚合类的每个资源应该有自己独立的解析口
|
|||
|
// params: 'http://127.0.0.1:5707/files/json/%E9%87%87%E9%9B%86.json',
|
|||
|
预处理: $js.toString(() => {
|
|||
|
let _url = rule.params;
|
|||
|
if (_url && typeof (_url) === 'string' && _url.startsWith('http')) {
|
|||
|
let html = request(_url);
|
|||
|
let json = JSON.parse(html);
|
|||
|
let _classes = [];
|
|||
|
rule.filter = {};
|
|||
|
rule.filter_def = {};
|
|||
|
json.forEach(it => {
|
|||
|
let _obj = {
|
|||
|
type_name: it.name,
|
|||
|
type_id: it.url,
|
|||
|
parse_url: it.parse_url || '',
|
|||
|
cate_exclude: it.cate_exclude || '',
|
|||
|
};
|
|||
|
_classes.push(_obj);
|
|||
|
try {
|
|||
|
let json1 = JSON.parse(request(urljoin(_obj.type_id, rule.classUrl))).class;
|
|||
|
if (_obj.cate_exclude) {
|
|||
|
json1 = json1.filter(cl => !new RegExp(_obj.cate_exclude, 'i').test(cl.type_name));
|
|||
|
}
|
|||
|
rule.filter[_obj.type_id] = [{
|
|||
|
"key": "类型", "name": "类型", "value": json1.map(i => {
|
|||
|
return {"n": i.type_name, 'v': i.type_id}
|
|||
|
})
|
|||
|
}];
|
|||
|
if (json1.length > 0) {
|
|||
|
rule.filter_def[it.url] = {"类型": json1[0].type_id};
|
|||
|
}
|
|||
|
} catch (e) {
|
|||
|
rule.filter[it.url] = [{"key": "类型", "name": "类型", "value": [{"n": "全部", "v": ""}]}];
|
|||
|
}
|
|||
|
});
|
|||
|
rule.classes = _classes;
|
|||
|
}
|
|||
|
}),
|
|||
|
// class_parse: $js.toString(() => {
|
|||
|
// let _url = rule.params;
|
|||
|
// if (_url && typeof (_url) === 'string' && _url.startsWith('http')) {
|
|||
|
// let html = request(_url);
|
|||
|
// let json = JSON.parse(html);
|
|||
|
// let _classes = [];
|
|||
|
// homeObj.filter = {};
|
|||
|
// rule.filter_def = {};
|
|||
|
// json.forEach(it => {
|
|||
|
// let _obj = {
|
|||
|
// type_name: it.name,
|
|||
|
// type_id: it.url,
|
|||
|
// parse_url: it.parse_url || '',
|
|||
|
// cate_exclude: it.cate_exclude || '',
|
|||
|
// };
|
|||
|
// _classes.push(_obj);
|
|||
|
// try {
|
|||
|
// let json1 = JSON.parse(request(urljoin(_obj.type_id, rule.classUrl))).class;
|
|||
|
// if (_obj.cate_exclude) {
|
|||
|
// json1 = json1.filter(cl => !new RegExp(_obj.cate_exclude, 'i').test(cl.type_name));
|
|||
|
// }
|
|||
|
// homeObj.filter[_obj.type_id] = [{
|
|||
|
// "key": "类型", "name": "类型", "value": json1.map(i => {
|
|||
|
// return {"n": i.type_name, 'v': i.type_id}
|
|||
|
// })
|
|||
|
// }];
|
|||
|
// if (json1.length > 0) {
|
|||
|
// rule.filter_def[it.url] = {"类型": json1[0].type_id};
|
|||
|
// }
|
|||
|
// } catch (e) {
|
|||
|
// homeObj.filter[it.url] = [{"key": "类型", "name": "类型", "value": [{"n": "全部", "v": ""}]}];
|
|||
|
// }
|
|||
|
// });
|
|||
|
// rule.classes = _classes;
|
|||
|
// input = _classes;
|
|||
|
// }
|
|||
|
// }),
|
|||
|
class_parse: $js.toString(() => {
|
|||
|
input = rule.classes;
|
|||
|
}),
|
|||
|
推荐: $js.toString(() => {
|
|||
|
if (rule.classes) {
|
|||
|
let _url = urljoin(rule.classes[0].type_id, input);
|
|||
|
let html = request(_url);
|
|||
|
let json = JSON.parse(html);
|
|||
|
VODS = json.list;
|
|||
|
VODS.forEach(it => {
|
|||
|
it.vod_id = rule.classes[0].type_id + '$' + it.vod_id
|
|||
|
});
|
|||
|
}
|
|||
|
}),
|
|||
|
一级: $js.toString(() => {
|
|||
|
VODS = [];
|
|||
|
if (rule.classes) {
|
|||
|
// log(input);
|
|||
|
let _url = urljoin(MY_CATE, input);
|
|||
|
let html = request(_url);
|
|||
|
let json = JSON.parse(html);
|
|||
|
VODS = json.list;
|
|||
|
VODS.forEach(it => {
|
|||
|
it.vod_id = MY_CATE + '$' + it.vod_id
|
|||
|
});
|
|||
|
}
|
|||
|
}),
|
|||
|
// 一级: 'json:list;vod_name;vod_pic;vod_remarks;vod_id;vod_play_from',
|
|||
|
二级: $js.toString(() => {
|
|||
|
VOD = [];
|
|||
|
if (rule.classes) {
|
|||
|
let _url = urljoin(fyclass, input);
|
|||
|
let html = request(_url);
|
|||
|
let json = JSON.parse(html);
|
|||
|
let data = json.list;
|
|||
|
VOD = data[0];
|
|||
|
}
|
|||
|
}),
|
|||
|
搜索: $js.toString(() => {
|
|||
|
VODS = [];
|
|||
|
if (rule.classes) {
|
|||
|
rule.classes.forEach(it => {
|
|||
|
let _url = urljoin(it.type_id, input);
|
|||
|
// log(_url);
|
|||
|
try {
|
|||
|
let html = request(_url);
|
|||
|
let json = JSON.parse(html);
|
|||
|
let data = json.list;
|
|||
|
data.forEach(i => {
|
|||
|
i.vod_id = it.type_id + '$' + i.vod_id
|
|||
|
});
|
|||
|
VODS = VODS.concat(data);
|
|||
|
} catch (e) {
|
|||
|
log(`请求:${it.type_id}发生错误:${e.message}`)
|
|||
|
}
|
|||
|
|
|||
|
});
|
|||
|
}
|
|||
|
}),
|
|||
|
lazy: $js.toString(() => {
|
|||
|
// lazy想办法用对应的parse_url,但是有难度,暂未实现
|
|||
|
if (/\.(m3u8|mp4)/.test(input)) {
|
|||
|
input = {parse: 0, url: input}
|
|||
|
} else {
|
|||
|
if (rule.parse_url.startsWith('json:')) {
|
|||
|
let purl = rule.parse_url.replace('json:', '') + input;
|
|||
|
let html = request(purl);
|
|||
|
input = {parse: 0, url: JSON.parse(html).url}
|
|||
|
} else {
|
|||
|
input = rule.parse_url + input;
|
|||
|
}
|
|||
|
}
|
|||
|
}),
|
|||
|
}
|