mirror of https://github.com/midoks/mdserver-web
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
363 lines
10 KiB
363 lines
10 KiB
# coding:utf-8
|
|
|
|
import sys
|
|
import io
|
|
import os
|
|
import time
|
|
import re
|
|
import socket
|
|
import json
|
|
|
|
from datetime import datetime
|
|
|
|
sys.path.append(os.getcwd() + "/class/core")
|
|
import mw
|
|
|
|
app_debug = False
|
|
if mw.isAppleSystem():
|
|
app_debug = True
|
|
|
|
|
|
class App:
|
|
__setupPath = '/www/server/nezha'
|
|
__cfg = ''
|
|
__agent_cfg = ''
|
|
|
|
def __init__(self):
|
|
self.__setupPath = self.getServerDir()
|
|
self.__cfg = self.__setupPath + '/nezha.cfg'
|
|
self.__agent_cfg = self.__setupPath + '/agent.cfg'
|
|
|
|
def getArgs(self):
|
|
args = sys.argv[3:]
|
|
tmp = {}
|
|
args_len = len(args)
|
|
|
|
if args_len == 1:
|
|
t = args[0].strip('{').strip('}')
|
|
t = t.split(':', 1)
|
|
tmp[t[0]] = t[1]
|
|
elif args_len > 1:
|
|
for i in range(len(args)):
|
|
t = args[i].split(':', 1)
|
|
tmp[t[0]] = t[1]
|
|
|
|
return tmp
|
|
|
|
def checkArgs(self, 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 __release_port(self, port):
|
|
from collections import namedtuple
|
|
try:
|
|
import firewall_api
|
|
firewall_api.firewall_api().addAcceptPortArgs(port, 'nezha', 'port')
|
|
return port
|
|
except Exception as e:
|
|
return "Release failed {}".format(e)
|
|
|
|
def openPort(self):
|
|
for i in ["9527", "5555"]:
|
|
self.__release_port(i)
|
|
return True
|
|
|
|
def getPluginName(self):
|
|
return 'nezha'
|
|
|
|
def getPluginDir(self):
|
|
return mw.getPluginDir() + '/' + self.getPluginName()
|
|
|
|
def getServerDir(self):
|
|
return mw.getServerDir() + '/' + self.getPluginName()
|
|
|
|
def getInitdConfTpl(self):
|
|
path = self.getPluginDir() + "/init.d/nezha.tpl"
|
|
return path
|
|
|
|
def getInitdAgentConfTpl(self):
|
|
path = self.getPluginDir() + "/init.d/nezha-agent.tpl"
|
|
return path
|
|
|
|
def getHomeDir(self):
|
|
if mw.isAppleSystem():
|
|
user = mw.execShell(
|
|
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
|
|
return '/Users/' + user
|
|
else:
|
|
return '/root'
|
|
|
|
def getRunUser(self):
|
|
if mw.isAppleSystem():
|
|
user = mw.execShell(
|
|
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
|
|
return user
|
|
else:
|
|
return 'root'
|
|
|
|
def status(self):
|
|
cmd = "ps -ef|grep " + self.getPluginName() + \
|
|
" |grep -v grep | grep -v nezha-agent | grep -v python | awk '{print $2}'"
|
|
data = mw.execShell(cmd)
|
|
if data[0] == '':
|
|
return 'stop'
|
|
return 'start'
|
|
|
|
def status_agent(self):
|
|
cmd = "ps -ef | grep nezha-agent | grep -v grep | grep -v python | awk '{print $2}'"
|
|
data = mw.execShell(cmd)
|
|
if data[0] == '':
|
|
return 'stop'
|
|
return 'start'
|
|
|
|
def contentReplace(self, content):
|
|
|
|
service_path = mw.getServerDir()
|
|
content = content.replace('{$ROOT_PATH}', mw.getRootDir())
|
|
content = content.replace('{$SERVER_PATH}', service_path)
|
|
content = content.replace('{$RUN_USER}', self.getRunUser())
|
|
content = content.replace('{$HOME_DIR}', self.getHomeDir())
|
|
|
|
return content
|
|
|
|
def initDreplace(self):
|
|
|
|
file_tpl = self.getInitdConfTpl()
|
|
service_path = mw.getServerDir()
|
|
|
|
initD_path = self.getServerDir() + '/init.d'
|
|
if not os.path.exists(initD_path):
|
|
os.mkdir(initD_path)
|
|
self.openPort()
|
|
|
|
file_bin = initD_path + '/' + self.getPluginName()
|
|
|
|
if not os.path.exists(file_bin):
|
|
content = mw.readFile(file_tpl)
|
|
content = self.contentReplace(content)
|
|
mw.writeFile(file_bin, content)
|
|
mw.execShell('chmod +x ' + file_bin)
|
|
|
|
# systemd
|
|
systemDir = mw.systemdCfgDir()
|
|
systemService = systemDir + '/nezha.service'
|
|
systemServiceTpl = self.getPluginDir() + '/init.d/nezha.service.tpl'
|
|
if os.path.exists(systemDir) and not os.path.exists(systemService):
|
|
service_path = mw.getServerDir()
|
|
se_content = mw.readFile(systemServiceTpl)
|
|
se_content = self.contentReplace(se_content)
|
|
mw.writeFile(systemService, se_content)
|
|
mw.execShell('systemctl daemon-reload')
|
|
|
|
return file_bin
|
|
|
|
def contentAgentReplace(self, content):
|
|
path = self.__agent_cfg
|
|
if os.path.exists(path):
|
|
data = self.get_agent_cfg()
|
|
content = content.replace('{$APP_HOST}', data['host'])
|
|
content = content.replace('{$APP_SECRET}', data['secret'])
|
|
|
|
return content
|
|
|
|
def initDAgent(self):
|
|
file_tpl = self.getInitdAgentConfTpl()
|
|
|
|
initD_path = self.getServerDir() + '/init.d'
|
|
if not os.path.exists(initD_path):
|
|
os.mkdir(initD_path)
|
|
|
|
file_agent_bin = initD_path + '/nezha-agent'
|
|
|
|
content = mw.readFile(file_tpl)
|
|
content = self.contentReplace(content)
|
|
content = self.contentAgentReplace(content)
|
|
mw.writeFile(file_agent_bin, content)
|
|
mw.execShell('chmod +x ' + file_agent_bin)
|
|
|
|
# systemd
|
|
sysDir = mw.systemdCfgDir()
|
|
sysService = sysDir + '/nezha-agent.service'
|
|
sysServiceTpl = self.getPluginDir() + '/init.d/nezha-agent.service.tpl'
|
|
service_path = mw.getServerDir()
|
|
content = mw.readFile(sysServiceTpl)
|
|
content = self.contentReplace(content)
|
|
content = self.contentAgentReplace(content)
|
|
mw.writeFile(sysService, content)
|
|
mw.execShell('systemctl daemon-reload')
|
|
|
|
return file_agent_bin
|
|
|
|
def init_cfg(self):
|
|
self.initDreplace()
|
|
self.initDAgent()
|
|
|
|
def imOp(self, method):
|
|
|
|
file = self.initDreplace()
|
|
|
|
if not mw.isAppleSystem():
|
|
cmd = 'systemctl {} {}'.format(method, self.getPluginName())
|
|
data = mw.execShell(cmd)
|
|
if data[1] == '':
|
|
return 'ok'
|
|
return 'fail'
|
|
|
|
data = mw.execShell(file + ' ' + method)
|
|
if data[1] == '':
|
|
return 'ok'
|
|
return data[0]
|
|
|
|
def start(self):
|
|
return self.imOp('start')
|
|
|
|
def stop(self):
|
|
return self.imOp('stop')
|
|
|
|
def restart(self):
|
|
return self.imOp('restart')
|
|
|
|
def reload(self):
|
|
return self.imOp('reload')
|
|
|
|
def agOp(self, method):
|
|
file = self.initDAgent()
|
|
|
|
path = self.__agent_cfg
|
|
if not os.path.exists(path):
|
|
return '请先设置Agent配置!'
|
|
|
|
if not mw.isAppleSystem():
|
|
cmd = 'systemctl {} {}'.format(method, 'nezha-agent')
|
|
data = mw.execShell(cmd)
|
|
if data[1] == '':
|
|
return 'ok'
|
|
return 'fail'
|
|
|
|
data = mw.execShell(file + ' ' + method)
|
|
if data[1] == '':
|
|
return 'ok'
|
|
return data[0]
|
|
|
|
def start_agent(self):
|
|
return self.agOp('start')
|
|
|
|
def stop_agent(self):
|
|
return self.agOp('stop')
|
|
|
|
def restart_agent(self):
|
|
return self.agOp('restart')
|
|
|
|
def reload_agent(self):
|
|
return self.agentOp('reload')
|
|
|
|
def initd_status(self):
|
|
cmd = 'systemctl status nezha | grep loaded | grep "enabled;"'
|
|
data = mw.execShell(cmd)
|
|
if data[0] == '':
|
|
return 'fail'
|
|
return 'ok'
|
|
|
|
def initd_install(self):
|
|
mw.execShell('systemctl enable nezha')
|
|
return 'ok'
|
|
|
|
def initd_uninstall(self):
|
|
mw.execShell('systemctl disable nezha')
|
|
return 'ok'
|
|
|
|
def initd_status_agent(self):
|
|
cmd = 'systemctl status nezha-agent | grep loaded | grep "enabled;"'
|
|
data = mw.execShell(cmd)
|
|
if data[0] == '':
|
|
return 'fail'
|
|
return 'ok'
|
|
|
|
def initd_install_agent(self):
|
|
mw.execShell('systemctl enable nezha-agent')
|
|
return 'ok'
|
|
|
|
def initd_uninstall_agent(self):
|
|
mw.execShell('systemctl disable nezha-agent')
|
|
return 'ok'
|
|
|
|
def conf(self):
|
|
return self.getServerDir() + '/dashboard/data/config.yaml'
|
|
|
|
def nezha_cfg(self):
|
|
path = self.__cfg
|
|
if not os.path.exists(path):
|
|
d = {}
|
|
cmd_un = 'cd ' + self.getServerDir() + '/dashboard && ./nezha conf -u ""'
|
|
td = mw.execShell(cmd_un)
|
|
d['username'] = td[0].strip()
|
|
|
|
pwd = mw.getRandomString(16)
|
|
cmd_pwd = 'cd ' + self.getServerDir() + '/dashboard && ./nezha conf -u "" -p ' + pwd
|
|
td = mw.execShell(cmd_pwd)
|
|
d['password'] = pwd
|
|
|
|
mw.writeFile(path, mw.enDoubleCrypt('nezha', mw.getJson(d)))
|
|
|
|
info = mw.readFile(path)
|
|
info = mw.deDoubleCrypt('nezha', info)
|
|
|
|
info = json.loads(info)
|
|
return mw.returnJson(True, 'ok', info)
|
|
|
|
def nezha_save_cfg(self):
|
|
args = self.getArgs()
|
|
data = self.checkArgs(args, ['username', 'password'])
|
|
if not data[0]:
|
|
return data[1]
|
|
path = self.__cfg
|
|
|
|
cmd = 'cd ' + self.getServerDir() + '/dashboard && ./nezha conf -su "' + \
|
|
args['username'] + '" -p ' + args['password']
|
|
# print(cmd)
|
|
t = mw.execShell(cmd)
|
|
# print(t)
|
|
mw.writeFile(path, mw.enDoubleCrypt('nezha', mw.getJson(args)))
|
|
return mw.returnJson(True, '修改成功!')
|
|
|
|
def get_agent_cfg(self):
|
|
path = self.__agent_cfg
|
|
info = mw.readFile(path)
|
|
info = mw.deDoubleCrypt('agent', info)
|
|
info = json.loads(info)
|
|
return info
|
|
|
|
def agent_cfg(self):
|
|
path = self.__agent_cfg
|
|
if not os.path.exists(path):
|
|
d = {}
|
|
d['host'] = '127.0.0.1:5555'
|
|
d['secret'] = 'secret'
|
|
mw.writeFile(path, mw.enDoubleCrypt('agent', mw.getJson(d)))
|
|
|
|
info = self.get_agent_cfg()
|
|
return mw.returnJson(True, 'ok', info)
|
|
|
|
def agent_save_cfg(self):
|
|
args = self.getArgs()
|
|
data = self.checkArgs(args, ['host', 'secret'])
|
|
if not data[0]:
|
|
return data[1]
|
|
path = self.__agent_cfg
|
|
mw.writeFile(path, mw.enDoubleCrypt('agent', mw.getJson(args)))
|
|
return mw.returnJson(True, '修改成功!')
|
|
|
|
def run_log(self):
|
|
return self.getServerDir() + '/logs/nezha.log'
|
|
|
|
|
|
if __name__ == "__main__":
|
|
func = sys.argv[1]
|
|
classApp = App()
|
|
try:
|
|
data = eval("classApp." + func + "()")
|
|
print(data)
|
|
except Exception as e:
|
|
print('error:' + str(e))
|
|
|