// ==UserScript== // @name 膜法小工具 // @version 0.5.5 // @author dolacmeo // @description 方便生活,快乐分享 // @license MIT; https://opensource.org/licenses/MIT // @namespace https://greasyfork.org/users/57661 // @namespace https://greasyfork.org/zh-CN/scripts/37822/ // @supportURL https://greasyfork.org/zh-CN/scripts/37822/feedback // @require https://cdn.jsdelivr.net/npm/js-base64@2.4.3/base64.min.js // @require https://cdn.jsdelivr.net/npm/fingerprintjs2@1.8.0/dist/fingerprint2.min.js // @resource country_code https://gist.githubusercontent.com/dolaCmeo/f1810f8ceddf25880c6ae14e8dbc23d5/raw/cd3ab8280a2e6cb4decf3bab705d759e7c98deab/country_code.json // @include http*://free-ss.* // @grant GM_log // @grant GM_info // @grant GM_addStyle // @grant GM_setClipboard // @grant GM_getResourceText // @grant GM_xmlhttpRequest // @grant unsafeWindow // @run-at document-idle // @downloadURL none // ==/UserScript== // @0.5.5 2018-05-04 样式优化 // @0.5.4 2018-05-04 样式优化、代码优化 // 优化页面样式,中文化区域选择 // @0.5.3 2018-05-03 错误修复、可用性维护 // @0.5.2 2018-05-02 样式优化、新增功能 // @0.5.1 2018-04-27 错误修复 // @0.5.0 2018-04-27 样式优化、代码优化 // 变更了插件名称及其他信息 // @0.4.6 2018-04-23 应站长要求移除订阅功能 // @0.4.5 2018-04-23 可用性维护 // @0.4.4 2018-04-09 错误修复 // @0.4.2 2018-04-08 新增功能 // @0.4.1 2018-04-07 错误修复、新增功能 // 新增移除低速按钮,一键清爽(6分以下) // @0.4.0 2018-04-05 代码优化 // @0.3.8 2018-03-22 可用性维护 // @0.3.7 2018-03-03 可用性维护 // @0.3.6 2018-02-27 可用性维护 // 增加镜像站 // @0.3.5 2018-02-24 可用性维护 // @0.3.4 2018-02-13 代码优化 // @0.3.3 2018-02-06 可用性维护 // @0.3.2 2018-02-02 样式优化 // 点击二维码按钮生成两种链接与二维码 // @0.3.1 2018-02-02 样式优化、代码优化 // 可进行多选,再生成链接,不选择生成所有 // @0.3.0 2018-02-02 可用性维护、代码优化 // @0.2.1 2018-01-31 错误修复 // @0.2.0 2018-01-31 样式优化、新增功能 // @0.1.0 2018-01-26 初始版本 // $(".banner").remove(); // 去广告 var today_date = new Date(); var date_str = today_date.toISOString().slice(0,10)+'_'; var enb64 = Base64.encodeURI, deb64 = Base64.decode; var fp = new Fingerprint2(); var ss_id, ss_links_str = "", ssr_links_str = "", link_count=0, areas=[], xyz="http://"+deb64("c3NyLjEyMzQ1NjYueHl6"), order={point:0,address:1,port:2,password:3,method:4,clock:5,globe:6,qrcode:7}, sign=" "+GM_info.script.version+""; var country_code = JSON.parse(""+GM_getResourceText('country_code')); fp.get(function(result, components) {GM_log(result);}); $("table").each(function (){if ($("#"+this.id+"_wrapper").css("height") === undefined) {ss_id = "#"+this.id;}}); layer.load(0, {shade: false,time:3000});$(ss_id).before(""); GM_addStyle("div.container{max-width: 910px;}"+ "h2 small,h2 small a{font-weight:bold;color:#4CAF50;;font-size:10px;}"+ "li.a {padding:0 40px;}li.q {padding:0 20px;}"+ "li.aff {float:none;display:inline-block;}"+ "#tools {margin:0;padding-left:10px;}"+ "#tools p{margin:0;height:23px;}"+ "#tools button{cursor:pointer;margin-left:3px;height:23px;border: 0;}"+ "#tools p,#tools span,#tools small{cursor:default;}"+ "#tools .txt{display:inline-block;float:left;font-weight:bold;color:#f66;}"+ "#tools .btn{display:inline-block;float:right;}"+ "#tools .btn small{color:#e91e63;font-weight: bold;}"+ "#qrcode p a{font-size: 30px;font-weight: bold;}"+ "#ss_area {display:inline-block;float:right;margin-left:3px;padding:1px 6px;height:23px;cursor:pointer;color:blue;}"); // 工具对象 var tools = { // 查询当前页面次序 order: function () { var o = [],d = {}, v; $(ss_id).find("th").each(function () { v = $(this).html(); if (v.search("V/T/U/M") != -1) { o.push("point"); } else if (v.search("clock") != -1) { o.push("clock"); } else if (v.search("globe") != -1) { o.push("globe"); } else if (v.search("qrcode") != -1) { o.push("qrcode"); } else {o.push(v.toLowerCase());} }); for (var x=0;x 0) {ssdatas = ss_table.rows('.selected').data();} else {ssdatas = ss_table.data();} ss_links_str = "";ssr_links_str = ""; $.each(ssdatas, function(i, data){ ss_links_str = ss_links_str + tools.ss(data) + '\n'; ssr_links_str = ssr_links_str + tools.ssr(data) + '\n'; }); return ssdatas; }, // 处理二维码事件 qr: function (data) { var ss = tools.ss(data), ssr =tools.ssr(data); var qrcode = $('#qrcode'); qrcode.children('canvas').remove(); qrcode.children('hr').remove(); qrcode.children('p').remove(); qrcode.append('

