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/gogs/index.py

687 lines
18 KiB

7 years ago
# coding: utf-8
import time
import os
import sys
6 years ago
import re
6 years ago
7 years ago
sys.path.append("/usr/local/lib/python2.7/site-packages")
import psutil
6 years ago
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 'gogs'
def getPluginDir():
return mw.getPluginDir() + '/' + getPluginName()
6 years ago
6 years ago
sys.path.append(getPluginDir() + "/class")
4 years ago
import mysqlDb
6 years ago
6 years ago
def getServerDir():
return mw.getServerDir() + '/' + getPluginName()
6 years ago
def getInitDFile():
if app_debug:
return '/tmp/' + getPluginName()
return '/etc/init.d/' + getPluginName()
def getArgs():
args = sys.argv[2:]
tmp = {}
6 years ago
args_len = len(args)
if args_len == 1:
t = args[0].strip('{').strip('}')
6 years ago
t = t.split(':', 1)
6 years ago
tmp[t[0]] = t[1]
6 years ago
elif args_len > 1:
for i in range(len(args)):
6 years ago
t = args[i].split(':', 1)
6 years ago
tmp[t[0]] = t[1]
6 years ago
return tmp
6 years ago
def getInitdConfTpl():
6 years ago
path = getPluginDir() + "/init.d/gogs.tpl"
return path
6 years ago
def getInitdConf():
path = getServerDir() + "/init.d/gogs"
return path
6 years ago
def getConf():
path = getServerDir() + "/custom/conf/app.ini"
return path
6 years ago
def getConfTpl():
path = getPluginDir() + "/conf/app.ini"
return path
6 years ago
def status():
data = mw.execShell(
6 years ago
"ps -ef|grep " + getPluginName() + " |grep -v grep | grep -v python | awk '{print $2}'")
if data[0] == '':
return 'stop'
return 'start'
6 years ago
def getHomeDir():
if mw.isAppleSystem():
user = mw.execShell(
6 years ago
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
6 years ago
return '/Users/' + user
6 years ago
else:
6 years ago
return '/root'
6 years ago
def getRunUser():
if mw.isAppleSystem():
user = mw.execShell(
6 years ago
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
return user
else:
6 years ago
return 'root'
6 years ago
__SR = '''#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
export USER=%s
export HOME=%s && ''' % ( getRunUser(), getHomeDir())
def contentReplace(content):
6 years ago
service_path = mw.getServerDir()
content = content.replace('{$ROOT_PATH}', mw.getRootDir())
6 years ago
content = content.replace('{$SERVER_PATH}', service_path)
6 years ago
content = content.replace('{$RUN_USER}', getRunUser())
content = content.replace('{$HOME_DIR}', getHomeDir())
6 years ago
return content
6 years ago
def initDreplace():
6 years ago
file_tpl = getInitdConfTpl()
service_path = mw.getServerDir()
6 years ago
initD_path = getServerDir() + '/init.d'
if not os.path.exists(initD_path):
os.mkdir(initD_path)
6 years ago
file_bin = initD_path + '/' + getPluginName()
6 years ago
6 years ago
if not os.path.exists(file_bin):
content = mw.readFile(file_tpl)
6 years ago
content = contentReplace(content)
mw.writeFile(file_bin, content)
mw.execShell('chmod +x ' + file_bin)
6 years ago
conf_bin = getConf()
6 years ago
if not os.path.exists(conf_bin):
mw.execShell('mkdir -p ' + getServerDir() + '/custom/conf')
6 years ago
conf_tpl = getConfTpl()
content = mw.readFile(conf_tpl)
6 years ago
content = contentReplace(content)
mw.writeFile(conf_bin, content)
6 years ago
log_path = getServerDir() + '/log'
if not os.path.exists(log_path):
os.mkdir(log_path)
6 years ago
return file_bin
6 years ago
def getRootUrl():
content = mw.readFile(getConf())
6 years ago
rep = 'ROOT_URL\s*=\s*(.*)'
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
def getSshPort():
content = mw.readFile(getConf())
rep = 'SSH_PORT\s*=\s*(.*)'
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
6 years ago
def getRootPath():
content = mw.readFile(getConf())
6 years ago
rep = 'ROOT\s*=\s*(.*)'
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
6 years ago
def getDbConfValue():
content = mw.readFile(getConf())
6 years ago
rep_scope = "\[database\](.*?)\["
tmp = re.findall(rep_scope, content, re.S)
rep = '(\w*)\s*=\s*(.*)'
tmp = re.findall(rep, tmp[0])
r = {}
for x in range(len(tmp)):
k = tmp[x][0]
v = tmp[x][1]
r[k] = v
return r
def pMysqlDb():
conf = getDbConfValue()
host = conf['HOST'].split(':')
4 years ago
conn = mysqlDb.mysqlDb()
6 years ago
conn.setHost(host[0])
conn.setUser(conf['USER'])
conn.setPwd(conf['PASSWD'])
conn.setPort(int(host[1]))
conn.setDb(conf['NAME'])
return conn
def isSqlError(mysqlMsg):
# 检测数据库执行错误
_mysqlMsg = str(mysqlMsg)
# print _mysqlMsg
if "MySQLdb" in _mysqlMsg:
return mw.returnData(False, 'MySQLdb组件缺失! <br>进入SSH命令行输入: pip install mysql-python')
6 years ago
if "2002," in _mysqlMsg:
return mw.returnData(False, '数据库连接失败,请检查数据库服务是否启动!')
6 years ago
if "using password:" in _mysqlMsg:
return mw.returnData(False, '数据库管理密码错误!')
6 years ago
if "Connection refused" in _mysqlMsg:
return mw.returnData(False, '数据库连接失败,请检查数据库服务是否启动!')
6 years ago
if "1133," in _mysqlMsg:
return mw.returnData(False, '数据库用户不存在!')
6 years ago
if "1007," in _mysqlMsg:
return mw.returnData(False, '数据库已经存在!')
6 years ago
if "1044," in _mysqlMsg:
return mw.returnData(False, mysqlMsg[1])
6 years ago
if "2003," in _mysqlMsg:
return mw.returnData(False, mysqlMsg[1])
return mw.returnData(True, 'OK')
6 years ago
6 years ago
def start():
6 years ago
is_frist = True
conf_bin = getConf()
if os.path.exists(conf_bin):
is_frist = False
6 years ago
file = initDreplace()
6 years ago
if is_frist:
return "第一次启动Gogs,默认使用MySQL连接!<br>可以在配置文件中重新设置,再启动!"
conn = pMysqlDb()
list_table = conn.query('show tables')
data = isSqlError(list_table)
if not data['status']:
return data['msg']
data = mw.execShell(__SR + file + ' start')
6 years ago
if data[1] == '':
return 'ok'
6 years ago
return data[0]
6 years ago
def stop():
file = initDreplace()
data = mw.execShell(__SR + file + ' stop')
6 years ago
if data[1] == '':
return 'ok'
6 years ago
return data[1]
6 years ago
def restart():
file = initDreplace()
data = mw.execShell(__SR + file + ' restart')
6 years ago
if data[1] == '':
return 'ok'
6 years ago
return data[1]
6 years ago
def reload():
file = initDreplace()
data = mw.execShell(__SR + file + ' reload')
6 years ago
if data[1] == '':
return 'ok'
6 years ago
return data[1]
6 years ago
def initdStatus():
if not app_debug:
os_name = mw.getOs()
6 years ago
if os_name == 'darwin':
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:
os_name = mw.getOs()
6 years ago
if os_name == 'darwin':
return "Apple Computer does not support"
mem_bin = initDreplace()
initd_bin = getInitDFile()
shutil.copyfile(mem_bin, initd_bin)
mw.execShell('chmod +x ' + initd_bin)
mw.execShell('chkconfig --add ' + getPluginName())
6 years ago
return 'ok'
def initdUinstall():
if not app_debug:
os_name = mw.getOs()
6 years ago
if os_name == 'darwin':
return "Apple Computer does not support"
initd_bin = getInitDFile()
os.remove(initd_bin)
mw.execShell('chkconfig --del ' + getPluginName())
6 years ago
return 'ok'
6 years ago
def runLog():
log_path = getServerDir() + '/log/gogs.log'
return log_path
6 years ago
6 years ago
def postReceiveLog():
log_path = getServerDir() + '/log/hooks/post-receive.log'
return log_path
6 years ago
def getGogsConf():
gets = [
6 years ago
{'name': 'DOMAIN', 'type': -1, 'ps': '服务器域名'},
{'name': 'ROOT_URL', 'type': -1, 'ps': '公开的完整URL路径'},
{'name': 'HTTP_ADDR', 'type': -1, 'ps': '应用HTTP监听地址'},
{'name': 'HTTP_PORT', 'type': -1, 'ps': '应用 HTTP 监听端口号'},
{'name': 'START_SSH_SERVER', 'type': 2, 'ps': '启动内置SSH服务器'},
{'name': 'SSH_PORT', 'type': -1, 'ps': 'SSH 端口号'},
6 years ago
{'name': 'REQUIRE_SIGNIN_VIEW', 'type': 2, 'ps': '强制登录浏览'},
6 years ago
{'name': 'ENABLE_CAPTCHA', 'type': 2, 'ps': '启用验证码服务'},
{'name': 'DISABLE_REGISTRATION', 'type': 2, 'ps': '禁止注册,只能由管理员创建帐号'},
{'name': 'ENABLE_NOTIFY_MAIL', 'type': 2, 'ps': '是否开启邮件通知'},
{'name': 'FORCE_PRIVATE', 'type': 2, 'ps': '强制要求所有新建的仓库都是私有'},
{'name': 'SHOW_FOOTER_BRANDING', 'type': 2, 'ps': 'Gogs推广信息'},
{'name': 'SHOW_FOOTER_VERSION', 'type': 2, 'ps': 'Gogs版本信息'},
{'name': 'SHOW_FOOTER_TEMPLATE_LOAD_TIME', 'type': 2, 'ps': 'Gogs模板加载时间'},
6 years ago
]
conf = mw.readFile(getConf())
6 years ago
result = []
6 years ago
6 years ago
for g in gets:
rep = g['name'] + '\s*=\s*(.*)'
tmp = re.search(rep, conf)
if not tmp:
continue
g['value'] = tmp.groups()[0]
result.append(g)
return mw.getJson(result)
6 years ago
def submitGogsConf():
6 years ago
gets = ['DOMAIN',
'ROOT_URL',
'HTTP_ADDR',
'HTTP_PORT',
'START_SSH_SERVER',
'SSH_PORT',
'REQUIRE_SIGNIN_VIEW',
'FORCE_PRIVATE',
'ENABLE_CAPTCHA',
'DISABLE_REGISTRATION',
'ENABLE_NOTIFY_MAIL',
'SHOW_FOOTER_BRANDING',
'SHOW_FOOTER_VERSION',
6 years ago
'SHOW_FOOTER_TEMPLATE_LOAD_TIME']
6 years ago
args = getArgs()
filename = getConf()
conf = mw.readFile(filename)
6 years ago
for g in gets:
if g in args:
rep = g + '\s*=\s*(.*)'
6 years ago
val = g + ' = ' + args[g]
6 years ago
conf = re.sub(rep, val, conf)
mw.writeFile(filename, conf)
6 years ago
reload()
return mw.returnJson(True, '设置成功')
6 years ago
6 years ago
def userList():
6 years ago
import math
6 years ago
args = getArgs()
6 years ago
6 years ago
page = 1
page_size = 10
search = ''
if 'page' in args:
page = int(args['page'])
if 'page_size' in args:
page_size = int(args['page_size'])
if 'search' in args:
search = args['search']
6 years ago
data = {}
data['root_url'] = getRootUrl()
pm = pMysqlDb()
start = (page - 1) * page_size
list_count = pm.query('select count(id) as num from user')
count = list_count[0][0]
list_data = pm.query(
'select id,name,email from user order by id desc limit ' + str(start) + ',' + str(page_size))
page_info = {'count': count, 'p': page,
'row': page_size, 'tojs': 'gogsUserList'}
data['list'] = mw.getPage(page_info)
6 years ago
data['page'] = page
data['page_size'] = page_size
data['page_count'] = int(math.ceil(count / page_size))
data['data'] = list_data
return mw.returnJson(True, 'OK', data)
6 years ago
def getAllUserProject(user, search=''):
path = getRootPath() + '/' + user
dlist = []
if os.path.exists(path):
for filename in os.listdir(path):
tmp = {}
filePath = path + '/' + filename
if os.path.isdir(filePath):
if search == '':
tmp['name'] = filename.replace('.git', '')
dlist.append(tmp)
else:
if filename.find(search) != -1:
tmp['name'] = filename.replace('.git', '')
dlist.append(tmp)
return dlist
def checkProjectListIsHasScript(user, data):
path = getRootPath() + '/' + user
for x in range(len(data)):
name = data[x]['name'] + '.git'
path_tmp = path + '/' + name + '/custom_hooks/post-receive'
if os.path.exists(path_tmp):
data[x]['has_hook'] = True
else:
data[x]['has_hook'] = False
return data
def userProjectList():
import math
args = getArgs()
# print args
page = 1
page_size = 5
search = ''
if not 'name' in args:
return mw.returnJson(False, '缺少参数name')
6 years ago
if 'page' in args:
page = int(args['page'])
if 'page_size' in args:
page_size = int(args['page_size'])
if 'search' in args:
search = args['search']
data = {}
ulist = getAllUserProject(args['name'])
dlist_sum = len(ulist)
start = (page - 1) * page_size
ret_data = ulist[start:start + page_size]
ret_data = checkProjectListIsHasScript(args['name'], ret_data)
data['root_url'] = getRootUrl()
data['data'] = ret_data
data['args'] = args
data['list'] = mw.getPage(
6 years ago
{'count': dlist_sum, 'p': page, 'row': page_size, 'tojs': 'userProjectList'})
return mw.returnJson(True, 'OK', data)
6 years ago
def projectScriptEdit():
args = getArgs()
if not 'user' in args:
return mw.returnJson(True, 'username missing')
6 years ago
if not 'name' in args:
return mw.returnJson(True, 'project name missing')
6 years ago
user = args['user']
name = args['name'] + '.git'
post_receive = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/commit'
6 years ago
if os.path.exists(post_receive):
return mw.returnJson(True, 'OK', {'path': post_receive})
6 years ago
else:
return mw.returnJson(False, 'file does not exist')
6 years ago
def projectScriptLoad():
args = getArgs()
if not 'user' in args:
return mw.returnJson(True, 'username missing')
6 years ago
if not 'name' in args:
return mw.returnJson(True, 'project name missing')
6 years ago
user = args['user']
name = args['name'] + '.git'
path = getRootPath() + '/' + user + '/' + name
post_receive_tpl = getPluginDir() + '/hook/post-receive.tpl'
post_receive = path + '/custom_hooks/post-receive'
if not os.path.exists(path + '/custom_hooks'):
mw.execShell('mkdir -p ' + path + '/custom_hooks')
6 years ago
pct_content = mw.readFile(post_receive_tpl)
6 years ago
pct_content = pct_content.replace('{$PATH}', path + '/custom_hooks')
mw.writeFile(post_receive, pct_content)
mw.execShell('chmod 777 ' + post_receive)
6 years ago
commit_tpl = getPluginDir() + '/hook/commit.tpl'
commit = path + '/custom_hooks/commit'
codeDir = mw.getRootDir() + '/git'
6 years ago
cc_content = mw.readFile(commit_tpl)
sshUrl = 'ssh://127.0.0.1:' + getSshPort()
cc_content = cc_content.replace('{$GITROOTURL}', sshUrl)
6 years ago
cc_content = cc_content.replace('{$CODE_DIR}', codeDir)
cc_content = cc_content.replace('{$USERNAME}', user)
cc_content = cc_content.replace('{$PROJECT}', args['name'])
cc_content = cc_content.replace('{$WEB_ROOT}', mw.getWwwDir())
mw.writeFile(commit, cc_content)
mw.execShell('chmod 777 ' + commit)
6 years ago
return 'ok'
def projectScriptUnload():
args = getArgs()
if not 'user' in args:
return mw.returnJson(True, 'username missing')
6 years ago
if not 'name' in args:
return mw.returnJson(True, 'project name missing')
6 years ago
user = args['user']
name = args['name'] + '.git'
post_receive = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/post-receive'
mw.execShell('rm -f ' + post_receive)
6 years ago
commit = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/commit'
mw.execShell('rm -f ' + commit)
6 years ago
return 'ok'
def projectScriptDebug():
args = getArgs()
if not 'user' in args:
return mw.returnJson(True, 'username missing')
6 years ago
if not 'name' in args:
return mw.returnJson(True, 'project name missing')
6 years ago
user = args['user']
name = args['name'] + '.git'
commit_log = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/sh.log'
data = {}
if os.path.exists(commit_log):
data['status'] = True
data['path'] = commit_log
else:
data['status'] = False
data['msg'] = '没有日志文件'
6 years ago
return mw.getJson(data)
6 years ago
def gogsEdit():
data = {}
data['post_receive'] = getPluginDir() + '/hook/post-receive.tpl'
data['commit'] = getPluginDir() + '/hook/commit.tpl'
return mw.getJson(data)
6 years ago
6 years ago
def getRsaPublic():
path = getHomeDir()
path += '/.ssh/id_rsa.pub'
content = mw.readFile(path)
6 years ago
data = {}
data['mw'] = content
return mw.getJson(data)
6 years ago
6 years ago
def getTotalStatistics():
st = status()
data = {}
if st == 'start':
6 years ago
pm = pMysqlDb()
list_count = pm.query('select count(id) as num from repository')
count = list_count[0][0]
6 years ago
data['status'] = True
6 years ago
data['count'] = count
data['ver'] = mw.readFile(getServerDir() + '/version.pl').strip()
return mw.returnJson(True, 'ok', data)
6 years ago
else:
data['status'] = False
data['count'] = 0
return mw.returnJson(False, 'fail', data)
6 years ago
6 years ago
6 years ago
if __name__ == "__main__":
func = sys.argv[1]
if func == 'status':
4 years ago
print(status())
6 years ago
elif func == 'start':
4 years ago
print(start())
6 years ago
elif func == 'stop':
4 years ago
print(stop())
6 years ago
elif func == 'restart':
4 years ago
print(restart())
6 years ago
elif func == 'reload':
4 years ago
print(reload())
6 years ago
elif func == 'initd_status':
4 years ago
print(initdStatus())
6 years ago
elif func == 'initd_install':
4 years ago
print(initdInstall())
6 years ago
elif func == 'initd_uninstall':
4 years ago
print(initdUinstall())
6 years ago
elif func == 'run_log':
4 years ago
print(runLog())
6 years ago
elif func == 'post_receive_log':
4 years ago
print(postReceiveLog())
6 years ago
elif func == 'conf':
4 years ago
print(getConf())
6 years ago
elif func == 'init_conf':
4 years ago
print(getInitdConf())
6 years ago
elif func == 'get_gogs_conf':
4 years ago
print(getGogsConf())
6 years ago
elif func == 'submit_gogs_conf':
4 years ago
print(submitGogsConf())
6 years ago
elif func == 'user_list':
4 years ago
print(userList())
6 years ago
elif func == 'user_project_list':
4 years ago
print(userProjectList())
6 years ago
elif func == 'project_script_edit':
4 years ago
print(projectScriptEdit())
6 years ago
elif func == 'project_script_load':
4 years ago
print(projectScriptLoad())
6 years ago
elif func == 'project_script_unload':
4 years ago
print(projectScriptUnload())
6 years ago
elif func == 'project_script_debug':
4 years ago
print(projectScriptDebug())
elif func == 'gogs_edit':
4 years ago
print(gogsEdit())
6 years ago
elif func == 'get_rsa_public':
4 years ago
print(getRsaPublic())
6 years ago
elif func == 'get_total_statistics':
4 years ago
print(getTotalStatistics())
6 years ago
else:
4 years ago
print('fail')