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" }