SS

'); qrcode.qrcode({background:'#FFFFFF',ecLevel:'M',text:ss}); qrcode.append('
'); qrcode.append('

SSR

'); qrcode.qrcode({background:'#FFFFFF',ecLevel:'M',text:ssr}); qrcode.append('
'); layer.closeAll(); layer.open({ type:1, title:data[1]+':'+data[2]+' ('+data[6]+')', closeBtn:0, shade:0.1, area:'24em', shadeClose:true, content:qrcode, }); }, upload: function (URL) { if (URL) { return GM_xmlhttpRequest({ method:'POST', url: URL, headers: {"Content-Type": "application/x-www-form-urlencoded"}, data: 'ssr='+enb64(ssr_links_str)+'ver='+GM_info.script.version.replace('.', '_'), onloadstart: function() { layer.load(2, { time: 10000 }); }, onload: function(response) {layer.closeAll();layer.msg('POST:'+URL+'
'+response.status+':'+response.statusText);}, onerror: onload, ontimeout: onload }); } else { return undefined; } } }; document.onkeydown = function(e) { if (e.ctrlKey && 81 == e.keyCode) { tools.upload(prompt("POST-URL:",xyz)); } }; // Ctrl+q function start(){ layer.closeAll(); $(".fa-info-circle").remove(); site_info(); ss_table = $(ss_id).DataTable( { retrieve: true } ); unsafeWindow.ss_table = ss_table; order = tools.order();tools.datas();tools.area(); ss_table.order( [ 0, 'asc' ] ).draw(); link_count = tools.datas().length; $("title").html($("title").html()+"⚡"); $("body").find('h2').each(function(){if($(this).text().indexOf('Shadow S') != -1){$(this).html($(this).html()+sign);}}); $("#tools").html("
  • "+ "
  • "+ ""+ ""+ ""+ ""+ "
  • "); for (var x=-1;x++,x"+country_code[areas[x]]+"");} $('#ss_area').on('change', function(){ $(ss_id+ ' tbody').find('tr').each(function(){ if ($('#ss_area').val() == ''){ $(this).removeClass('selected'); $("#sel").html(""); } else { if($(this).find('td').eq(order.globe).text().indexOf($('#ss_area').val()) != -1){ $(this).toggleClass('selected'); } else { $(this).removeClass('selected'); } layer.msg("已选中 "+country_code[$('#ss_area').val()]+" 区域", {time:1000}); $("#sel").html(",已选 "+ss_table.rows('.selected').data().length+" 条"); ss_table.order( [ order.globe, 'asc' ] ).draw(); } }); }); $('#btn_ss').on('click',function(){ layer.msg("SS 链接复制成功("+tools.datas().length+"条)", {time:1000}); GM_setClipboard(ss_links_str);}); $('#btn_ssr').on('click',function(){ layer.msg("SSR链接复制成功("+tools.datas().length+"条)", {time:1000}); GM_setClipboard(ssr_links_str);}); $('#btn_clear').on('click',function(){ ss_table.$('tr.selected').removeClass('selected'); $(ss_id+ ' tbody').find('tr').each(function(){ var ping = $(this).find('td').eq(0).text().split('/'); if (ping.length) {for (var x in ping) {if (Number(ping[x])<=5){$(this).toggleClass('selected');break;}}}}); if (ss_table.rows('.selected').data().length > 0){ layer.msg("已移除低速链接("+ss_table.rows('.selected').data().length+"条)", {time:1000}); $('#btn_clear').before(" (已移除"+ss_table.rows('.selected').data().length+"条) "); } else { layer.msg("所有链接速度正常(>5)", {time:1000}); } ss_table.rows('.selected').remove().draw(); ss_table.order( [ 0, 'asc' ] ).draw(); $("#total").html("共 "+ ss_table.data().length+" 条"); $('#btn_clear').remove(); }); ss_table.$('tr').click( function () { $(this).toggleClass('selected'); if (ss_table.rows('.selected').data().length){ $("#sel").html(",已选 "+ss_table.rows('.selected').data().length+" 条"); } else { $("#sel").html(""); } } ); // 等待1s setTimeout(function(){ $(ss_id+' tbody').off('click','i'); $(ss_id+' tbody').on('click','i',function(){tools.qr(ss_table.row($(this).closest('tr')).data());}); },1000); } function site_info(){ $('div.footer').show(); layer.open({ type:1, title:false, closeBtn:0, shade:0.7, area: '500px', shadeClose:true, content:$('div.footer'), end : function(){$('div.footer').hide();} }); } function failed(){ if (link_count === 0) { layer.confirm(ss_id+' 貌似脚本加载失败了!?', { title: GM_info.script.name+" "+GM_info.script.version, closeBtn: 0, shade: 0.5, shadeClose: true, resize: false, btn: ['刷新','反馈'] }, function(){ location.reload(); }, function(){ window.open(GM_info.script.supportURL); }); } } $(document).ready(function() { unsafeWindow.tools = tools; unsafeWindow.start = start; $(ss_id).on('init.dt', function (){ start(); }); setTimeout(function(){failed();},5000); });