mirror of https://github.com/midoks/mdserver-web
pull/109/head
parent
35204badf8
commit
59dfad1ca2
After Width: | Height: | Size: 344 B |
@ -0,0 +1,17 @@ |
|||||||
|
<div class="bt-form"> |
||||||
|
<div class="bt-w-main"> |
||||||
|
<div class="bt-w-menu"> |
||||||
|
<p class="bgw" onclick="orPluginService('op_firewall');">服务</p> |
||||||
|
<p onclick="pluginInitD('op_firewall');">自启动</p> |
||||||
|
<p onclick="pluginConfig('op_firewall');">配置修改</p> |
||||||
|
<!-- <p onclick="pluginLogs('op_firewall');">错误日志</p> --> |
||||||
|
</div> |
||||||
|
<div class="bt-w-con pd15"> |
||||||
|
<div class="soft-man-con"></div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
</div> |
||||||
|
<script type="text/javascript"> |
||||||
|
$.getScript( "/plugins/file?name=openrop_firewallesty&f=js/op_firewall.js"); |
||||||
|
</script> |
@ -0,0 +1,299 @@ |
|||||||
|
# coding:utf-8 |
||||||
|
|
||||||
|
import sys |
||||||
|
import io |
||||||
|
import os |
||||||
|
import time |
||||||
|
import subprocess |
||||||
|
|
||||||
|
sys.path.append(os.getcwd() + "/class/core") |
||||||
|
import public |
||||||
|
|
||||||
|
|
||||||
|
app_debug = False |
||||||
|
|
||||||
|
if public.isAppleSystem(): |
||||||
|
app_debug = True |
||||||
|
|
||||||
|
|
||||||
|
def getPluginName(): |
||||||
|
return 'op_firewall' |
||||||
|
|
||||||
|
|
||||||
|
def getPluginDir(): |
||||||
|
return public.getPluginDir() + '/' + getPluginName() |
||||||
|
|
||||||
|
|
||||||
|
def getServerDir(): |
||||||
|
return public.getServerDir() + '/' + getPluginName() |
||||||
|
|
||||||
|
|
||||||
|
def getInitDFile(): |
||||||
|
if app_debug: |
||||||
|
return '/tmp/' + getPluginName() |
||||||
|
return '/etc/init.d/' + getPluginName() |
||||||
|
|
||||||
|
|
||||||
|
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 clearTemp(): |
||||||
|
path_bin = getServerDir() + "/nginx" |
||||||
|
public.execShell('rm -rf ' + path_bin + '/client_body_temp') |
||||||
|
public.execShell('rm -rf ' + path_bin + '/fastcgi_temp') |
||||||
|
public.execShell('rm -rf ' + path_bin + '/proxy_temp') |
||||||
|
public.execShell('rm -rf ' + path_bin + '/scgi_temp') |
||||||
|
public.execShell('rm -rf ' + path_bin + '/uwsgi_temp') |
||||||
|
|
||||||
|
|
||||||
|
def getConf(): |
||||||
|
path = getServerDir() + "/nginx/conf/nginx.conf" |
||||||
|
return path |
||||||
|
|
||||||
|
|
||||||
|
def getConfTpl(): |
||||||
|
path = getPluginDir() + '/conf/nginx.conf' |
||||||
|
return path |
||||||
|
|
||||||
|
|
||||||
|
def getOs(): |
||||||
|
data = {} |
||||||
|
data['os'] = public.getOs() |
||||||
|
ng_exe_bin = getServerDir() + "/nginx/sbin/nginx" |
||||||
|
if checkAuthEq(ng_exe_bin, 'root'): |
||||||
|
data['auth'] = True |
||||||
|
else: |
||||||
|
data['auth'] = False |
||||||
|
return public.getJson(data) |
||||||
|
|
||||||
|
|
||||||
|
def getInitDTpl(): |
||||||
|
path = getPluginDir() + "/init.d/nginx.tpl" |
||||||
|
return path |
||||||
|
|
||||||
|
|
||||||
|
def makeConf(): |
||||||
|
vhost = getServerDir() + '/nginx/conf/vhost' |
||||||
|
if not os.path.exists(vhost): |
||||||
|
os.mkdir(vhost) |
||||||
|
php_status = getServerDir() + '/nginx/conf/php_status' |
||||||
|
if not os.path.exists(php_status): |
||||||
|
os.mkdir(php_status) |
||||||
|
|
||||||
|
|
||||||
|
def getFileOwner(filename): |
||||||
|
import pwd |
||||||
|
stat = os.lstat(filename) |
||||||
|
uid = stat.st_uid |
||||||
|
pw = pwd.getpwuid(uid) |
||||||
|
return pw.pw_name |
||||||
|
|
||||||
|
|
||||||
|
def checkAuthEq(file, owner='root'): |
||||||
|
fowner = getFileOwner(file) |
||||||
|
if (fowner == owner): |
||||||
|
return True |
||||||
|
return False |
||||||
|
|
||||||
|
|
||||||
|
def confReplace(): |
||||||
|
service_path = os.path.dirname(os.getcwd()) |
||||||
|
content = public.readFile(getConfTpl()) |
||||||
|
content = content.replace('{$SERVER_PATH}', service_path) |
||||||
|
|
||||||
|
user = 'www' |
||||||
|
user_group = 'www' |
||||||
|
|
||||||
|
if public.getOs() == 'darwin': |
||||||
|
# macosx do |
||||||
|
user = public.execShell( |
||||||
|
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip() |
||||||
|
# user = 'root' |
||||||
|
user_group = 'staff' |
||||||
|
content = content.replace('{$EVENT_MODEL}', 'kqueue') |
||||||
|
else: |
||||||
|
content = content.replace('{$EVENT_MODEL}', 'epoll') |
||||||
|
|
||||||
|
content = content.replace('{$OS_USER}', user) |
||||||
|
content = content.replace('{$OS_USER_GROUP}', user_group) |
||||||
|
|
||||||
|
public.writeFile(getServerDir() + '/nginx/conf/nginx.conf', content) |
||||||
|
|
||||||
|
# give nginx root permission |
||||||
|
ng_exe_bin = getServerDir() + "/nginx/sbin/nginx" |
||||||
|
if not checkAuthEq(ng_exe_bin, 'root'): |
||||||
|
args = getArgs() |
||||||
|
sudoPwd = args['pwd'] |
||||||
|
cmd_own = 'chown -R ' + 'root:' + user_group + ' ' + ng_exe_bin |
||||||
|
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_own)) |
||||||
|
cmd_mod = 'chmod 755 ' + ng_exe_bin |
||||||
|
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_mod)) |
||||||
|
cmd_s = 'chmod u+s ' + ng_exe_bin |
||||||
|
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_s)) |
||||||
|
|
||||||
|
|
||||||
|
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 |
||||||
|
content = public.readFile(file_tpl) |
||||||
|
content = content.replace('{$SERVER_PATH}', service_path) |
||||||
|
public.writeFile(file_bin, content) |
||||||
|
public.execShell('chmod +x ' + file_bin) |
||||||
|
|
||||||
|
# config replace |
||||||
|
confReplace() |
||||||
|
|
||||||
|
# make nginx vhost or other |
||||||
|
makeConf() |
||||||
|
|
||||||
|
return file_bin |
||||||
|
|
||||||
|
|
||||||
|
def status(): |
||||||
|
data = public.execShell( |
||||||
|
"ps -ef|grep nginx |grep -v grep | grep -v python | awk '{print $2}'") |
||||||
|
if data[0] == '': |
||||||
|
return 'stop' |
||||||
|
return 'start' |
||||||
|
|
||||||
|
|
||||||
|
def start(): |
||||||
|
file = initDreplace() |
||||||
|
data = public.execShell(file + ' start') |
||||||
|
if data[1] == '': |
||||||
|
return 'ok' |
||||||
|
return data[1] |
||||||
|
|
||||||
|
|
||||||
|
def stop(): |
||||||
|
file = initDreplace() |
||||||
|
data = public.execShell(file + ' stop') |
||||||
|
clearTemp() |
||||||
|
if data[1] == '': |
||||||
|
return 'ok' |
||||||
|
return data[1] |
||||||
|
|
||||||
|
|
||||||
|
def restart(): |
||||||
|
file = initDreplace() |
||||||
|
data = public.execShell(file + ' restart') |
||||||
|
if data[1] == '': |
||||||
|
return 'ok' |
||||||
|
return data[1] |
||||||
|
|
||||||
|
|
||||||
|
def reload(): |
||||||
|
file = initDreplace() |
||||||
|
data = public.execShell(file + ' reload') |
||||||
|
if data[1] == '': |
||||||
|
return 'ok' |
||||||
|
return data[1] |
||||||
|
|
||||||
|
|
||||||
|
def initdStatus(): |
||||||
|
if not app_debug: |
||||||
|
if public.isAppleSystem(): |
||||||
|
return "Apple Computer does not support" |
||||||
|
initd_bin = getInitDFile() |
||||||
|
if os.path.exists(initd_bin): |
||||||
|
return 'ok' |
||||||
|
return 'fail' |
||||||
|
|
||||||
|
|
||||||
|
def initdInstall(): |
||||||
|
import shutil |
||||||
|
if not app_debug: |
||||||
|
if public.isAppleSystem(): |
||||||
|
return "Apple Computer does not support" |
||||||
|
|
||||||
|
source_bin = initDreplace() |
||||||
|
initd_bin = getInitDFile() |
||||||
|
shutil.copyfile(source_bin, initd_bin) |
||||||
|
public.execShell('chmod +x ' + initd_bin) |
||||||
|
public.execShell('chkconfig --add ' + getPluginName()) |
||||||
|
return 'ok' |
||||||
|
|
||||||
|
|
||||||
|
def initdUinstall(): |
||||||
|
if not app_debug: |
||||||
|
if public.isAppleSystem(): |
||||||
|
return "Apple Computer does not support" |
||||||
|
|
||||||
|
public.execShell('chkconfig --del ' + getPluginName()) |
||||||
|
initd_bin = getInitDFile() |
||||||
|
os.remove(initd_bin) |
||||||
|
return 'ok' |
||||||
|
|
||||||
|
|
||||||
|
def runInfo(): |
||||||
|
# 取Openresty负载状态 |
||||||
|
try: |
||||||
|
result = public.httpGet('http://127.0.0.1/nginx_status') |
||||||
|
tmp = result.split() |
||||||
|
data = {} |
||||||
|
data['active'] = tmp[2] |
||||||
|
data['accepts'] = tmp[9] |
||||||
|
data['handled'] = tmp[7] |
||||||
|
data['requests'] = tmp[8] |
||||||
|
data['Reading'] = tmp[11] |
||||||
|
data['Writing'] = tmp[13] |
||||||
|
data['Waiting'] = tmp[15] |
||||||
|
return public.getJson(data) |
||||||
|
except Exception as e: |
||||||
|
return 'oprenresty not started' |
||||||
|
|
||||||
|
|
||||||
|
def errorLogPath(): |
||||||
|
return getServerDir() + '/nginx/logs/error.log' |
||||||
|
|
||||||
|
|
||||||
|
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 == 'get_os': |
||||||
|
print getOs() |
||||||
|
elif func == 'run_info': |
||||||
|
print runInfo() |
||||||
|
elif func == 'error_log': |
||||||
|
print errorLogPath() |
||||||
|
else: |
||||||
|
print 'error' |
@ -0,0 +1,15 @@ |
|||||||
|
{ |
||||||
|
"title":"OP防火墙[dev]", |
||||||
|
"tip":"soft", |
||||||
|
"name":"op_firewall", |
||||||
|
"type":"其他插件", |
||||||
|
"ps":"有效防止sql注入/xss/一句话木马等常见渗透攻击", |
||||||
|
"shell":"install.sh", |
||||||
|
"checks":"server/op_firewall", |
||||||
|
"path":"server/op_firewall", |
||||||
|
"author":"loveshell", |
||||||
|
"home":"https://github.com/loveshell/ngx_lua_waf", |
||||||
|
"date":"2019-04-21", |
||||||
|
"pid": "1", |
||||||
|
"versions": ["0.1"] |
||||||
|
} |
@ -0,0 +1,32 @@ |
|||||||
|
#!/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") |
||||||
|
|
||||||
|
|
||||||
|
action=$1 |
||||||
|
type=$2 |
||||||
|
|
||||||
|
if id www &> /dev/null ;then |
||||||
|
echo "www UID is `id -u www`" |
||||||
|
echo "www Shell is `grep "^www:" /etc/passwd |cut -d':' -f7 `" |
||||||
|
else |
||||||
|
groupadd www |
||||||
|
useradd -g www -s /sbin/nologin www |
||||||
|
fi |
||||||
|
|
||||||
|
if [ "${2}" == "" ];then |
||||||
|
echo '缺少安装脚本...' > $install_tmp |
||||||
|
exit 0 |
||||||
|
fi |
||||||
|
|
||||||
|
if [ ! -d $curPath/versions/$2 ];then |
||||||
|
echo '缺少安装脚本2...' > $install_tmp |
||||||
|
exit 0 |
||||||
|
fi |
||||||
|
|
||||||
|
sh -x $curPath/versions/$2/install.sh $1 |
Loading…
Reference in new issue