diff --git a/plugins/gdrive/info.json b/plugins/gdrive/info.json
index 9e866a073..093caf880 100644
--- a/plugins/gdrive/info.json
+++ b/plugins/gdrive/info.json
@@ -15,5 +15,5 @@
"api_doc":"https://developers.google.com/drive/api/guides/about-sdk?hl=zh_CN",
"api_doc2":"https://developers.google.cn/drive/api/reference/rest/v3/comments/list?hl=zh-cn",
"date":"2022-06-26",
- "pid":"4"
+ "pid":"5"
}
\ No newline at end of file
diff --git a/plugins/lvs/ico.png b/plugins/lvs/ico.png
new file mode 100644
index 000000000..b222bacdc
Binary files /dev/null and b/plugins/lvs/ico.png differ
diff --git a/plugins/lvs/index.html b/plugins/lvs/index.html
new file mode 100755
index 000000000..6c1a0e3db
--- /dev/null
+++ b/plugins/lvs/index.html
@@ -0,0 +1,18 @@
+
+
\ No newline at end of file
diff --git a/plugins/lvs/index.py b/plugins/lvs/index.py
new file mode 100755
index 000000000..0abb29d0a
--- /dev/null
+++ b/plugins/lvs/index.py
@@ -0,0 +1,253 @@
+# coding:utf-8
+
+import sys
+import io
+import os
+import time
+import re
+import string
+import subprocess
+
+sys.path.append(os.getcwd() + "/class/core")
+import mw
+
+app_debug = False
+if mw.isAppleSystem():
+ app_debug = True
+
+
+def getPluginName():
+ return 'lvs'
+
+
+def getPluginDir():
+ return mw.getPluginDir() + '/' + getPluginName()
+
+
+def getServerDir():
+ return mw.getServerDir() + '/' + getPluginName()
+
+
+def getInitDFile():
+ if app_debug:
+ return '/tmp/' + getPluginName()
+ return '/etc/init.d/' + getPluginName()
+
+
+def getConfTpl():
+ path = getPluginDir() + "/conf/haproxy.conf"
+ return path
+
+
+def getConf():
+ path = getServerDir() + "/haproxy.conf"
+ return path
+
+
+def getInitDTpl():
+ path = getPluginDir() + "/init.d/" + getPluginName() + ".tpl"
+ return path
+
+
+def getArgs():
+ args = sys.argv[2:]
+ tmp = {}
+ args_len = len(args)
+
+ if args_len == 1:
+ t = args[0].strip('{').strip('}')
+ t = t.split(':')
+ tmp[t[0]] = t[1]
+ elif args_len > 1:
+ for i in range(len(args)):
+ t = args[i].split(':')
+ tmp[t[0]] = t[1]
+ return tmp
+
+
+def checkArgs(data, ck=[]):
+ for i in range(len(ck)):
+ if not ck[i] in data:
+ return (False, mw.returnJson(False, '参数:(' + ck[i] + ')没有!'))
+ return (True, mw.returnJson(True, 'ok'))
+
+
+def configTpl():
+ path = getPluginDir() + '/tpl'
+ pathFile = os.listdir(path)
+ tmp = []
+ for one in pathFile:
+ file = path + '/' + one
+ tmp.append(file)
+ return mw.getJson(tmp)
+
+
+def readConfigTpl():
+ args = getArgs()
+ data = checkArgs(args, ['file'])
+ if not data[0]:
+ return data[1]
+
+ content = mw.readFile(args['file'])
+ content = contentReplace(content)
+ return mw.returnJson(True, 'ok', content)
+
+
+def contentReplace(content):
+ service_path = mw.getServerDir()
+ content = content.replace('{$ROOT_PATH}', mw.getRootDir())
+ content = content.replace('{$SERVER_PATH}', service_path)
+ content = content.replace('{$SERVER_APP}', service_path + '/haproxy')
+ return content
+
+
+def status():
+ data = mw.execShell(
+ "ps -ef|grep haproxy |grep -v grep | grep -v python | awk '{print $2}'")
+ if data[0] == '':
+ return 'stop'
+ return 'start'
+
+
+def initDreplace():
+
+ file_tpl = getInitDTpl()
+ service_path = os.path.dirname(os.getcwd())
+
+ initD_path = getServerDir() + '/init.d'
+ if not os.path.exists(initD_path):
+ os.mkdir(initD_path)
+ file_bin = initD_path + '/' + getPluginName()
+
+ # initd replace
+ if not os.path.exists(file_bin):
+ content = mw.readFile(file_tpl)
+ content = contentReplace(content)
+ mw.writeFile(file_bin, content)
+ mw.execShell('chmod +x ' + file_bin)
+
+ # config replace
+ conf_bin = getConf()
+ if not os.path.exists(conf_bin):
+ conf_content = mw.readFile(getConfTpl())
+ conf_content = contentReplace(conf_content)
+ mw.writeFile(getServerDir() + '/haproxy.conf', conf_content)
+
+ # systemd
+ systemDir = mw.systemdCfgDir()
+ systemService = systemDir + '/haproxy.service'
+ systemServiceTpl = getPluginDir() + '/init.d/haproxy.service.tpl'
+ if os.path.exists(systemDir) and not os.path.exists(systemService):
+ service_path = mw.getServerDir()
+ se_content = mw.readFile(systemServiceTpl)
+ se_content = se_content.replace('{$SERVER_PATH}', service_path)
+ mw.writeFile(systemService, se_content)
+ mw.execShell('systemctl daemon-reload')
+
+ return file_bin
+
+
+def haOp(method):
+ file = initDreplace()
+
+ if not mw.isAppleSystem():
+ data = mw.execShell('systemctl ' + method + ' haproxy')
+ if data[1] == '':
+ return 'ok'
+ return 'fail'
+
+ data = mw.execShell(file + ' ' + method)
+ if data[1] == '':
+ return 'ok'
+ return data[1]
+
+
+def start():
+ return haOp('start')
+
+
+def stop():
+ return haOp('stop')
+
+
+def restart():
+ return haOp('restart')
+
+
+def reload():
+ return haOp('reload')
+
+
+def initdStatus():
+ if mw.isAppleSystem():
+ return "Apple Computer does not support"
+
+ shell_cmd = 'systemctl status haproxy | grep loaded | grep "enabled;"'
+ data = mw.execShell(shell_cmd)
+ if data[0] == '':
+ return 'fail'
+ return 'ok'
+
+
+def initdInstall():
+ if mw.isAppleSystem():
+ return "Apple Computer does not support"
+
+ mw.execShell('systemctl enable haproxy')
+ return 'ok'
+
+
+def initdUinstall():
+ if mw.isAppleSystem():
+ return "Apple Computer does not support"
+
+ mw.execShell('systemctl disable haproxy')
+ return 'ok'
+
+
+def runLog():
+ path = getConf()
+ content = mw.readFile(path)
+ rep = 'log\s*=\s*(.*)'
+ tmp = re.search(rep, content)
+ return tmp.groups()[0]
+
+
+def getPort():
+ path = getConf()
+ content = mw.readFile(path)
+ rep = 'listen\s*=\s*(.*)'
+ tmp = re.search(rep, content)
+ return tmp.groups()[0]
+
+
+if __name__ == "__main__":
+ func = sys.argv[1]
+ if func == 'status':
+ print(status())
+ elif func == 'start':
+ print(start())
+ elif func == 'stop':
+ print(stop())
+ elif func == 'restart':
+ print(restart())
+ elif func == 'reload':
+ print(reload())
+ elif func == 'initd_status':
+ print(initdStatus())
+ elif func == 'initd_install':
+ print(initdInstall())
+ elif func == 'initd_uninstall':
+ print(initdUinstall())
+ elif func == 'conf':
+ print(getConf())
+ elif func == 'config_tpl':
+ print(configTpl())
+ elif func == 'read_config_tpl':
+ print(readConfigTpl())
+ elif func == 'run_log':
+ print(runLog())
+ elif func == 'query_log':
+ print(queryLog())
+ else:
+ print('error')
diff --git a/plugins/lvs/info.json b/plugins/lvs/info.json
new file mode 100755
index 000000000..344d389a7
--- /dev/null
+++ b/plugins/lvs/info.json
@@ -0,0 +1,18 @@
+{
+ "sort": 7,
+ "ps": "LVS超强负载均衡",
+ "name": "lvs",
+ "title": "LVS",
+ "shell": "install.sh",
+ "versions":["1.0"],
+ "updates":["1.0"],
+ "tip": "soft",
+ "checks": "server/lvs",
+ "path": "server/lvs",
+ "display": 1,
+ "author": "midoks",
+ "date": "2023-11-17",
+ "home": "http://www.linuxvirtualserver.org/",
+ "type": 0,
+ "pid": "4"
+}
\ No newline at end of file
diff --git a/plugins/lvs/install.sh b/plugins/lvs/install.sh
new file mode 100755
index 000000000..ec4f1ed9e
--- /dev/null
+++ b/plugins/lvs/install.sh
@@ -0,0 +1,47 @@
+#!/bin/bash
+PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
+
+# for mac
+export PATH=$PATH:/opt/homebrew/bin
+
+curPath=`pwd`
+rootPath=$(dirname "$curPath")
+rootPath=$(dirname "$rootPath")
+serverPath=$(dirname "$rootPath")
+install_tmp=${rootPath}/tmp/mw_install.pl
+
+
+action=$1
+type=$2
+
+echo $action $type
+
+
+if [ "${2}" == "" ];then
+ echo '缺少安装脚本...'
+ exit 0
+fi
+
+if [ ! -d $curPath/versions/$2 ];then
+ echo '缺少安装脚本2...'
+ exit 0
+fi
+
+if [ "${action}" == "uninstall" ];then
+
+ if [ -f /usr/lib/systemd/system/haproxy.service ] || [ -f /lib/systemd/system/haproxy.service ];then
+ systemctl stop haproxy
+ systemctl disable haproxy
+ rm -rf /usr/lib/systemd/system/haproxy.service
+ rm -rf /lib/systemd/system/haproxy.service
+ systemctl daemon-reload
+ fi
+fi
+
+sh -x $curPath/versions/$2/install.sh $1
+
+if [ "${action}" == "install" ] && [ -d $serverPath/haproxy ];then
+ #初始化
+ cd ${rootPath} && python3 ${rootPath}/plugins/haproxy/index.py start ${type}
+ cd ${rootPath} && python3 ${rootPath}/plugins/haproxy/index.py initd_install ${type}
+fi
diff --git a/plugins/lvs/js/lvs.js b/plugins/lvs/js/lvs.js
new file mode 100755
index 000000000..8c7d114b5
--- /dev/null
+++ b/plugins/lvs/js/lvs.js
@@ -0,0 +1,53 @@
+function lvsPostMin(method, args, callback){
+
+ var req_data = {};
+ req_data['name'] = 'haproxy';
+ req_data['func'] = method;
+
+ if (typeof(args) != 'undefined' && args!=''){
+ req_data['args'] = JSON.stringify(args);
+ }
+
+ $.post('/plugins/run', req_data, function(data) {
+ if (!data.status){
+ layer.msg(data.msg,{icon:0,time:2000,shade: [0.3, '#000']});
+ return;
+ }
+
+ if(typeof(callback) == 'function'){
+ callback(data);
+ }
+ },'json');
+}
+
+function lvsPost(method, args, callback){
+ var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 });
+ lvsPostMin(method,args,function(data){
+ layer.close(loadT);
+ if(typeof(callback) == 'function'){
+ callback(data);
+ }
+ });
+}
+
+
+function secToTime(s) {
+ var t;
+ if(s > -1){
+ var hour = Math.floor(s/3600);
+ var min = Math.floor(s/60) % 60;
+ var sec = s % 60;
+ if(hour < 10) {
+ t = '0'+ hour + ":";
+ } else {
+ t = hour + ":";
+ }
+
+ if(min < 10){t += "0";}
+ t += min + ":";
+ if(sec < 10){t += "0";}
+ t += sec.toFixed(2);
+ }
+ return t;
+}
+
diff --git a/plugins/lvs/versions/2.6/install.sh b/plugins/lvs/versions/2.6/install.sh
new file mode 100755
index 000000000..2405b6c06
--- /dev/null
+++ b/plugins/lvs/versions/2.6/install.sh
@@ -0,0 +1,70 @@
+#!/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")
+sysName=`uname`
+
+install_tmp=${rootPath}/tmp/mw_install.pl
+
+
+bash ${rootPath}/scripts/getos.sh
+OSNAME=`cat ${rootPath}/data/osname.pl`
+OSNAME_ID=`cat /etc/*-release | grep VERSION_ID | awk -F = '{print $2}' | awk -F "\"" '{print $2}'`
+
+
+VERSION=2.6.4
+MIN_VERSION=2.6
+Install_App()
+{
+
+ echo '正在安装脚本文件...' > $install_tmp
+ mkdir -p $serverPath/haproxy
+
+ APP_DIR=${serverPath}/source/haproxy
+ mkdir -p $APP_DIR
+
+ if [ ! -f ${APP_DIR}/haproxy-${VERSION}.tar.gz ];then
+ if [ $sysName == 'Darwin' ]; then
+ wget --no-check-certificate -O ${APP_DIR}/haproxy-${VERSION}.tar.gz https://www.haproxy.org/download/${MIN_VERSION}/src/haproxy-${VERSION}.tar.gz
+ else
+ curl -sSLo ${APP_DIR}/haproxy-${VERSION}.tar.gz https://www.haproxy.org/download/${MIN_VERSION}/src/haproxy-${VERSION}.tar.gz
+ fi
+ fi
+
+ if [ ! -f ${APP_DIR}/haproxy-${VERSION}.tar.gz ];then
+ curl -sSLo ${APP_DIR}/haproxy-${VERSION}.tar.gz https://www.haproxy.org/download/${MIN_VERSION}/src/haproxy-${VERSION}.tar.gz
+ fi
+
+
+ cd ${APP_DIR} && tar -zxvf haproxy-${VERSION}.tar.gz
+
+ if [ "$OSNAME" == "macos" ];then
+ cd ${APP_DIR}/haproxy-${VERSION} && make TARGET=osx && make install PREFIX=$serverPath/haproxy
+ else
+ cd ${APP_DIR}/haproxy-${VERSION} && make TARGET=linux-glibc && make install PREFIX=$serverPath/haproxy
+ fi
+
+ echo $MIN_VERSION > $serverPath/haproxy/version.pl
+ echo 'Install_HA' > $install_tmp
+}
+
+Uninstall_App()
+{
+ if [ -f $serverPath/haproxy/initd/haproxy ];then
+ $serverPath/haproxy/initd/haproxy stop
+ fi
+
+ rm -rf $serverPath/haproxy
+ echo "Uninstall_HA" > $install_tmp
+}
+
+action=$1
+if [ "${1}" == 'install' ];then
+ Install_App
+else
+ Uninstall_App
+fi
diff --git a/plugins/msonedrive/info.json b/plugins/msonedrive/info.json
index 247e741db..910c196ea 100644
--- a/plugins/msonedrive/info.json
+++ b/plugins/msonedrive/info.json
@@ -10,5 +10,5 @@
"checks": "server/msonedrive",
"author": "midoks",
"date": "2023-8-18",
- "pid": "4"
+ "pid": "5"
}