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速度)+内存容量
+
+
+
\ 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].address+' | '+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: ''
+
+ })
+ }
+
+ })
+ }
+ 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-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');
}