mdserver-web/plugins/gogs/index.py

1132 lines
30 KiB
Python
Raw Permalink Normal View History

2018-12-13 05:07:44 -05:00
# coding: utf-8
import time
import os
import sys
2019-02-13 23:02:16 -05:00
import re
2024-11-23 17:02:41 -05:00
import psutil
2018-12-14 03:06:59 -05:00
2024-11-23 17:02:41 -05:00
web_dir = os.getcwd() + "/web"
if os.path.exists(web_dir):
sys.path.append(web_dir)
os.chdir(web_dir)
2022-04-10 10:55:52 -04:00
2024-11-23 17:02:41 -05:00
import core.mw as mw
2022-04-10 10:57:23 -04:00
2022-06-25 10:31:35 -04:00
2018-12-14 03:06:59 -05:00
app_debug = False
2020-07-10 03:57:25 -04:00
if mw.isAppleSystem():
2018-12-14 03:06:59 -05:00
app_debug = True
def getPluginName():
return 'gogs'
def getPluginDir():
2020-07-10 03:57:25 -04:00
return mw.getPluginDir() + '/' + getPluginName()
2018-12-14 03:06:59 -05:00
def getServerDir():
2020-07-10 03:57:25 -04:00
return mw.getServerDir() + '/' + getPluginName()
2018-12-14 03:06:59 -05:00
def getInitDFile():
if app_debug:
return '/tmp/' + getPluginName()
return '/etc/init.d/' + getPluginName()
def getArgs():
args = sys.argv[2:]
tmp = {}
2018-12-14 04:39:47 -05:00
args_len = len(args)
if args_len == 1:
t = args[0].strip('{').strip('}')
2019-03-11 07:22:18 -04:00
t = t.split(':', 1)
2018-12-14 03:06:59 -05:00
tmp[t[0]] = t[1]
2018-12-14 04:39:47 -05:00
elif args_len > 1:
for i in range(len(args)):
2019-03-11 07:22:18 -04:00
t = args[i].split(':', 1)
2018-12-14 04:39:47 -05:00
tmp[t[0]] = t[1]
2018-12-14 03:06:59 -05:00
return tmp
2022-06-25 10:31:35 -04:00
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'))
2019-01-07 00:48:54 -05:00
def getInitdConfTpl():
2018-12-14 04:39:47 -05:00
path = getPluginDir() + "/init.d/gogs.tpl"
return path
2019-01-07 00:48:54 -05:00
def getInitdConf():
path = getServerDir() + "/init.d/gogs"
return path
2018-12-14 05:29:53 -05:00
def getConf():
path = getServerDir() + "/custom/conf/app.ini"
return path
2019-02-13 06:49:02 -05:00
def getConfTpl():
path = getPluginDir() + "/conf/app.ini"
return path
2018-12-14 03:06:59 -05:00
def status():
2020-07-10 03:57:25 -04:00
data = mw.execShell(
2018-12-14 03:06:59 -05:00
"ps -ef|grep " + getPluginName() + " |grep -v grep | grep -v python | awk '{print $2}'")
if data[0] == '':
return 'stop'
return 'start'
2019-02-28 06:54:53 -05:00
def getHomeDir():
2020-07-10 03:57:25 -04:00
if mw.isAppleSystem():
user = mw.execShell(
2019-02-13 06:58:42 -05:00
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
2019-02-28 06:54:53 -05:00
return '/Users/' + user
2019-02-13 06:58:42 -05:00
else:
2019-03-12 01:11:00 -04:00
return '/root'
2019-02-28 06:54:53 -05:00
def getRunUser():
2020-07-10 03:57:25 -04:00
if mw.isAppleSystem():
2024-11-28 10:28:58 -05:00
user = mw.execShell("who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
2019-02-28 06:54:53 -05:00
return user
else:
2019-03-12 01:11:00 -04:00
return 'root'
2019-02-28 06:54:53 -05:00
__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):
2019-02-13 06:58:42 -05:00
2020-07-10 03:57:25 -04:00
service_path = mw.getServerDir()
2024-11-24 12:13:47 -05:00
content = content.replace('{$ROOT_PATH}', mw.getFatherDir())
2019-02-13 06:49:02 -05:00
content = content.replace('{$SERVER_PATH}', service_path)
2019-02-28 06:54:53 -05:00
content = content.replace('{$RUN_USER}', getRunUser())
content = content.replace('{$HOME_DIR}', getHomeDir())
2019-02-13 06:49:02 -05:00
return content
2018-12-14 03:06:59 -05:00
def initDreplace():
2019-01-07 00:48:54 -05:00
file_tpl = getInitdConfTpl()
2020-07-10 03:57:25 -04:00
service_path = mw.getServerDir()
2018-12-14 03:06:59 -05:00
initD_path = getServerDir() + '/init.d'
if not os.path.exists(initD_path):
os.mkdir(initD_path)
2018-12-14 04:39:47 -05:00
file_bin = initD_path + '/' + getPluginName()
2018-12-14 03:06:59 -05:00
2019-02-13 06:49:02 -05:00
if not os.path.exists(file_bin):
2020-07-10 03:57:25 -04:00
content = mw.readFile(file_tpl)
2019-02-13 06:49:02 -05:00
content = contentReplace(content)
2020-07-10 03:57:25 -04:00
mw.writeFile(file_bin, content)
mw.execShell('chmod +x ' + file_bin)
2019-02-13 06:49:02 -05:00
2022-06-19 03:46:05 -04:00
# conf_bin = getConf()
# if not os.path.exists(conf_bin):
# mw.execShell('mkdir -p ' + getServerDir() + '/custom/conf')
# conf_tpl = getConfTpl()
# content = mw.readFile(conf_tpl)
# content = contentReplace(content)
# mw.writeFile(conf_bin, content)
# systemd
2022-07-11 01:49:25 -04:00
systemDir = mw.systemdCfgDir()
2022-06-19 03:46:05 -04:00
systemService = systemDir + '/gogs.service'
systemServiceTpl = getPluginDir() + '/init.d/gogs.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')
2018-12-14 05:04:50 -05:00
log_path = getServerDir() + '/log'
if not os.path.exists(log_path):
os.mkdir(log_path)
2018-12-14 03:06:59 -05:00
return file_bin
2019-02-15 07:19:41 -05:00
def getRootUrl():
2020-07-10 03:57:25 -04:00
content = mw.readFile(getConf())
2024-10-24 02:25:17 -04:00
rep = r'ROOT_URL\\s*=\\s*(.*)'
2019-02-15 07:19:41 -05:00
tmp = re.search(rep, content)
2022-06-25 13:16:27 -04:00
if tmp:
return tmp.groups()[0]
2024-10-24 02:25:17 -04:00
rep = r'EXTERNAL_URL\\s*=\s*(.*)'
2022-06-25 13:16:27 -04:00
tmp = re.search(rep, content)
if tmp:
return tmp.groups()[0]
return ''
2019-02-15 07:19:41 -05:00
2019-03-05 03:00:31 -05:00
def getSshPort():
2020-07-10 03:57:25 -04:00
content = mw.readFile(getConf())
2024-10-24 02:25:17 -04:00
rep = r'SSH_PORT\\s*=\\s*(.*)'
2019-03-05 03:00:31 -05:00
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
2021-11-11 05:38:47 -05:00
def getHttpPort():
content = mw.readFile(getConf())
2024-10-24 02:25:17 -04:00
rep = r'HTTP_PORT\\s*=\\s*(.*)'
2021-11-11 05:38:47 -05:00
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
2019-02-15 07:19:41 -05:00
def getRootPath():
2020-07-10 03:57:25 -04:00
content = mw.readFile(getConf())
2024-10-24 02:25:17 -04:00
rep = r'ROOT\\s*=\\s*(.*)'
2019-02-15 07:19:41 -05:00
tmp = re.search(rep, content)
if not tmp:
return ''
return tmp.groups()[0]
2019-02-14 04:50:32 -05:00
def getDbConfValue():
2022-07-14 04:21:14 -04:00
conf = getConf()
if not os.path.exists(conf):
return {}
2019-02-14 04:50:32 -05:00
2022-07-14 04:21:14 -04:00
content = mw.readFile(conf)
2024-10-24 02:25:17 -04:00
rep_scope = r"\\[database\\](.*?)\\["
2019-02-14 04:50:32 -05:00
tmp = re.findall(rep_scope, content, re.S)
2024-10-24 02:25:17 -04:00
rep = r'(\\w*)\\s*=\\s*(.*)'
2019-02-14 04:50:32 -05:00
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
2022-06-25 10:31:35 -04:00
def pMysqlDb(conf):
2019-02-14 04:50:32 -05:00
host = conf['HOST'].split(':')
2022-09-06 05:45:56 -04:00
# pymysql
db = mw.getMyORM()
# MySQLdb |
# db = mw.getMyORMDb()
2019-02-14 04:50:32 -05:00
2022-09-06 05:45:56 -04:00
db.setPort(int(host[1]))
db.setUser(conf['USER'])
2022-09-28 11:20:38 -04:00
if 'PASSWD' in conf:
db.setPwd(conf['PASSWD'])
else:
db.setPwd(conf['PASSWORD'])
2022-09-06 05:45:56 -04:00
db.setDbName(conf['NAME'])
# db.setSocket(getSocketFile())
db.setCharset("utf8")
return db
2019-02-14 04:50:32 -05:00
2022-06-25 10:31:35 -04:00
def pSqliteDb(conf):
# print(conf)
import db
psDb = db.Sql()
# 默认
gsdir = getServerDir() + '/data'
dbname = 'gogs'
if conf['PATH'][0] == '/':
# 绝对路径
pass
else:
path = conf['PATH'].split('/')
gsdir = getServerDir() + '/' + path[0]
dbname = path[1].split('.')[0]
# print(gsdir, dbname)
psDb.dbPos(gsdir, dbname)
return psDb
2022-06-25 10:42:06 -04:00
def getGogsDbType(conf):
if 'DB_TYPE' in conf:
return conf['DB_TYPE']
if 'TYPE' in conf:
return conf['TYPE']
return 'NONE'
2022-06-25 10:31:35 -04:00
def pQuery(sql):
conf = getDbConfValue()
2022-06-25 10:42:06 -04:00
gtype = getGogsDbType(conf)
if gtype == 'sqlite3':
2022-06-25 10:31:35 -04:00
db = pSqliteDb(conf)
data = db.query(sql, []).fetchall()
return data
2022-06-25 10:42:06 -04:00
elif gtype == 'mysql':
2022-06-25 10:31:35 -04:00
db = pMysqlDb(conf)
return db.query(sql)
print("仅支持mysql|sqlite3配置")
exit(0)
2019-02-14 04:50:32 -05:00
def isSqlError(mysqlMsg):
# 检测数据库执行错误
_mysqlMsg = str(mysqlMsg)
# print _mysqlMsg
if "MySQLdb" in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, 'MySQLdb组件缺失! <br>进入SSH命令行输入 pip install mysql-python')
2019-02-14 04:50:32 -05:00
if "2002," in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, '数据库连接失败,请检查数据库服务是否启动!')
2019-02-14 04:50:32 -05:00
if "using password:" in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, '数据库管理密码错误!')
2019-02-14 04:50:32 -05:00
if "Connection refused" in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, '数据库连接失败,请检查数据库服务是否启动!')
2019-02-14 04:50:32 -05:00
if "1133," in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, '数据库用户不存在!')
2019-02-14 04:50:32 -05:00
if "1007," in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, '数据库已经存在!')
2019-02-14 04:50:32 -05:00
if "1044," in _mysqlMsg:
2020-07-10 03:57:25 -04:00
return mw.returnData(False, mysqlMsg[1])
2019-02-14 04:50:32 -05:00
if "2003," in _mysqlMsg:
2021-11-06 07:50:28 -04:00
return mw.returnData(False, "Can't connect to MySQL server on '127.0.0.1' (61)")
2020-07-10 03:57:25 -04:00
return mw.returnData(True, 'OK')
2019-02-14 04:50:32 -05:00
2022-06-25 10:31:35 -04:00
def gogsOp(method):
2018-12-14 03:06:59 -05:00
file = initDreplace()
2022-06-25 10:31:35 -04:00
if not mw.isAppleSystem():
data = mw.execShell('systemctl ' + method + ' gogs')
if data[1] == '':
return 'ok'
return 'fail'
data = mw.execShell(__SR + file + ' ' + method)
2018-12-14 03:06:59 -05:00
if data[1] == '':
return 'ok'
2019-02-14 02:19:36 -05:00
return data[0]
2018-12-14 03:06:59 -05:00
2022-06-25 10:31:35 -04:00
def start():
return gogsOp('start')
2018-12-14 03:06:59 -05:00
def stop():
2022-06-25 10:31:35 -04:00
return gogsOp('stop')
2018-12-14 03:06:59 -05:00
def restart():
2022-06-25 10:31:35 -04:00
return gogsOp('restart')
2018-12-14 03:06:59 -05:00
def reload():
2022-06-25 10:31:35 -04:00
return gogsOp('reload')
2018-12-14 03:06:59 -05:00
def initdStatus():
2022-06-19 03:46:05 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
shell_cmd = 'systemctl status gogs | grep loaded | grep "enabled;"'
data = mw.execShell(shell_cmd)
if data[0] == '':
return 'fail'
return 'ok'
2018-12-14 03:06:59 -05:00
def initdInstall():
2022-06-19 03:46:05 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
mw.execShell('systemctl enable gogs')
2018-12-14 03:06:59 -05:00
return 'ok'
def initdUinstall():
2022-06-19 03:46:05 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
mw.execShell('systemctl disable gogs')
2018-12-14 03:06:59 -05:00
return 'ok'
2018-12-14 05:29:53 -05:00
def runLog():
log_path = getServerDir() + '/log/gogs.log'
return log_path
2019-02-13 23:02:16 -05:00
2019-02-15 07:19:41 -05:00
def postReceiveLog():
log_path = getServerDir() + '/log/hooks/post-receive.log'
return log_path
2019-02-13 23:02:16 -05:00
def getGogsConf():
2022-07-13 04:08:53 -04:00
conf = getConf()
if not os.path.exists(conf):
2022-08-15 01:41:01 -04:00
return mw.returnJson(False, "请先安装初始化!<br/>默认地址:http://" + mw.getLocalIp() + ":3000")
2022-07-13 04:08:53 -04:00
2019-02-13 23:02:16 -05:00
gets = [
2019-02-14 01:28:11 -05:00
{'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 端口号'},
2019-02-13 23:02:16 -05:00
{'name': 'REQUIRE_SIGNIN_VIEW', 'type': 2, 'ps': '强制登录浏览'},
2019-02-14 01:28:11 -05:00
{'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模板加载时间'},
2019-02-13 23:02:16 -05:00
]
2022-07-13 04:08:53 -04:00
conf = mw.readFile(conf)
2019-02-13 23:02:16 -05:00
result = []
2019-02-14 01:28:11 -05:00
2019-02-13 23:02:16 -05:00
for g in gets:
2024-10-24 02:39:16 -04:00
rep = g['name'] + '\\s*=\\s*(.*)'
2019-02-13 23:02:16 -05:00
tmp = re.search(rep, conf)
if not tmp:
continue
g['value'] = tmp.groups()[0]
result.append(g)
2022-07-13 04:08:53 -04:00
return mw.returnJson(True, 'OK', result)
2019-02-13 23:02:16 -05:00
def submitGogsConf():
2019-02-15 07:19:41 -05:00
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',
2019-02-14 01:28:11 -05:00
'SHOW_FOOTER_TEMPLATE_LOAD_TIME']
2019-02-13 23:02:16 -05:00
args = getArgs()
filename = getConf()
2020-07-10 03:57:25 -04:00
conf = mw.readFile(filename)
2019-02-13 23:02:16 -05:00
for g in gets:
if g in args:
2024-10-24 02:25:17 -04:00
rep = g + '\\s*=\\s*(.*)'
2019-02-14 01:28:11 -05:00
val = g + ' = ' + args[g]
2019-02-13 23:02:16 -05:00
conf = re.sub(rep, val, conf)
2020-07-10 03:57:25 -04:00
mw.writeFile(filename, conf)
2019-02-14 01:28:11 -05:00
reload()
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, '设置成功')
2019-02-13 23:02:16 -05:00
2019-02-14 11:21:56 -05:00
2023-10-29 02:35:09 -04:00
def gogsEditTpl():
data = {}
data['post_receive'] = getPluginDir() + '/hook/post-receive.tpl'
data['commit'] = getPluginDir() + '/hook/commit.tpl'
return mw.getJson(data)
2019-02-14 11:21:56 -05:00
def userList():
2022-07-13 04:08:53 -04:00
conf = getConf()
if not os.path.exists(conf):
2022-08-15 01:41:01 -04:00
return mw.returnJson(False, "请先安装初始化!<br/>默认地址:http://" + mw.getLocalIp() + ":3000")
2022-07-13 04:08:53 -04:00
2022-10-03 00:27:44 -04:00
conf = getDbConfValue()
2022-10-06 05:52:25 -04:00
gtype = getGogsDbType(conf)
2022-10-03 00:27:44 -04:00
if gtype != 'mysql':
return mw.returnJson(False, "仅支持mysql数据操作!")
2019-02-15 07:19:41 -05:00
import math
2019-02-14 11:21:56 -05:00
args = getArgs()
2019-02-15 07:19:41 -05:00
2022-06-25 10:31:35 -04:00
data = checkArgs(args, ['page', 'page_size'])
if not data[0]:
return data[1]
2019-02-14 11:21:56 -05:00
2022-06-25 10:31:35 -04:00
page = int(args['page'])
page_size = int(args['page_size'])
search = ''
2019-02-14 11:21:56 -05:00
if 'search' in args:
search = args['search']
2023-10-30 03:04:58 -04:00
user_where1 = ''
user_where2 = ''
if search != '':
user_where1 = ' where name like "%' + search + '%"'
user_where2 = ' where name like "%' + search + '%"'
2019-02-15 07:19:41 -05:00
data = {}
data['root_url'] = getRootUrl()
start = (page - 1) * page_size
2023-10-30 03:04:58 -04:00
list_count = pQuery('select count(id) as num from user' + user_where1)
2022-09-06 05:45:56 -04:00
count = list_count[0]["num"]
2022-06-25 10:31:35 -04:00
list_data = pQuery(
2023-10-30 03:04:58 -04:00
'select id,name,email from user ' + user_where2 + ' order by id desc limit ' + str(start) + ',' + str(page_size))
2022-06-25 10:31:35 -04:00
data['list'] = mw.getPage({'count': count, 'p': page,
'row': page_size, 'tojs': 'gogsUserList'})
2019-02-15 07:19:41 -05:00
data['page'] = page
data['page_size'] = page_size
data['page_count'] = int(math.ceil(count / page_size))
data['data'] = list_data
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'OK', data)
2019-02-15 07:19:41 -05:00
2023-10-28 15:23:17 -04:00
def checkRepoListIsHasScript(data):
path = getRootPath()
for x in range(len(data)):
name = data[x]['name'] + '/' + data[x]['repo'] + '.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 repoList():
conf = getConf()
if not os.path.exists(conf):
return mw.returnJson(False, "请先安装初始化!<br/>默认地址:http://" + mw.getLocalIp() + ":3000")
conf = getDbConfValue()
gtype = getGogsDbType(conf)
if gtype != 'mysql':
return mw.returnJson(False, "仅支持mysql数据操作!")
import math
args = getArgs()
data = checkArgs(args, ['page', 'page_size'])
if not data[0]:
return data[1]
page = int(args['page'])
page_size = int(args['page_size'])
search = ''
if 'search' in args:
search = args['search']
data = {}
data['root_url'] = getRootUrl()
2023-10-30 02:47:54 -04:00
repo_where1 = ''
repo_where2 = ''
if search != '':
repo_where1 = ' where name like "%' + search + '%"'
repo_where2 = ' where r.name like "%' + search + '%"'
2023-10-28 15:23:17 -04:00
start = (page - 1) * page_size
2023-10-30 02:47:54 -04:00
list_count = pQuery(
'select count(id) as num from repository' + repo_where1)
2023-10-28 15:23:17 -04:00
count = list_count[0]["num"]
2023-10-30 02:47:54 -04:00
sql = 'select r.id,r.owner_id,r.name as repo, u.name from repository r left join user u on r.owner_id=u.id ' + repo_where2 + ' order by r.id desc limit ' + \
2023-10-28 15:23:17 -04:00
str(start) + ',' + str(page_size)
# print(sql)
list_data = pQuery(sql)
# print(list_data)
list_data = checkRepoListIsHasScript(list_data)
2024-11-28 10:28:58 -05:00
data['list'] = mw.getPage({'count': count, 'p': page, 'row': page_size, 'tojs': 'gogsRepoListPage'})
2023-10-28 15:23:17 -04:00
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)
2019-02-15 07:19:41 -05:00
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:
2020-07-10 03:57:25 -04:00
return mw.returnJson(False, '缺少参数name')
2019-02-15 07:19:41 -05:00
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
2020-07-10 03:57:25 -04:00
data['list'] = mw.getPage(
2023-10-04 03:13:17 -04:00
{'count': dlist_sum, 'p': page, 'row': page_size, 'tojs': 'userProjectListPage'})
2019-02-15 07:19:41 -05:00
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'OK', data)
2019-02-15 07:19:41 -05:00
def projectScriptEdit():
args = getArgs()
if not 'user' in args:
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'username missing')
2019-02-15 07:19:41 -05:00
if not 'name' in args:
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'project name missing')
2019-02-15 07:19:41 -05:00
user = args['user']
name = args['name'] + '.git'
post_receive = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/commit'
2019-02-15 07:19:41 -05:00
if os.path.exists(post_receive):
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'OK', {'path': post_receive})
2019-02-15 07:19:41 -05:00
else:
2020-07-10 03:57:25 -04:00
return mw.returnJson(False, 'file does not exist')
2019-02-15 07:19:41 -05:00
def projectScriptLoad():
args = getArgs()
if not 'user' in args:
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'username missing')
2019-02-15 07:19:41 -05:00
if not 'name' in args:
2020-07-10 03:57:25 -04:00
return mw.returnJson(True, 'project name missing')
2019-02-15 07:19:41 -05:00
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'):
2020-07-10 03:57:25 -04:00
mw.execShell('mkdir -p ' + path + '/custom_hooks')
2019-02-15 07:19:41 -05:00
2020-07-10 03:57:25 -04:00
pct_content = mw.readFile(post_receive_tpl)
2019-02-15 07:19:41 -05:00
pct_content = pct_content.replace('{$PATH}', path + '/custom_hooks')
2020-07-10 03:57:25 -04:00
mw.writeFile(post_receive, pct_content)
mw.execShell('chmod 777 ' + post_receive)
2019-02-15 07:19:41 -05:00
commit_tpl = getPluginDir() + '/hook/commit.tpl'
commit = path + '/custom_hooks/commit'
2024-11-24 12:13:47 -05:00
codeDir = mw.getFatherDir() + '/git'
2019-02-15 07:19:41 -05:00
2020-07-10 03:57:25 -04:00
cc_content = mw.readFile(commit_tpl)
2019-03-05 03:00:31 -05:00
2022-06-25 14:36:04 -04:00
gitPath = getRootPath()
cc_content = cc_content.replace('{$GITROOTURL}', gitPath)
2019-02-15 07:19:41 -05:00
cc_content = cc_content.replace('{$CODE_DIR}', codeDir)
cc_content = cc_content.replace('{$USERNAME}', user)
cc_content = cc_content.replace('{$PROJECT}', args['name'])
2020-07-10 03:57:25 -04:00
cc_content = cc_content.replace('{$WEB_ROOT}', mw.getWwwDir())
mw.writeFile(commit, cc_content)
mw.execShell('chmod 777 ' + commit)
2019-02-15 07:19:41 -05:00
return 'ok'
def projectScriptUnload():
args = getArgs()
2022-07-13 21:41:03 -04:00
data = checkArgs(args, ['user', 'name'])
if not data[0]:
return data[1]
2019-02-15 07:19:41 -05:00
user = args['user']
name = args['name'] + '.git'
post_receive = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/post-receive'
2020-07-10 03:57:25 -04:00
mw.execShell('rm -f ' + post_receive)
2019-02-15 07:19:41 -05:00
commit = getRootPath() + '/' + user + '/' + name + \
'/custom_hooks/commit'
2020-07-10 03:57:25 -04:00
mw.execShell('rm -f ' + commit)
2019-02-15 07:19:41 -05:00
return 'ok'
def projectScriptDebug():
args = getArgs()
2022-07-13 21:41:03 -04:00
data = checkArgs(args, ['user', 'name'])
if not data[0]:
return data[1]
2019-02-15 07:19:41 -05:00
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'] = '没有日志文件'
2019-02-14 11:21:56 -05:00
2020-07-10 03:57:25 -04:00
return mw.getJson(data)
2019-02-14 11:21:56 -05:00
2019-02-15 12:20:56 -05:00
2023-10-29 02:26:46 -04:00
def projectScriptRun():
args = getArgs()
data = checkArgs(args, ['user', 'name'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
path = getRootPath() + '/' + user + '/' + name
commit_sh = path + '/custom_hooks/commit'
commit_log = path + '/custom_hooks/sh.log'
script_run = 'sh -x ' + commit_sh + ' 2>' + commit_log
if not os.path.exists(commit_sh):
return mw.returnJson(False, '脚本文件不存在!')
mw.execShell(script_run)
return mw.returnJson(True, '脚本文件执行成功,观察日志!')
2023-10-29 02:35:09 -04:00
def projectScriptSelf():
args = getArgs()
data = checkArgs(args, ['user', 'name'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
2019-02-15 12:20:56 -05:00
2023-10-29 11:50:32 -04:00
custom_hooks = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
2023-10-29 12:25:45 -04:00
self_path = custom_hooks + '/self'
2023-10-29 11:50:32 -04:00
if not os.path.exists(self_path):
os.mkdir(self_path)
2023-10-29 12:25:45 -04:00
self_logs_path = custom_hooks + '/self_logs'
if not os.path.exists(self_logs_path):
os.mkdir(self_logs_path)
2023-10-29 11:50:32 -04:00
self_hook_file = custom_hooks + '/self_hook.sh'
self_hook_exist = False
if os.path.exists(self_hook_file):
self_hook_exist = True
dlist = []
if os.path.exists(self_path):
for filename in os.listdir(self_path):
tmp = {}
filePath = self_path + '/' + filename
if os.path.isfile(filePath):
tmp['path'] = filePath
tmp['name'] = os.path.basename(filePath)
2023-10-29 13:43:35 -04:00
tmp['is_hidden'] = False
if tmp['name'].endswith('.txt'):
tmp['is_hidden'] = True
2023-10-29 11:50:32 -04:00
dlist.append(tmp)
dlist_sum = len(dlist)
# print(dlist)
rdata = {}
rdata['data'] = dlist
rdata['self_hook'] = self_hook_exist
rdata['list'] = mw.getPage(
{'count': dlist_sum, 'p': 1, 'row': 100, 'tojs': 'self_page'})
return mw.returnJson(True, 'ok', rdata)
def projectScriptSelf_Create():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'file'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
file = args['file']
2024-11-28 10:28:58 -05:00
self_path = path = getRootPath() + '/' + user + '/' + name + '/custom_hooks/self'
2023-10-29 11:50:32 -04:00
if not os.path.exists(self_path):
os.mkdir(self_path)
abs_file = self_path + '/' + file + '.sh'
if os.path.exists(abs_file):
return mw.returnJson(False, '脚本已经存在!')
2023-10-29 13:00:54 -04:00
mw.writeFile(abs_file, "#!/bin/bash\necho `date +'%Y-%m-%d %H:%M:%S'`\n")
2023-10-29 11:50:32 -04:00
rdata = {}
rdata['abs_file'] = abs_file
return mw.returnJson(True, '创建文件成功!', rdata)
def projectScriptSelf_Del():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'file'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
file = args['file']
2023-10-29 12:25:45 -04:00
custom_hooks = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
self_path = custom_hooks + '/self'
2023-10-29 11:50:32 -04:00
if not os.path.exists(self_path):
os.mkdir(self_path)
abs_file = self_path + '/' + file
# print(abs_file)
if not os.path.exists(abs_file):
return mw.returnJson(False, '脚本已经删除!')
os.remove(abs_file)
2023-10-29 12:25:45 -04:00
# 日志也删除
log_file = custom_hooks + '/self_logs/' + file + '.log'
if os.path.exists(log_file):
os.remove(log_file)
2023-10-29 11:50:32 -04:00
return mw.returnJson(True, '脚本删除成功!')
def projectScriptSelf_Logs():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'file'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
file = args['file']
self_path = path = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks/self_logs'
if not os.path.exists(self_path):
os.mkdir(self_path)
logs_file = self_path + '/' + file + '.log'
if os.path.exists(logs_file):
rdata = {}
rdata['path'] = logs_file
2023-10-29 12:25:45 -04:00
return mw.returnJson(True, 'ok', rdata)
2023-10-29 11:50:32 -04:00
return mw.returnJson(False, '日志不存在!')
2023-10-29 13:00:54 -04:00
def projectScriptSelf_Run():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'file'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
file = args['file']
custom_hooks = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
self_path = custom_hooks + '/self/' + file
self_logs_path = custom_hooks + '/self_logs/' + file + '.log'
2023-11-11 03:13:11 -05:00
shell = "sh -x " + self_path + " 2>" + self_logs_path + ' &'
2023-10-29 13:00:54 -04:00
mw.execShell(shell)
return mw.returnJson(True, '执行成功!')
2023-10-29 11:50:32 -04:00
def projectScriptSelf_Rename():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'o_file', 'n_file'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
o_file = args['o_file']
n_file = args['n_file']
2023-10-29 12:25:45 -04:00
custom_hooks = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
self_path = custom_hooks + '/self'
2023-10-29 11:50:32 -04:00
if not os.path.exists(self_path):
os.mkdir(self_path)
o_file_abs = self_path + '/' + o_file + '.sh'
if not os.path.exists(o_file_abs):
return mw.returnJson(False, '原文件已经不存在了!')
n_file_abs = self_path + '/' + n_file + '.sh'
os.rename(o_file_abs, n_file_abs)
2023-10-29 12:25:45 -04:00
# 日志也删除
log_file = custom_hooks + '/self_logs/' + o_file + '.sh.log'
if os.path.exists(log_file):
os.remove(log_file)
2023-10-29 11:50:32 -04:00
return mw.returnJson(True, '重命名成功!')
def projectScriptSelf_Enable():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'enable'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
enable = args['enable']
custom_path = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
2023-10-30 01:31:18 -04:00
# 替换commit配置
commit_path = custom_path + '/commit'
note = '#Gogs Script Don`t Remove and Change'
2023-10-29 11:50:32 -04:00
self_file = custom_path + '/self_hook.sh'
self_hook_tpl = getPluginDir() + '/hook/self_hook.tpl'
if enable == '1':
content = mw.readFile(self_hook_tpl)
2023-10-29 12:25:45 -04:00
content = content.replace('{$HOOK_DIR}', custom_path + '/self')
content = content.replace(
'{$HOOK_LOGS_DIR}', custom_path + '/self_logs')
2023-10-29 11:50:32 -04:00
mw.writeFile(self_file, content)
2023-10-29 12:25:45 -04:00
mw.execShell("chmod 777 " + self_file)
2023-10-30 01:31:18 -04:00
commit_content = mw.readFile(commit_path)
commit_content += "\n\n" + "bash " + self_file + " " + note
mw.writeFile(commit_path, commit_content)
2023-10-29 11:50:32 -04:00
return mw.returnJson(True, '开启成功!')
else:
2023-10-30 01:31:18 -04:00
commit_content = mw.readFile(commit_path)
rep = ".*" + note
commit_content = re.sub(rep, '', commit_content, re.M)
commit_content = commit_content.strip()
mw.writeFile(commit_path, commit_content)
2023-10-29 11:50:32 -04:00
if os.path.exists(self_file):
os.remove(self_file)
return mw.returnJson(True, '关闭成功!')
2019-02-25 04:10:32 -05:00
2023-10-29 13:43:35 -04:00
def projectScriptSelf_Status():
args = getArgs()
data = checkArgs(args, ['user', 'name', 'file', 'status'])
if not data[0]:
return data[1]
user = args['user']
name = args['name'] + '.git'
file = args['file']
status = args['status']
custom_hooks = getRootPath() + '/' + user + '/' + \
name + '/custom_hooks'
self_path = custom_hooks + '/self'
if not os.path.exists(self_path):
os.mkdir(self_path)
# 日志也删除
log_file = custom_hooks + '/self_logs/' + file + '.log'
if os.path.exists(log_file):
os.remove(log_file)
if status == '1':
file_abs = self_path + '/' + file
file_text_abs = self_path + '/' + file + '.txt'
os.rename(file_abs, file_text_abs)
return mw.returnJson(True, '开始禁用成功!')
else:
file_abs = self_path + '/' + file.strip('.txt')
file_text_abs = self_path + '/' + file
os.rename(file_text_abs, file_abs)
return mw.returnJson(True, '开始使用成功!')
return mw.returnJson(True, '禁用成功!')
2019-03-12 01:11:00 -04:00
def getRsaPublic():
path = getHomeDir()
path += '/.ssh/id_rsa.pub'
2020-07-10 03:57:25 -04:00
content = mw.readFile(path)
2019-03-12 01:11:00 -04:00
data = {}
2020-07-10 03:57:25 -04:00
data['mw'] = content
return mw.getJson(data)
2019-03-12 01:11:00 -04:00
2019-02-25 04:10:32 -05:00
def getTotalStatistics():
st = status()
data = {}
2022-04-10 02:14:29 -04:00
if st.strip() == 'start':
2022-06-25 10:31:35 -04:00
list_count = pQuery('select count(id) as num from repository')
2022-09-15 23:49:20 -04:00
count = list_count[0]["num"]
2019-02-25 04:10:32 -05:00
data['status'] = True
2019-02-25 04:15:53 -05:00
data['count'] = count
2020-07-10 03:57:25 -04:00
data['ver'] = mw.readFile(getServerDir() + '/version.pl').strip()
return mw.returnJson(True, 'ok', data)
2022-04-10 02:14:29 -04:00
data['status'] = False
data['count'] = 0
return mw.returnJson(False, 'fail', data)
2019-02-25 04:10:32 -05:00
2019-03-12 01:11:00 -04:00
2018-12-14 03:06:59 -05:00
if __name__ == "__main__":
func = sys.argv[1]
if func == 'status':
2021-05-01 02:17:42 -04:00
print(status())
2018-12-14 03:06:59 -05:00
elif func == 'start':
2021-05-01 02:17:42 -04:00
print(start())
2018-12-14 03:06:59 -05:00
elif func == 'stop':
2021-05-01 02:17:42 -04:00
print(stop())
2018-12-14 03:06:59 -05:00
elif func == 'restart':
2021-05-01 02:17:42 -04:00
print(restart())
2018-12-14 03:06:59 -05:00
elif func == 'reload':
2021-05-01 02:17:42 -04:00
print(reload())
2018-12-14 03:06:59 -05:00
elif func == 'initd_status':
2021-05-01 02:17:42 -04:00
print(initdStatus())
2018-12-14 03:06:59 -05:00
elif func == 'initd_install':
2021-05-01 02:17:42 -04:00
print(initdInstall())
2018-12-14 03:06:59 -05:00
elif func == 'initd_uninstall':
2021-05-01 02:17:42 -04:00
print(initdUinstall())
2018-12-14 05:29:53 -05:00
elif func == 'run_log':
2021-05-01 02:17:42 -04:00
print(runLog())
2019-02-15 07:19:41 -05:00
elif func == 'post_receive_log':
2021-05-01 02:17:42 -04:00
print(postReceiveLog())
2018-12-14 03:06:59 -05:00
elif func == 'conf':
2021-05-01 02:17:42 -04:00
print(getConf())
2018-12-14 05:29:53 -05:00
elif func == 'init_conf':
2021-05-01 02:17:42 -04:00
print(getInitdConf())
2019-02-13 23:02:16 -05:00
elif func == 'get_gogs_conf':
2021-05-01 02:17:42 -04:00
print(getGogsConf())
2019-02-13 23:02:16 -05:00
elif func == 'submit_gogs_conf':
2021-05-01 02:17:42 -04:00
print(submitGogsConf())
2023-10-29 02:34:16 -04:00
elif func == 'gogs_edit_tpl':
print(gogsEditTpl())
2019-02-14 11:21:56 -05:00
elif func == 'user_list':
2021-05-01 02:17:42 -04:00
print(userList())
2023-10-28 15:23:17 -04:00
elif func == 'repo_list':
print(repoList())
2019-02-15 07:19:41 -05:00
elif func == 'user_project_list':
2021-05-01 02:17:42 -04:00
print(userProjectList())
2019-02-15 07:19:41 -05:00
elif func == 'project_script_edit':
2021-05-01 02:17:42 -04:00
print(projectScriptEdit())
2019-02-15 07:19:41 -05:00
elif func == 'project_script_load':
2021-05-01 02:17:42 -04:00
print(projectScriptLoad())
2019-02-15 07:19:41 -05:00
elif func == 'project_script_unload':
2021-05-01 02:17:42 -04:00
print(projectScriptUnload())
2019-02-15 07:19:41 -05:00
elif func == 'project_script_debug':
2021-05-01 02:17:42 -04:00
print(projectScriptDebug())
2023-10-29 02:26:46 -04:00
elif func == 'project_script_run':
print(projectScriptRun())
2023-10-29 02:34:16 -04:00
elif func == 'project_script_self':
print(projectScriptSelf())
2023-10-29 11:50:32 -04:00
elif func == 'project_script_self_create':
print(projectScriptSelf_Create())
elif func == 'project_script_self_del':
print(projectScriptSelf_Del())
elif func == 'project_script_self_logs':
print(projectScriptSelf_Logs())
2023-10-29 13:00:54 -04:00
elif func == 'project_script_self_run':
print(projectScriptSelf_Run())
2023-10-29 11:50:32 -04:00
elif func == 'project_script_self_rename':
print(projectScriptSelf_Rename())
elif func == 'project_script_self_enable':
print(projectScriptSelf_Enable())
2023-10-29 13:43:35 -04:00
elif func == 'project_script_self_status':
print(projectScriptSelf_Status())
2019-03-12 01:11:00 -04:00
elif func == 'get_rsa_public':
2021-05-01 02:17:42 -04:00
print(getRsaPublic())
2019-02-25 04:10:32 -05:00
elif func == 'get_total_statistics':
2021-05-01 02:17:42 -04:00
print(getTotalStatistics())
2018-12-14 03:06:59 -05:00
else:
2021-05-01 02:17:42 -04:00
print('fail')