diff --git a/SrcJyAlist.js b/SrcJyAlist.js
new file mode 100644
index 00000000..14c16cfc
--- /dev/null
+++ b/SrcJyAlist.js
@@ -0,0 +1,917 @@
+//本代码仅用于个人学习,请勿用于其他作用,下载后请24小时内删除,代码虽然是公开学习的,但请尊重作者,应留下说明
+//引入Ali公用文件
+require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAliPublic.js');
+let alistfile = "hiker://files/rules/Src/Juying/Alist.json";
+let alistData = {};
+if (fetch(alistfile)) {
+ try {
+ eval("alistData = " + fetch(alistfile));
+ } catch (e) {
+ alistData = {};
+ }
+}
+let datalist = alistData.drives || [];
+
+function getlist(data, isdir, filter) {
+ let list = data.filter(item => {
+ let suffix = item.name.substring(item.name.lastIndexOf('.') + 1);//后缀名
+ return isdir ? item.is_dir : filter ? ((contain.test(suffix) || /srt|vtt|ass/.test(suffix))) && !item.is_dir : !item.is_dir;
+ })
+ try {
+ if (!isdir) {
+ list.sort(SortList);
+ }
+ } catch (e) {
+ log('排序修正失败>' + e.message);
+ }
+ return list || [];
+}
+
+function gethtml(alistapi, int, path) {
+ let pwd = "";
+ if (alistapi.password) {
+ if (alistapi.password[path]) {
+ pwd = alistapi.password[path]
+ } else {
+ let paths = path.split('/');
+ let patht = path.split('/');
+ for (let i = 0; i < paths.length - 1; i++) {
+ patht.length = patht.length - 1;
+ let onpath = patht.join('/') || "/";
+ if (alistapi.password[onpath]) {
+ pwd = alistapi.password[onpath];
+ break;
+ }
+ }
+ }
+ }
+ let headers = { 'content-type': 'application/json;charset=UTF-8' }
+ if (alistapi.token) {
+ headers.Authorization = alistapi.token;
+ }
+ let body = { "path": path, "password": pwd }
+ if (int == "/api/fs/other") {
+ body.method = "video_preview";
+ }
+ let html = request(alistapi.server + int, { headers: headers, body: body, method: 'POST', timeout: 10000 });
+ return html;
+}
+
+function alistHome() {
+ let getapi = datalist.filter(item => {
+ return item.server == getItem('Alistapi', datalist.length > 0 ? datalist[0].server : "");
+ });
+ let alistapi = getapi.length > 0 ? getapi[0] : datalist.length > 0 ? datalist[0] : {};
+ let d = [];
+ datalist.forEach(item => {
+ d.push({
+ title: alistapi.server == item.server ? `““””` + item.name + `` : item.name,
+ url: $(item.server + '#noLoading#').lazyRule((item) => {
+ setItem('Alistapi', item.server);
+ refreshPage(false);
+ return "hiker://empty";
+ }, item),
+ col_type: 'scroll_button'
+ })
+ })
+ d.push({
+ col_type: 'blank_block'
+ });
+ d.push({
+ title: '⚙设置',
+ url: $('hiker://empty#noRecordHistory##noHistory#').rule(() => {
+ require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAlist.js');
+ alistSet();
+ }),
+ col_type: 'scroll_button'
+ });
+ d.push({
+ title: '🔍搜索',
+ url: $(getItem('searchtestkey', ''), "搜索关键字").input((alistapi) => {
+ setItem("searchtestkey", input);
+ require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAlist.js');
+ showLoading('搜索中,请稍后...');
+ deleteItemByCls('loadlist');
+ let searchlist = alistSearch(alistapi, input);
+ if (searchlist.length > 0) {
+ addItemBefore('listloading', searchlist);
+ } else {
+ addItemBefore('listloading', {
+ title: alistapi.name + " 未搜索到 “" + input + "”",
+ url: "hiker://empty",
+ col_type: "text_center_1",
+ extra: {
+ cls: "loadlist"
+ }
+ });
+ }
+ hideLoading();
+ return "toast://搜索完成";
+ }, alistapi),
+ col_type: 'scroll_button'
+ });
+ d.push({
+ title: '🔎聚合',
+ url: $(getItem('searchtestkey', ''), "搜索关键字").input(() => {
+ setItem("searchtestkey", input);
+ require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAlist.js');
+ showLoading('搜索中,请稍后...');
+ alistSearch2(input);
+ hideLoading();
+ return "toast://搜索完成";
+ }),
+ col_type: 'scroll_button'
+ });
+ if (alistapi.token) {
+ d.push({
+ title: '🔗挂载',
+ url: $(["挂载阿里分享"], 2).select((alistapi, alitoken) => {
+ if (input == '挂载阿里分享') {
+ if (alitoken) {
+ return $("", "阿里分享链接").input((alistapi, alitoken) => {
+ input = input.replace('https://www.aliyundrive.com/s/', '');
+ let share_id = input.indexOf('/folder/') > -1 ? input.split('/folder/')[0] : input;
+ let folder_id = input.indexOf('/folder/') > -1 ? input.split('/folder/')[1] : "root";
+ let html = request("https://api.aliyundrive.com/adrive/v3/share_link/get_share_by_anonymous", { body: { "share_id": share_id }, method: 'POST', timeout: 10000 });
+ let folderlist = JSON.parse(html).file_infos;
+ if (folderlist.length == 1) {
+ let body = {
+ "mount_path": "/阿里分享/自动挂载/" + folderlist[0].file_name,
+ "order": 0,
+ "remark": "",
+ "cache_expiration": 30,
+ "web_proxy": false,
+ "webdav_policy": "302_redirect",
+ "down_proxy_url": "",
+ "extract_folder": "",
+ "driver": "AliyundriveShare",
+ "addition": "{\"refresh_token\":\"" + alitoken + "\",\"share_id\":\"" + share_id + "\",\"share_pwd\":\"\",\"root_folder_id\":\"" + folder_id + "\",\"order_by\":\"\",\"order_direction\":\"\"}"
+ }
+ let result = JSON.parse(request(alistapi.server + "/api/admin/storage/create", { headers: { "Authorization": alistapi.token }, body: body, method: 'POST', timeout: 10000 }));
+ if (result.code == 200) {
+
+ return "toast://成功";
+ } else if (result.code == 500) {
+ return "toast://已存在";
+ }
+ }
+ }, alistapi, alitoken)
+ } else {
+ return "toast://阿里token还未填写,无法挂载";
+ }
+ }
+ }, alistapi, alitoken),
+ col_type: 'scroll_button'
+ });
+ }
+ d.push({
+ col_type: 'line'
+ });
+ d.push({
+ title: "加载中,请稍后...",
+ url: "hiker://empty",
+ col_type: "text_center_1",
+ extra: {
+ id: "listloading",
+ lineVisible: false
+ }
+ })
+ setResult(d);
+
+ if (datalist.length > 0) {
+ setPageTitle(alistapi.name + ' | Alist网盘');
+ try {
+ let json = JSON.parse(gethtml(alistapi, "/api/fs/list", '/'));
+ if (json.code == 200) {
+ let dirlist = getlist(json.data.content || [], 1);
+ addItemBefore('listloading', arrayAdd(dirlist, 1, alistapi));
+
+ let filelist = getlist(json.data.content || [], 0, alistapi.nofilter ? 0 : fileFilter);
+ addItemBefore('listloading', arrayAdd(filelist, 0, alistapi));
+ } else if (json.code == 401) {
+ if (logintoken(alistapi.server)) {
+ refreshPage(false);
+ } else {
+ toast('登录令牌token失效,需要重新获取');
+ }
+ } else if (json.code == 500) {
+ toast('获取列表失败,下拉刷新重试.' + json.message);
+ }
+ updateItem('listloading', {
+ title: "““””此规则仅限学习交流使用,请于导入后24小时内删除,任何团体或个人不得以任何方式方法传播此规则的整体或部分!"
+ });
+ } catch (e) {
+ updateItem('listloading', {
+ title: "超时或出错了,下拉刷新重试."
+ });
+ }
+ } else {
+ setPageTitle('Alist网盘 | 聚影√');
+ updateItem('listloading', {
+ title: "Alist列表为空"
+ });
+ }
+}
+
+function alistList(alistapi, dirname) {
+ setPageTitle(dirname);
+ let d = [];
+ let listid = base64Encode(MY_PARAMS.path);
+ d.push({
+ title: "🏠" + alistapi.name + MY_PARAMS.path + "",
+ col_type: 'rich_text'
+ })
+ d.push({
+ title: "加载中,请稍后...",
+ url: "hiker://empty",
+ col_type: "text_center_1",
+ extra: {
+ id: listid,
+ lineVisible: false
+ }
+ })
+ setResult(d);
+ try {
+ let json = JSON.parse(gethtml(alistapi, "/api/fs/list", MY_PARAMS.path));
+ if (json.code == 200) {
+ let dirlist = getlist(json.data.content || [], 1);
+ addItemBefore(listid, arrayAdd(dirlist, 1, alistapi));
+
+ let filelist = getlist(json.data.content || [], 0, alistapi.nofilter ? 0 : fileFilter);
+ addItemBefore(listid, arrayAdd(filelist, 0, alistapi));
+ if (dirlist.length == 0 && filelist.length == 0) {
+ addItemBefore(listid, {
+ title: "列表为空",
+ url: "hiker://empty",
+ col_type: "text_center_1"
+ });
+ }
+ } else if (json.code == 401) {
+ if (logintoken(alistapi.server)) {
+ refreshPage(false);
+ } else {
+ toast('登录令牌token失效,需要重新获取');
+ }
+ } else if (json.code == 500) {
+ toast('获取列表失败,下拉刷新重试.' + json.message);
+ }
+ updateItem(listid, {
+ title: !alistapi.nofilter && fileFilter ? "““””已开启文件过滤,仅显示音视频文件" : ""
+ });
+ } catch (e) {
+ log(alistapi.name + '>获取列表失败>' + e.message);
+ updateItem(listid, {
+ title: "超时或出错了,下拉刷新重试."
+ });
+ }
+}
+
+function arrayAdd(list, isdir, alistapi) {
+ let d = [];
+ if (!isdir) {
+ var sublist = list.filter(item => {
+ return /srt|vtt|ass/.test(item.name.substring(item.name.lastIndexOf('.') + 1));
+ })
+ if (!alistapi.nofilter && fileFilter && !isdir) {
+ list = list.filter(item => {
+ return contain.test(item.name.substring(item.name.lastIndexOf('.') + 1));
+ })
+ }
+ }
+
+ list.forEach(item => {
+ let path = ((item.parent == "/" ? "" : item.parent) || (typeof (MY_PARAMS) != "undefined" && MY_PARAMS.path) || "") + "/" + item.name;
+ if (isdir) {
+ d.push({
+ title: item.name,
+ img: item.thumb || "hiker://files/cache/src/文件夹.svg",//#noRecordHistory##noHistory#
+ url: $("hiker://empty##" + encodeURI(alistapi.server + path)).rule((alistapi, dirname) => {
+ require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAlist.js');
+ alistList(alistapi, dirname);
+ }, alistapi, item.name),
+ col_type: 'avatar',
+ extra: {
+ path: path,
+ cls: "loadlist"
+ }
+ })
+ } else {
+ let name = item.name.substring(0, item.name.lastIndexOf("."));//文件名
+ let suffix = item.name.substring(item.name.lastIndexOf('.') + 1);//后缀名
+ let subtitles = [];
+ sublist.forEach(item => {
+ if (item.name.indexOf(name) > -1) {
+ subtitles.push(item.name + "?sign=" + (item.sign || ""));
+ }
+ })
+ d.push({
+ title: item.name,
+ img: item.thumb || (music.test(suffix) ? "hiker://files/cache/src/音乐.svg" : contain.test(suffix) ? "hiker://files/cache/src/影片.svg" : image.test(suffix) ? "hiker://files/cache/src/图片.png" : "hiker://files/cache/src/Alist.svg"),
+ url: $(encodeURI(alistapi.server + path)).lazyRule((alistapi, path, sign, subtitle) => {
+ require(config.依赖.match(/http(s)?:\/\/.*\//)[0] + 'SrcJyAlist.js');
+ return alistUrl(alistapi, path, sign, subtitle);
+ }, alistapi, path, item.sign || "", subtitles.length > 0 ? subtitles[0] : ""),
+ col_type: 'avatar',
+ extra: {
+ id: encodeURI(path),
+ cls: typeof (MY_PARAMS) != "undefined" && contain.test(suffix) ? "playlist" : typeof (MY_PARAMS) == "undefined" && contain.test(suffix) ? "loadlist playlist" : "loadlist",
+ longClick: [{
+ title: "📋复制链接",
+ js: $.toString((url) => {
+ copy(url);
+ return "hiker://empty";
+ }, encodeURI(alistapi.server + '/d' + path) + '?sign=' + (item.sign || ""))
+ }]
+ }
+ })
+ }
+ })
+ return d;
+}
+
+function alistUrl(alistapi, path, sign, subtitle) {
+ let suffix = path.substring(path.lastIndexOf('.') + 1);//后缀名
+ let url = encodeURI(alistapi.server + "/d" + path) + "?sign=" + sign;
+ subtitle = subtitle ? url.match(/http(s)?:\/\/.*\//)[0] + subtitle : "";
+ let provider;
+ if (contain.test(suffix)) {
+ try {
+ let json = JSON.parse(gethtml(alistapi, "/api/fs/get", path));
+ if (json.code == 200) {
+ url = json.data.raw_url || url;
+ provider = json.data.provider;
+ }
+ } catch (e) { }
+ try {
+ if (!music.test(suffix)) {
+ if (provider == "AliyundriveOpen") {
+ try {
+ let json = JSON.parse(gethtml(alistapi, "/api/fs/other", path));
+ if (json.code == 200) {
+ let playurl = json.data.video_preview_play_info.live_transcoding_task_list;
+ playurl.reverse();
+ let urls = [];
+ let names = [];
+ let heads = [];
+ urls.push(url);
+ names.push('原始 画质');
+ heads.push({ 'Referer': 'https://www.aliyundrive.com/' });
+ playurl.forEach((item) => {
+ urls.push(item.url + "#isVideo=true##pre#");
+ names.push(transcoding[item.template_id] ? transcoding[item.template_id] : item.template_height);
+ heads.push({ 'Referer': 'https://www.aliyundrive.com/' });
+ })
+ return JSON.stringify({
+ urls: urls,
+ names: names,
+ headers: heads,
+ subtitle: subtitle
+ });
+ }
+ } catch (e) {
+ log('阿里开放获取多线程失败>' + e.message);
+ }
+ } else if (provider == "AliyundriveShare") {
+ if (typeof (startProxyServer) == "undefined") {
+ return "toast://软件需升级新版本才能支持代理播放";
+ }
+ try {
+ let redirect = JSON.parse(request(url, { onlyHeaders: true, redirect: false, timeout: 3000 }));
+ let rurl = redirect.headers.location[0];
+ let share_id = rurl.split('&sl=')[1].split('&')[0];
+ let file_id = rurl.split('&f=')[1].split('&')[0];
+ //let alitoken = alistconfig.alitoken;
+ let play = getAliUrl(share_id, file_id, alitoken);
+ if (play.urls) {
+ if (subtitle) {
+ play['subtitle'] = subtitle;
+ }
+ return JSON.stringify(play);
+ } else {
+ log('获取转码播放列表失败,是不是没有设置阿里token');
+ }
+ } catch (e) {
+ log('阿里共享获取转码播放列表异常>' + e.message);
+ }
+ }
+ }
+ url = url + (music.test(suffix) ? "#isMusic=true#" : "#isVideo=true#") + (url.indexOf('baidu.com') > -1 ? ';{User-Agent@Lavf/57.83.100}' : url.indexOf('aliyundrive') > -1 ? ';{Referer@https://www.aliyundrive.com/}' : '');
+ if (!subtitle) {
+ return url;
+ } else {
+ let urls = [];
+ urls.push(url);
+ return JSON.stringify({
+ urls: urls,
+ subtitle: subtitle ? url.match(/http(s)?:\/\/.*\//)[0] + subtitle : ""
+ });
+ }
+ } catch (e) { }
+ return url;
+ } else if (image.test(suffix)) {
+ return url + "@Referer=";
+ } else {
+ return "download://" + url;
+ }
+}
+
+function logintoken(api) {
+ try {
+ let atokenlist = storage0.getItem('atokenlist', {});
+ let atoken = atokenlist[api];
+ if (atoken) {
+ let html = fetch(api + "/api/auth/login", { headers: { 'content-type': 'application/json;charset=UTF-8' }, body: { "Username": atoken.user, "Password": atoken.pwd }, method: 'POST', timeout: 10000 });
+ let json = JSON.parse(html);
+ if (json.code == 200) {
+ eval("var alistData=" + fetch(alistfile));
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == api)[0]);
+ datalist[index].token = json.data.token;
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ log("自动重新获取登录用户令牌成功");
+ return true;
+ }
+ }
+ } catch (e) {
+ log("自动重新获取登录用户令牌失败>" + e.message);
+ }
+ return false;
+}
+
+function alistSearch(alistapi, input, notoast) {
+ let dirlist = [];
+ let filelist = [];
+ try {
+ let headers = { 'content-type': 'application/json;charset=UTF-8' };
+ if (alistapi.token) {
+ headers.Authorization = alistapi.token;
+ }
+ let json = JSON.parse(fetch(alistapi.server + "/api/fs/search", { headers: headers, body: { "per_page": 100, "page": 1, "parent": "/", "keywords": input }, method: 'POST', timeout: 10000 }));
+ if (json.code == 200) {
+ dirlist = getlist(json.data.content, 1);
+ filelist = getlist(json.data.content, 0, alistapi.nofilter ? 0 : fileFilter);
+ } else if (json.code == 500) {
+ if (!notoast) { toast(alistapi.name + ' 搜索失败.' + json.message); }
+ } else if (json.code == 401) {
+ if (logintoken(alistapi.server)) {
+ //alistSearch(alistapi,input,notoast);
+ } else {
+ if (!notoast) { toast(alistapi.name + ' 登录令牌token失效,需要重新获取'); }
+ }
+ }
+ } catch (e) {
+ //log(alistapi.name+' 内置搜索出错,偿试小雅搜索>'+e.message);
+ try {
+ let html = fetch(alistapi.server + '/search?box=' + input + '&url=&type=video');
+ let list = pdfa(html, 'body&&div&&a');
+ list.forEach(item => {
+ let txt = pdfh(item, "a&&href");
+ let parent = txt.substring(0, txt.lastIndexOf("/"));
+ let name = txt.substring(txt.lastIndexOf('/') + 1);
+ let suffix = name.substring(name.lastIndexOf('.') + 1);
+ if (suffix.length > 3 && !contain.test(suffix) && !dirlist.some(d => d.parent + '/' + d.name == parent)) {
+ dirlist.push({
+ "parent": parent,
+ "name": name,
+ "is_dir": true
+ })
+ } else if (contain.test(suffix) && !dirlist.some(d => d.parent + '/' + d.name == parent)) {
+ filelist.push({
+ "parent": parent,
+ "name": name,
+ "is_dir": false
+ })
+ }
+ })
+ } catch (e) {
+ log(alistapi.name + '>偿试小雅搜索失败');
+ }
+ }
+ let searchlist = [];
+ try {
+ let templist = [];
+ dirlist.forEach(item => {
+ if (!templist.some(s => item.parent.indexOf(s.parent) > -1 && s.parent != '/')) {
+ templist.push(item);
+ }
+ })
+
+ searchlist = searchlist.concat(arrayAdd(templist, 1, alistapi));
+
+ templist = [];
+ filelist.forEach(item => {
+ if (!dirlist.some(d => item.parent.indexOf(d.parent) > -1 && d.parent != '/') || item.parent == '/') {
+ templist.push(item);
+ }
+ })
+ searchlist = searchlist.concat(arrayAdd(templist, 0, alistapi));
+ } catch (e) {
+ log(alistapi.name + '>生成搜索数据失败>' + e.message);
+ }
+ return searchlist;
+}
+
+function alistSearch2(input, notoast) {
+ showLoading('搜索中,请稍后...');
+ let alistMark = storage0.getMyVar('alistMark') || {};
+ let i = 0;
+ let one = "";
+ for (var k in alistMark) {
+ i++;
+ if (i == 1) { one = k }
+ }
+ if (i > 30) { delete alistMark[one]; }
+ let task = function (obj) {
+ try {
+ let searchlist = alistSearch(obj, input, notoast);
+ if (searchlist.length > 0) {
+ hideLoading();
+ searchlist.unshift({
+ title: obj.name + " 找到" + searchlist.length + "条 “" + input + "” 相关",
+ url: "hiker://empty",
+ col_type: "text_center_1",
+ extra: {
+ cls: "loadlist"
+ }
+ });
+ searchlist.unshift({
+ col_type: "line_blank",
+ extra: {
+ cls: "loadlist"
+ }
+ });
+ alistMark[input] = alistMark[input] || [];
+ alistMark[input] = alistMark[input].concat(searchlist);
+ addItemBefore('listloading', searchlist);
+ } else {
+ if (!notoast) { log(obj.name + ">未搜索到 “" + input + "”"); }
+ }
+ } catch (e) {
+ if (!notoast) { log(obj.name + '>搜索失败>' + e.message); }
+ }
+ return 1;
+ }
+ let list = datalist.map((item) => {
+ return {
+ func: task,
+ param: item,
+ id: item.server
+ }
+ });
+ if (list.length > 0) {
+ deleteItemByCls('loadlist');
+ putMyVar('diskSearch', '1');
+ be(list, {
+ func: function (obj, id, error, taskResult) {
+ },
+ param: {
+ }
+ });
+ storage0.putMyVar('alistMark', alistMark);
+ clearMyVar('diskSearch');
+ toast('搜索完成');
+ } else {
+ toast('无接口,无法搜索');
+ }
+ hideLoading();
+}
+
+function alistSet() {
+ setPageTitle('⚙设置 | Alist网盘');
+ /*
+ try{
+ eval("var alistData=" + fetch(alistfile));
+ let jknum = alistData.drives.length;
+ }catch(e){
+ var alistData= {drives:[]};
+ }
+
+ let alistconfig = alistData.config || {};
+ let contain = alistconfig.contain || audiovisual;
+ let fileFilter = alistconfig['fileFilter']==0?0:1;
+ let datalist = alistData.drives;
+ */
+ var d = [];
+ d.push({
+ title: fileFilter ? '音视频过滤开' : '音视频过滤关',
+ url: $('#noLoading#').lazyRule((fileFilter, aliconfig, alicfgfile) => {
+ let sm = "";
+ if (fileFilter) {
+ aliconfig['fileFilter'] = 0;
+ sm = "已关闭音视频文件过滤,将显示全部文件";
+ } else {
+ aliconfig['fileFilter'] = 1;
+ sm = "已开启文件过滤,仅显示音视频文件";
+ }
+ writeFile(alicfgfile, JSON.stringify(aliconfig));
+ refreshPage(false);
+ return 'toast://' + sm;
+ }, fileFilter, aliconfig, alicfgfile),
+ img: fileFilter ? "https://hikerfans.com/tubiao/messy/55.svg" : "https://hikerfans.com/tubiao/messy/56.svg",
+ col_type: "icon_2"
+ });
+ d.push({
+ title: '音视频后缀名',
+ url: $(contain, "开启过滤后,仅允许显示的音频或视频文件格式,用|隔开").input((aliconfig, alicfgfile) => {
+ if (input) {
+ aliconfig['contain'] = input.replace(/\./g, "");
+ } else {
+ delete aliconfig['contain'];
+ }
+ writeFile(alicfgfile, JSON.stringify(aliconfig));
+ refreshPage(false);
+ return 'toast://已设置音视频文件格式后缀';
+ }, aliconfig, alicfgfile),
+ img: "https://hikerfans.com/tubiao/messy/145.svg",
+ col_type: "icon_2"
+ });
+ d.push({
+ col_type: "line"
+ });
+ d.push({
+ title: '增加',
+ url: $("", "alist链接地址\n如:https://alist.abc.com").input((alistfile) => {
+ if (!input.startsWith('http')) {
+ return 'toast://链接有误';
+ }
+ if (input.endsWith('/')) {
+ input = input.slice(0, input.length - 1);
+ }
+ showLoading('正在较验有效性');
+ let apiurl = input + "/api/public/settings";
+ try {
+ let getapi = JSON.parse(fetch(apiurl, { timeout: 10000 }));
+ hideLoading();
+ if (getapi.code == 200 && /^v3|^3|小幸运内置/.test(getapi.data.version)) {
+ return $("", "当前链接有效,起个名保存吧").input((alistfile, api) => {
+ try {
+ eval("var alistData=" + fetch(alistfile));
+ let jknum = alistData.drives.length;
+ } catch (e) {
+ var alistData = { drives: [] };
+ }
+ if (alistData.drives.some(item => item.server == input)) {
+ return 'toast://已存在';
+ }
+ if (input != "") {
+ alistData.drives.push({
+ "name": input,
+ "server": api
+ })
+ writeFile(alistfile, JSON.stringify(alistData));
+ refreshPage(false);
+ return 'toast://已保存';
+ } else {
+ return 'toast://名称为空,无法保存';
+ }
+ }, alistfile, input);
+ } else {
+ return 'toast://不支持v2版本,仅支持v3以上版本';
+ }
+ } catch (e) {
+ hideLoading();
+ return 'toast://链接无效';
+ }
+ }, alistfile),
+ img: "https://hikerfans.com/tubiao/more/25.png",
+ col_type: "icon_small_3"
+ });
+ d.push({
+ title: '导入',
+ url: $("", "alist分享口令的云剪贴板").input((alistfile) => {
+ try {
+ let inputname = input.split('¥')[0];
+ if (inputname == "聚影Alist") {
+ showLoading("正在导入,请稍后...");
+ let parseurl = aesDecode('Juying', input.split('¥')[1]);
+ let content = parsePaste(parseurl);
+ let datalist = JSON.parse(aesDecode('Juying', content));
+ try {
+ eval("var alistData=" + fetch(alistfile));
+ let jknum = alistData.drives.length;
+ } catch (e) {
+ hideLoading();
+ var alistData = { drives: [] };
+ }
+ let newdatalist = alistData.drives;
+ let num = 0;
+ for (let i = 0; i < datalist.length; i++) {
+ if (!newdatalist.some(item => item.server == datalist[i].server)) {
+ newdatalist.push(datalist[i]);
+ num = num + 1;
+ }
+ }
+ alistData.drives = newdatalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ hideLoading();
+ refreshPage(false);
+ return "toast://合计" + datalist.length + "个,导入" + num + "个";
+ } else {
+ return "toast://聚影√:非Alist口令";
+ }
+ } catch (e) {
+ return "toast://聚影√:口令有误";
+ }
+ }, alistfile),
+ img: "https://hikerfans.com/tubiao/more/43.png",
+ col_type: "icon_small_3"
+ });
+ d.push({
+ title: '分享',
+ url: datalist.length == 0 ? "toast://alist接口为0,无法分享" : $().lazyRule((datalist) => {
+ let pasteurl = sharePaste(aesEncode('Juying', JSON.stringify(datalist)));
+ if (pasteurl) {
+ let code = '聚影Alist¥' + aesEncode('Juying', pasteurl) + '¥共' + datalist.length + '条';
+ copy(code);
+ return "toast://(全部)Alist分享口令已生成";
+ } else {
+ return "toast://分享失败,剪粘板或网络异常";
+ }
+ }, datalist),
+ img: "https://hikerfans.com/tubiao/more/3.png",
+ col_type: "icon_small_3"
+ });
+ d.push({
+ col_type: "line"
+ });
+
+ datalist.forEach(item => {
+ d.push({
+ title: item.name,
+ url: $(["复制地址", "分享接口", "删除接口", "密码管理", item.nofilter ? "全局过滤" : "禁止过滤", "登录令牌", "向上进位", "向下落位", "列表置顶", "列表置底"], 2).select((item, alistfile) => {
+ if (input == "复制地址") {
+ copy(item.name + item.server);
+ return "hiker://empty";
+ } else if (input == "分享接口") {
+ showLoading('分享上传中,请稍后...');
+ let oneshare = []
+ oneshare.push(item);
+ let pasteurl = sharePaste(aesEncode('Juying', JSON.stringify(oneshare)));
+ hideLoading();
+ if (pasteurl) {
+ let code = '聚影Alist¥' + aesEncode('Juying', pasteurl) + '¥共1条';
+ copy(code);
+ return "toast://(单个)Alist分享口令已生成";
+ } else {
+ return "toast://分享失败,剪粘板或网络异常";
+ }
+ } else if (input == "登录令牌") {
+ return $("", "此接口的登录用户名\n留空则清除令牌token").input((api, alistfile) => {
+ if (input == "") {
+ eval("var alistData=" + fetch(alistfile));
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == api)[0]);
+ delete datalist[index].token;
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ return "toast://已清除令牌token,取消登录状态";
+ }
+ return $("", "此接口的登录密码").input((user, api, alistfile) => {
+ try {
+ let html = fetch(api + "/api/auth/login", { headers: { 'content-type': 'application/json;charset=UTF-8' }, body: { "Username": user, "Password": input }, method: 'POST', timeout: 10000 });
+ let json = JSON.parse(html);
+ if (json.code == 200) {
+ eval("var alistData=" + fetch(alistfile));
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == api)[0]);
+ datalist[index].token = json.data.token;
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ let atokenlist = storage0.getItem('atokenlist', {});
+ atokenlist[api] = { user: user, pwd: input };
+ storage0.setItem('atokenlist', atokenlist);
+ return "toast://登录用户令牌已获取成功";
+ } else {
+ return "toast://" + json.message;
+ }
+ } catch (e) {
+ return "toast://" + e.message;
+ }
+ }, input, api, alistfile)
+ }, item.server, alistfile)
+ } else {
+ function Move(arr, a, b) {
+ let arr_temp = [].concat(arr);
+ arr_temp.splice(b, 0, arr_temp.splice(a, 1)[0]);
+ return arr_temp;
+ }
+ eval("var alistData=" + fetch(alistfile));
+
+ if (input == "删除接口") {
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == item.server)[0]);
+ datalist.splice(index, 1);
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ let atokenlist = storage0.getItem('atokenlist', {});
+ delete atokenlist[item.server];
+ storage0.setItem('atokenlist', atokenlist);
+ refreshPage(false);
+ return 'toast://已删除';
+ } else if (input == "全局过滤" || input == "禁止过滤") {
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == item.server)[0]);
+ let sm = "";
+ if (input == "禁止过滤") {
+ datalist[index].nofilter = true;
+ sm = "已设置此接口不过滤文件";
+ } else {
+ delete datalist[index].nofilter;
+ sm = "此接口是否过滤文件交由全局设置";
+ }
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ refreshPage(false);
+ return 'toast://' + sm;
+ } else if (input == "向上进位" || input == "向下落位" || input == "列表置顶" || input == "列表置底") {
+ let datalist = alistData.drives;
+ let index = datalist.indexOf(datalist.filter(d => d.server == item.server)[0]);
+ if ((index == 0 && (input == "向上进位" || input == "列表置顶")) || (index == datalist.length - 1 && (input == "向下落位" || input == "列表置底"))) {
+ return 'toast://位置移动无效';
+ } else {
+ if (input == "向上进位" || input == "向下落位") {
+ let newindex = input == "向上进位" ? index - 1 : index + 1;
+ datalist.splice(newindex, 0, datalist.splice(index, 1)[0]);
+ } else {
+ let data = datalist[index];
+ datalist.splice(index, 1);
+ if (input == "列表置顶") {
+ datalist.unshift(data);
+ } else {
+ datalist.push(data);
+ }
+ }
+ }
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ refreshPage(false);
+ return 'toast://已移动';
+ } else if (input == "密码管理") {
+ return $('hiker://empty#noRecordHistory##noHistory#').rule((item, alistfile) => {
+ setPageTitle(item.name + ' | 密码管理');
+ eval("var alistData=" + fetch(alistfile));
+ let datalist = alistData.drives;
+ let d = [];
+ d.push({
+ title: '🔢 添加密码',
+ url: $("", "有密码的路径").input((api, alistData, alistfile) => {
+ return $("", "此路径的密码").input((path, api, alistData, alistfile) => {
+ let datalist = alistData.drives;
+ for (let i = 0; i < datalist.length; i++) {
+ if (datalist[i].server == api) {
+ let password = datalist[i].password || {};
+ password[path] = input;
+ datalist[i].password = password;
+ break;
+ }
+ }
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ refreshPage(false);
+ return "hiker://empty";
+ }, input, api, alistData, alistfile)
+ }, item.server, alistData, alistfile),
+ img: "https://hikerfans.com/tubiao/movie/98.svg",
+ col_type: "text_center_1"
+ });
+ for (let i = 0; i < datalist.length; i++) {
+ if (datalist[i].server == item.server) {
+ var pwdlist = datalist[i].password || {}
+ break;
+ }
+ }
+ for (let key in pwdlist) {
+ d.push({
+ title: key,
+ desc: pwdlist[key],
+ url: $("确定删除:" + key).confirm((api, key, alistData, alistfile) => {
+ let datalist = alistData.drives;
+ for (let i = 0; i < datalist.length; i++) {
+ if (datalist[i].server == api) {
+ let password = datalist[i].password;
+ delete password[key];
+ datalist[i].password = password;
+ break;
+ }
+ }
+ alistData.drives = datalist;
+ writeFile(alistfile, JSON.stringify(alistData));
+ refreshPage(false);
+ return "hiker://empty";
+ }, item.server, key, alistData, alistfile),
+ col_type: "text_1"
+ });
+ }
+ setResult(d);
+ }, item, alistfile)
+ }
+ }
+ }, item, alistfile),
+ desc: item.server,
+ col_type: "text_1"
+ });
+ })
+
+ setResult(d);
+}
\ No newline at end of file