diff --git a/plugins/readme/ico.png b/plugins/readme/ico.png new file mode 100644 index 000000000..d89cdde5a Binary files /dev/null and b/plugins/readme/ico.png differ diff --git a/plugins/readme/index.html b/plugins/readme/index.html new file mode 100755 index 000000000..99adcc1b6 --- /dev/null +++ b/plugins/readme/index.html @@ -0,0 +1,36 @@ + +
+
+
+
+
正在跑分中
+
+
+
开始跑分
+
+
公式:1万次整数+2万次浮点+1亿位圆周率+1万次排序 +((磁盘读+磁盘写)*IO速度)+内存容量
+
+
+
+
+
CPU
+
cpu运算能力
+
+
+
+
+
磁盘
+
磁盘读写能力
+
+
+
+
+
内存
+
内存容量
+
+
+
+ \ No newline at end of file diff --git a/plugins/readme/index.py b/plugins/readme/index.py new file mode 100755 index 000000000..bdc834a89 --- /dev/null +++ b/plugins/readme/index.py @@ -0,0 +1,11 @@ +# coding: utf-8 + +import time +import psutil +import random +import os +import urllib +import binascii +import json +import public +import re diff --git a/plugins/readme/info.json b/plugins/readme/info.json new file mode 100755 index 000000000..4d752e7c8 --- /dev/null +++ b/plugins/readme/info.json @@ -0,0 +1,14 @@ +{ + "title":"插件开发说明", + "tip":"soft", + "name":"readme", + "type":"扩展", + "ps":"(mdserver-web)插件产开发说明,每个版本可能有所变化!", + "versions": "0.1", + "shell":"install.sh", + "checks":"mdserver-web/plugins/readme/r", + "author":"mdserver-web", + "home":"github.com/midoks/mdserver-web", + "date":"2018-11-30", + "pid":"5" +} \ No newline at end of file diff --git a/plugins/readme/install.sh b/plugins/readme/install.sh new file mode 100755 index 000000000..0653a7873 --- /dev/null +++ b/plugins/readme/install.sh @@ -0,0 +1,27 @@ +#!/bin/bash +PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin +export PATH + +curPath=`pwd` +rootPath=$(dirname "$curPath") +rootPath=$(dirname "$rootPath") +serverPath=$(dirname "$rootPath") + +install_tmp=${rootPath}/tmp/bt_install.pl + +Install_readme() +{ + echo '安装完成' > $install_tmp +} + +Uninstall_readme() +{ + echo '卸载完成' > $install_tmp +} + +action=$1 +if [ "${1}" == 'install' ];then + Install_readme +else + Uninstall_readme +fi diff --git a/plugins/readme/js/score.js b/plugins/readme/js/score.js new file mode 100755 index 000000000..f1cfec773 --- /dev/null +++ b/plugins/readme/js/score.js @@ -0,0 +1,301 @@ +(function($){ + +$.fn.stamper = function(options) { + var opts = $.extend({ + scale : 5, // 图片初始大小,在原始图片大小上的倍数 + speed : 600 // 动画持续时间,单位毫秒 + }, options); + + this.each(function(index) { + var target = $(this); + var imgId = target.attr("data-stamper-img-id"); + if (!imgId) { + imgId = "jquery_stamper_img_" + (new Date().getTime()) + "_" + index; + target.attr("data-stamper-img-id", imgId); + } + var img = new Image(); + img.src = opts.image; + img.onload = function() { + var orgiCoor = getImageCoordinate(target, img); + var initCoor = getStartCoordinate(target, img, opts.scale); + var imgObj = getImageElement(imgId).attr("src", img.src) + .css({ + position : "absolute", + opacity : "0", + left : "-106px", + top : "-116px", + width : initCoor.w + "px", + height : initCoor.h + "px" + }) + .show() + .animate({ + opacity : "1", + left : "0px", + top : "0px", + width : orgiCoor.w + "px", + height : orgiCoor.h + "px" + }, opts.speed, opts.complete); + }; + }); +}; + +/** 获取img的DOM对象 **/ +function getImageElement(id) { + var img = $("#" + id); + if (img.length == 0) { + return $("").appendTo($(".ts-stamper")).hide(); + } else { + return img.hide(); + } +} + +/** 获取图片的落脚坐标点(以当前元素为基准)和尺寸信息,格式:{x:10,y:20,h:100,w:200} **/ +function getImageCoordinate(target, image) { + var offset = $(target).offset(); + var cx = offset.left + $(target).width()/2; + var cy = offset.top + $(target).height()/2; + return { + x : cx - image.width/2, + y : cy - image.height/2, + w : image.width, + h : image.height + }; +} + +/** 给定倍数(multiple)获取图片的开始位置和大小信息,格式:{x:10,y:20,h:100,w:200} **/ +function getStartCoordinate(target, image, multiple) { + var offset = $(target).offset(); + var cx = offset.left + $(target).width()/2; + var cy = offset.top + $(target).height()/2; + var width = image.width * multiple; + var height = image.height * multiple; + return { + x : cx - width/2, + y : cy - height/2, + w : width, + h : height + }; +} +})(jQuery); + +function startTest(){ + var name = $(".ts-btn").text(); + switch(name){ + case '开始跑分': + startTestServer(name); + break; + case '正在跑分': + stopTestServer(); + break; + case '重新跑分': + startTestServer(name); + break; + } +} +if(getCookie("#Total") >0){ + $(".old-score").html("上次跑分:"+getCookie("#Total") + ' 分 我的排名').show(); +} + +function startTestServer(name){ + layer.confirm('测试过程可能需要几分钟时间且占用大量服务器资源,继续吗?',{title:'性能测试',closeBtn:2},function(){ + layer.closeAll('dialog'); + if(name == "重新跑分"){ + $(".btphb").remove(); + $(".ts-content").find(".ts-box-rotate").remove(); + $(".ts-h-s-num").html('正在跑分中'); + $(".ts-btn-reset").removeAttr("onclick").width(140); + $(".ts-cpu-over").removeClass("ts-cpu-over"); + $(".ts-disk-over").removeClass("ts-disk-over"); + $(".ts-mem-over").removeClass("ts-mem-over"); + $(".ts-h-s-img").removeClass("ts-h-s-img1"); + $(".ts-h-s-img").removeClass("ts-h-s-img2"); + $(".ts-h-s-img").removeClass("ts-h-s-img3"); + $(".ts-h-s-img").addClass("ts-h-s-imging"); + $(".ts-stamper").html(""); + } + $(".old-score").fadeOut(); + $(".ts-btn").removeClass("ts-btn-start").text("正在跑分").animate({"left":"490px"}); + $(".ts-h-score").fadeIn(); + $(".ts-cpu").addClass("ts-cpu-ing").append("
"); + $(".ts-info").html("正在测试整数运算性能[1万次]"); + var cpuscore = 0; + $.get('/plugin?action=a&name=score&s=testCpu&type=1',function(rint){ + cpuscore += rint.score; + $(".ts-info").html("正在测试浮点运算性能[2万次]"); + $.get('/plugin?action=a&name=score&s=testCpu&type=2',function(rfloat){ + cpuscore += rfloat.score; + $(".ts-info").html("正在测试圆周率运算[1亿位]"); + $.get('/plugin?action=a&name=score&s=testCpu&type=3',function(rpi){ + cpuscore += rpi.score; + $(".ts-info").html("正在测试二叉树排序算法[1万次]"); + $.get('/plugin?action=a&name=score&s=testCpu&type=4',function(r1){ + r1.score += cpuscore; + $(".ts-cpu").removeClass("ts-cpu-ing").addClass("ts-cpu-over").find(".ts-box-rotate").remove(); + $(".ts-disk").addClass("ts-disk-ing").append("
"); + $(".ts-cpu .ts-c-b-score").html(r1.score); + $(".ts-cpu .ts-c-b-info").html(r1.cpuType + ' ' +r1.cpuCount + ' 核心'); + //$("#cpuType").html('型号:' + r1.cpuType); + setCookie('cpuTotal',r1.score); + setCookie('cpuCount',r1.cpuCount + ' 核心'); + setCookie('cpuType','型号:' + r1.cpuType); + $(".ts-info").html("正在测试磁盘性能"); + $.get('/plugin?action=a&name=score&s=testDisk',function(r2){ + $(".ts-disk").removeClass("ts-disk-ing").addClass("ts-disk-over").find(".ts-box-rotate").remove(); + $(".ts-mem").addClass("ts-mem-ing").append("
"); + $(".ts-disk .ts-c-b-score").html(r2.score); + $(".ts-disk .ts-c-b-info").html('读: ' + r2.read + ' MB,写: ' + r2.write + ' MB'); + setCookie('diskTotal',r2.score); + setCookie('diskRead','Read: ' + r2.read + ' MB'); + setCookie('diskWrite','Write: ' + r2.write + ' MB'); + $(".ts-info").html("正在测试内存"); + $.get('/plugin?action=a&name=score&s=testMem','',function(r3){ + $(".ts-mem").removeClass("ts-mem-ing").addClass("ts-mem-over").find(".ts-box-rotate").remove(); + $(".ts-mem .ts-c-b-score").html(parseInt(r3)); + $(".ts-mem .ts-c-b-info").html( r3 + ' MB'); + var total = r1.score+r2.score+ parseInt(r3); + $(".ts-h-s-num span").html(total + ' 分').css({"font-size":"40px"}); + setCookie("#memTotal",r3 + ' MB'); + setCookie("#Total",total); + $(".ts-btn").addClass("ts-btn-reset").text("重新跑分").css({"left":"550px","width":"80px"}).attr("onclick","startTestServer('重新跑分')"); + $(".ts-h-score").after('
我的排名
'); + if(total<2500){ + $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img1"); + scoreIco("1"); + } + if(total>2500 && total<10000){ + $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img2"); + scoreIco("2"); + } + if(total > 10000){ + $(".ts-h-s-img").removeClass("ts-h-s-imging").addClass("ts-h-s-img3"); + scoreIco("3"); + } + + var data = "soc="+total; + $.get("/ajax?action=GetAd&name=zun",data,function(rad){ + $(".ts-info").html(rad); + }); + }); + }); + }); + }); + }); + }); + }); +} +function stopTestServer(){ + /* + $(".ts-btn").addClass("ts-btn-start").removeClass("ts-btn-reset").text("开始测试").animate({"left":"233px"}); + $(".ts-h-score").fadeOut(); + $(".ts-info").html("跑分计算规则为:通过计算cpu运算能力,计算内存吞吐能力,计算磁盘读写能力"); + */ + //layer.msg("测试中,不能停止",{shade:0.3}); + return false; +} +function scoreIco(ico) { + var img = ''; + switch(ico){ + case "1": + img = ''; + break; + case "2": + img = ''; + break; + case "3": + img = ''; + break; + } + $(".ts-stamper").stamper({ + image : img, + scale : 3, + speed : 300, + complete : function() { + //alert("完成啦~~~~"); + } + }) +} + +function GetScore(){ + $.get('/plugin?action=a&name=score&s=GetScore',function(rdata){ + + }); +} +GetScore(); +//我的排名 +function btphb(){ + $.get("/ssl?action=GetUserInfo",function(rdata){ + if(rdata.status){ + var loadT = layer.msg("获取列表..",{icon:16,time:0}); + var tr = ""; + $.get("/plugin?action=a&name=score&s=GetScore",function(pm){ + layer.close(loadT); + if(pm.status){ + for(var i=0; i'+pm.data[i].core+'核 | '+pm.data[i].memory+'MB | 读'+pm.data[i].disk.split(",")[0]+'MB/s | 写'+pm.data[i].disk.split(",")[1]+'MB/s'+pm.data[i].virt+''+pm.data[i].isp+''+pm.data[i].total_score+'查看排名'; + } + layer.open({ + type: 1, + area: "700px", + title: "我的服务器跑分", + closeBtn: 2, + shadeClose: false, + content: '
\ +
\ + \ + \ + '+tr+'\ +
服务器IP配置平台服务商跑分查看排名
\ +
\ +
' + + }) + } + + }) + } + else{ + bindBTName(2,'b'); + } + }); +} + +//绑定修改宝塔账号 +function bindBTName(a,type){ + var titleName = "绑定宝塔账号"; + if(type == "b"){ + btn = ""; + } + if(a == 1) { + p1 = $("#p1").val(); + p2 = $("#p2").val(); + $.post(" /ssl?action=GetToken", "username=" + p1 + "&password=" + p2, function(b) { + if(b.status) { + $(".btn-bw").click(); + layer.msg(b.msg, { + icon: 1 + }); + $.get("/plugin?action=a&name=score&s=SubmitScore",function(p){ + //layer.msg(p.msg,{icon:p.status?1:2}); + }); + btphb(); + } else { + layer.msg(b.msg, { + icon: 2 + }) + } + }); + return + } + var bindw = layer.open({ + type: 1, + area: "290px", + title: titleName, + closeBtn: 2, + shift: 5, + shadeClose: false, + content: "
账号
密码
"+btn+"
" + }) + $(".btn-bw").click(function(){ + layer.close(bindw); + }); +} \ No newline at end of file diff --git a/route/plugins.py b/route/plugins.py index 8c2967dcc..61ec1cbc7 100644 --- a/route/plugins.py +++ b/route/plugins.py @@ -51,6 +51,13 @@ def indexList(): return public.getJson(data) +@plugins.route('/index_sort', methods=['POST']) +def indexSort(): + sort = request.form.get('ssrot', '') + # data = plugin_api.plugin_api().setIndexSort() + return public.returnJson(False, '已将安装任务添加到队列!') + + @plugins.route('/install', methods=['POST']) def install(): diff --git a/static/js/public.js b/static/js/public.js index 4f7a96fb0..b432c3f0a 100755 --- a/static/js/public.js +++ b/static/js/public.js @@ -341,6 +341,25 @@ function showHidePwd() { }) } +function showMsg(msg, callback ,icon, time){ + + if (typeof time == 'undefined'){ + time = 2000; + } + + if (typeof icon == 'undefined'){ + icon = {}; + } + + var loadT = layer.msg(msg, icon); + setTimeout(function() { + layer.close(loadT); + if (typeof callback == 'function'){ + callback(); + } + }, time); +} + function openPath(a) { setCookie("Path", a); window.location.href = "/files" @@ -489,89 +508,6 @@ function OnlineEditFile(k, f) { }); } -function ServiceAdmin(a, b) { - if(!isNaN(a)) { - a = "php-fpm-" + a - } - a = a.replace('_soft',''); - var c = "name=" + a + "&type=" + b; - var d = ""; - - switch(b) { - case "stop": - d = lan.bt.stop; - break; - case "start": - d = lan.bt.start; - break; - case "restart": - d = lan.bt.restart; - break; - case "reload": - d = lan.bt.reload; - break - } - layer.confirm( lan.get('service_confirm',[d,a]), {icon:3, - closeBtn: 2 - }, function() { - var e = layer.msg(lan.get('service_the',[d,a]), { - icon: 16, - time: 0 - }); - $.post("/system?action=ServiceAdmin", c, function(g) { - layer.close(e); - - var f = g.status ? lan.get('service_ok',[a,d]):lan.get('service_err',[a,d]); - layer.msg(f, { - icon: g.status ? 1 : 2 - }); - if(b != "reload" && g.status == true) { - setTimeout(function() { - window.location.reload() - }, 1000) - } - if(!g.status) { - layer.msg(g.msg, { - icon: 2, - time: 0, - shade: 0.3, - shadeClose: true - }) - } - }).error(function() { - layer.close(e); - layer.msg(lan.public.success, { - icon: 1 - }) - }) - }) -} - -function GetConfigFile(a) { - var b = ""; - switch(a) { - case "mysql": - b = "/etc/my.cnf"; - break; - case "nginx": - b = "/www/server/nginx/conf/nginx.conf"; - break; - case "pure-ftpd": - b = "/www/server/pure-ftpd/etc/pure-ftpd.conf"; - break; - case "apache": - b = "/www/server/apache/conf/httpd.conf"; - break; - case "tomcat": - b = "/www/server/tomcat/conf/server.xml"; - break; - default: - b = "/www/server/php/" + a + "/etc/php.ini"; - break - } - OnlineEditFile(0, b) -} - function GetPHPStatus(a) { if(a == "52") { layer.msg(lan.bt.php_status_err, { diff --git a/static/js/soft.js b/static/js/soft.js index 081f52322..001511c0e 100755 --- a/static/js/soft.js +++ b/static/js/soft.js @@ -298,7 +298,6 @@ function toIndexDisplay(name, version, coexist) { var verinfo = version.replace(/\./, ""); status = $("#index_" + name + verinfo).prop("checked") ? "0" : "1"; } - console.log(name,status,version); var data = "name=" + name + "&status=" + status + "&version=" + version; $.post("/plugins/set_index", data, function(rdata) { @@ -323,6 +322,7 @@ function indexSoft() { var loadT = layer.msg('正在获取列表...', { icon: 16, time: 0, shade: [0.3, '#000'] }); $.get('/plugins/index_list', function(rdata) { layer.close(loadT); + $("#indexsoft").html(''); var con = ''; for (var i = 0; i < rdata.length; i++) { var plugin = rdata[i]; @@ -340,8 +340,6 @@ function indexSoft() { version_info = version_info.substring(0, version_info.length - 1); } - console.log(version_info, plugin); - if (plugin.status == true) { state = '' @@ -353,18 +351,18 @@ function indexSoft() { if (plugin.coexist){ name = plugin.title + ' '; } - - //(\'' + plugin.name + '\',\'' + version_info + '\')" + if (plugin.display == true) { con += '
\ \
\ -
\ +
\
' + name + state + '
\
\
' } } + $("#indexsoft").html(con); //软件位置移动 var softboxlen = $("#indexsoft > div").length; @@ -378,13 +376,19 @@ function indexSoft() { } $("#indexsoft").append(softboxcon); } - $("#indexsoft").dragsort({ dragSelector: ".spanmove", dragBetween: true, dragEnd: saveOrder, placeHolderTemplate: "
" }); + $("#indexsoft").dragsort({ dragSelector: ".spanmove", dragBetween: true, dragEnd: saveOrder, placeHolderTemplate: "
" }); function saveOrder() { var data = $("#indexsoft > div").map(function() { return $(this).attr("data-id"); }).get(); var ssort = data.join("|"); $("input[name=list1SortOrder]").val(ssort); - $.post("/plugin?action=savePluginSort", 'ssort=' + ssort, function(rdata) {}); + $.post("/plugins/index_sort", 'ssort=' + ssort, function(rdata) { + if (!rdata.status){ + showMsg('设置失败:'+ rdata.msg, function(){ + indexSoft(); + }, { icon: 16, time: 0, shade: [0.3, '#000'] }); + } + },'json'); }; },'json'); }