Simple Linux Panel
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.
mdserver-web/plugins/l2tp/index.py

234 lines
5.5 KiB

6 years ago
# coding:utf-8
import sys
import io
import os
import time
import shutil
sys.path.append(os.getcwd() + "/class/core")
import mw
6 years ago
app_debug = False
if mw.isAppleSystem():
6 years ago
app_debug = True
def getPluginName():
return 'l2tp'
def getPluginDir():
return mw.getPluginDir() + '/' + getPluginName()
6 years ago
def getServerDir():
return mw.getServerDir() + '/' + getPluginName()
6 years ago
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'))
6 years ago
def status():
cmd = "ps -ef|grep xl2tpd |grep -v grep | grep -v python | awk '{print $2}'"
data = mw.execShell(cmd)
6 years ago
if data[0] == '':
return 'stop'
return 'start'
def initConf():
l2tp_cs = getServerDir() + '/chap-secrets'
if not os.path.exists(l2tp_cs):
mw.execShell('cp -rf ' + getPluginDir() +
'/tmp/chap-secrets' + ' ' + getServerDir())
6 years ago
l2tp_is = getServerDir() + '/ipsec.secrets'
if not os.path.exists(l2tp_is):
mw.execShell('cp -rf ' + getPluginDir() +
'/tmp/ipsec.secrets' + ' ' + getServerDir())
6 years ago
def start():
initConf()
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
data = mw.execShell('service xl2tpd start')
6 years ago
if data[0] == '':
return 'ok'
return data[1]
def stop():
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
data = mw.execShell('service xl2tpd stop')
6 years ago
if data[0] == '':
return 'ok'
return data[1]
def restart():
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
data = mw.execShell('service xl2tpd restart')
6 years ago
if data[0] == '':
return 'ok'
return data[1]
def reload():
data = mw.execShell('service xl2tpd reload')
6 years ago
if data[0] == '':
return 'ok'
return data[1]
def getPathFile():
if mw.isAppleSystem():
6 years ago
return getServerDir() + '/chap-secrets'
return '/etc/ppp/chap-secrets'
def getPathFilePsk():
if mw.isAppleSystem():
6 years ago
return getServerDir() + '/ipsec.secrets'
return '/etc/ipsec.secrets'
def getUserList():
import re
path = getPathFile()
if not os.path.exists(path):
return mw.returnJson(False, '密码配置文件不存在!')
conf = mw.readFile(path)
6 years ago
conf = re.sub('#(.*)\n', '', conf)
if conf.strip() == '':
return mw.returnJson(True, 'ok', [])
6 years ago
ulist = conf.strip().split('\n')
user = []
for line in ulist:
line_info = {}
line = re.match(r'(\w*)\s*(\w*)\s*(\w*)\s*(.*)',
line.strip(), re.M | re.I).groups()
line_info['user'] = line[0]
line_info['pwd'] = line[2]
line_info['type'] = line[1]
line_info['ip'] = line[3]
user.append(line_info)
return mw.returnJson(True, 'ok', user)
6 years ago
def addUser():
if mw.isAppleSystem():
return mw.returnJson(False, "Apple Computer does not support")
6 years ago
args = getArgs()
data = checkArgs(args, ['username'])
if not data[0]:
return data[1]
ret = mw.execShell('echo ' + args['username'] + '|l2tp -a')
6 years ago
if ret[1] == '':
return mw.returnJson(True, '添加成功!:' + ret[0])
return mw.returnJson(False, '添加失败:' + ret[0])
6 years ago
def delUser():
if mw.isAppleSystem():
return mw.returnJson(False, "Apple Computer does not support")
6 years ago
args = getArgs()
data = checkArgs(args, ['username'])
if not data[0]:
return data[1]
ret = mw.execShell('echo ' + args['username'] + '|l2tp -d')
6 years ago
if ret[1] == '':
return mw.returnJson(True, '删除成功!:' + ret[0])
return mw.returnJson(False, '删除失败:' + ret[0])
6 years ago
def modUser():
args = getArgs()
data = checkArgs(args, ['username', 'password'])
if not data[0]:
return data[1]
path = getPathFile()
username = args['username']
password = args['password']
# sed -i "/^\<${user}\>/d" /etc/ppp/chap-secrets
# echo "${user} l2tpd ${pass} *" >> /etc/ppp/chap-secrets
if mw.isAppleSystem():
mw.execShell("sed -i .bak '/^\(" + username + "\)/d' " + path)
6 years ago
else:
mw.execShell("sed -i '/^\(" + username + "\)/d' " + path)
6 years ago
# print 'echo "' + username + " l2tpd " + password + " *\" >>"
# + path
ret = mw.execShell("echo \"" + username +
" l2tpd " + password + " *\" >>" + path)
6 years ago
if ret[1] == '':
return mw.returnJson(True, '修改成功!')
return mw.returnJson(False, '修改失败')
6 years ago
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 == 'conf':
print getPathFile()
elif func == 'conf_psk':
print getPathFilePsk()
elif func == 'user_list':
print getUserList()
elif func == 'add_user':
print addUser()
elif func == 'del_user':
print delUser()
elif func == 'mod_user':
print modUser()
else:
print 'error'