app.py 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  1. # Init
  2. import os
  3. import re
  4. from route.tool.func import *
  5. # from route import *
  6. for i_data in os.listdir("route"):
  7. f_src = re.search(r"(.+)\.py$", i_data)
  8. f_src = f_src.group(1) if f_src else ""
  9. if not f_src in ('', '__init__'):
  10. try:
  11. exec(
  12. "from route." + f_src + " " +
  13. "import " + f_src
  14. )
  15. except:
  16. exec(
  17. "from route." + f_src + " " +
  18. "import " + f_src + "_2"
  19. )
  20. # Init-Version
  21. version_list = json.loads(open(
  22. 'version.json',
  23. encoding = 'utf8'
  24. ).read())
  25. # Init-DB
  26. if os.path.exists(os.path.join('data', 'set.json')):
  27. db_set_list = ['db', 'db_type']
  28. set_data = json.loads(open(
  29. os.path.join('data', 'set.json'),
  30. encoding = 'utf8'
  31. ).read())
  32. for i in db_set_list:
  33. if not i in set_data:
  34. print('Please delete set.json')
  35. print('----')
  36. raise
  37. print('DB name : ' + set_data['db'])
  38. print('DB type : ' + set_data['db_type'])
  39. elif os.getenv('NAMU_DB') or os.getenv('NAMU_DB_TYPE'):
  40. set_data = {}
  41. if os.getenv('NAMU_DB'):
  42. set_data['db'] = os.getenv('NAMU_DB')
  43. else:
  44. set_data['db'] = 'data'
  45. if os.getenv('NAMU_DB_TYPE'):
  46. set_data['db'] = os.getenv('NAMU_DB_TYPE')
  47. else:
  48. set_data['db'] = 'sqlite'
  49. print('DB name : ' + set_data['db'])
  50. print('DB type : ' + set_data['db_type'])
  51. else:
  52. set_data = {}
  53. normal_db_type = ['sqlite', 'mysql']
  54. print('DB type (' + normal_db_type[0] + ') [' + ', '.join(normal_db_type) + '] : ', end = '')
  55. data_get = str(input())
  56. if data_get == '' or not data_get in normal_db_type:
  57. set_data['db_type'] = 'sqlite'
  58. else:
  59. set_data['db_type'] = data_get
  60. all_src = []
  61. if set_data['db_type'] == 'sqlite':
  62. for i_data in os.listdir("."):
  63. f_src = re.search(r"(.+)\.db$", i_data)
  64. if f_src:
  65. all_src += [f_src.group(1)]
  66. print('DB name (data) [' + ', '.join(all_src) + '] : ', end = '')
  67. data_get = str(input())
  68. if data_get == '':
  69. set_data['db'] = 'data'
  70. else:
  71. set_data['db'] = data_get
  72. with open(os.path.join('data', 'set.json'), 'w', encoding = 'utf8') as f:
  73. f.write(json.dumps(set_data))
  74. data_db_set = {}
  75. data_db_set['name'] = set_data['db']
  76. data_db_set['type'] = set_data['db_type']
  77. if data_db_set['type'] == 'mysql':
  78. if os.path.exists(os.path.join('data', 'mysql.json')):
  79. db_set_list = ['user', 'password', 'host', 'port']
  80. set_data = json.loads(
  81. open(
  82. os.path.join('data', 'mysql.json'),
  83. encoding = 'utf8'
  84. ).read()
  85. )
  86. for i in db_set_list:
  87. if not i in set_data:
  88. os.remove(os.path.join('data', 'mysql.json'))
  89. break
  90. set_data_mysql = set_data
  91. if not os.path.exists(os.path.join('data', 'mysql.json')):
  92. set_data_mysql = {}
  93. print('DB user ID : ', end = '')
  94. set_data_mysql['user'] = str(input())
  95. print('DB password : ', end = '')
  96. set_data_mysql['password'] = str(input())
  97. print('DB host (localhost) : ', end = '')
  98. set_data_mysql['host'] = str(input())
  99. if set_data_mysql['host'] == '':
  100. set_data_mysql['host'] = 'localhost'
  101. print('DB port (3306) : ', end = '')
  102. set_data_mysql['port'] = str(input())
  103. if set_data_mysql['port'] == '':
  104. set_data_mysql['port'] = '3306'
  105. with open(
  106. os.path.join('data', 'mysql.json'),
  107. 'w',
  108. encoding = 'utf8'
  109. ) as f:
  110. f.write(json.dumps(set_data_mysql))
  111. data_db_set['mysql_user'] = set_data_mysql['user']
  112. data_db_set['mysql_pw'] = set_data_mysql['password']
  113. if 'host' in set_data_mysql:
  114. data_db_set['mysql_host'] = set_data_mysql['host']
  115. else:
  116. data_db_set['mysql_host'] = 'localhost'
  117. if 'port' in set_data_mysql:
  118. data_db_set['mysql_port'] = set_data_mysql['port']
  119. else:
  120. data_db_set['mysql_port'] = '3306'
  121. db_data_get(data_db_set['type'])
  122. do_db_set(data_db_set)
  123. load_db = get_db_connect_old(data_db_set)
  124. conn = load_db.db_load()
  125. curs = conn.cursor()
  126. setup_tool = ''
  127. try:
  128. curs.execute(db_change('select data from other where name = "ver"'))
  129. except:
  130. setup_tool = 'init'
  131. if setup_tool != 'init':
  132. ver_set_data = curs.fetchall()
  133. if ver_set_data:
  134. if int(version_list['beta']['c_ver']) > int(ver_set_data[0][0]):
  135. setup_tool = 'update'
  136. else:
  137. setup_tool = 'normal'
  138. else:
  139. setup_tool = 'init'
  140. if setup_tool != 'normal':
  141. # Init-Create_DB
  142. create_data = {}
  143. # 폐지 예정 (data_set으로 통합)
  144. create_data['data'] = ['title', 'data', 'type']
  145. create_data['history'] = ['id', 'title', 'data', 'date', 'ip', 'send', 'leng', 'hide', 'type']
  146. create_data['rc'] = ['id', 'title', 'date', 'type']
  147. create_data['acl'] = ['title', 'data', 'type']
  148. # 개편 예정 (data_link로 변경)
  149. create_data['back'] = ['title', 'link', 'type']
  150. # 폐지 예정 (topic_set으로 통합) [가장 시급]
  151. create_data['rd'] = ['title', 'sub', 'code', 'date', 'band', 'stop', 'agree', 'acl']
  152. create_data['topic'] = ['id', 'data', 'date', 'ip', 'block', 'top', 'code']
  153. # 폐지 예정 (user_set으로 통합)
  154. create_data['rb'] = ['block', 'end', 'today', 'blocker', 'why', 'band', 'login', 'ongoing']
  155. create_data['scan'] = ['user', 'title', 'type']
  156. # 개편 예정 (wiki_set과 wiki_filter과 wiki_vote으로 변경)
  157. create_data['other'] = ['name', 'data', 'coverage']
  158. create_data['html_filter'] = ['html', 'kind', 'plus', 'plus_t']
  159. create_data['vote'] = ['name', 'id', 'subject', 'data', 'user', 'type', 'acl']
  160. # 개편 예정 (auth_list와 auth_log로 변경)
  161. create_data['alist'] = ['name', 'acl']
  162. create_data['re_admin'] = ['who', 'what', 'time']
  163. # 개편 예정 (user_notice와 user_agent로 변경)
  164. create_data['alarm'] = ['name', 'data', 'date']
  165. create_data['ua_d'] = ['name', 'ip', 'ua', 'today', 'sub']
  166. create_data['user_set'] = ['name', 'id', 'data']
  167. for create_table in create_data:
  168. for create in ['test'] + create_data[create_table]:
  169. try:
  170. curs.execute(db_change('select ' + create + ' from ' + create_table + ' limit 1'))
  171. except:
  172. try:
  173. curs.execute(db_change('create table ' + create_table + '(test longtext default "")'))
  174. except:
  175. curs.execute(db_change("alter table " + create_table + " add column " + create + " longtext default ''"))
  176. if setup_tool == 'update':
  177. update(int(ver_set_data[0][0]), set_data)
  178. else:
  179. set_init()
  180. set_init_always(version_list['beta']['c_ver'])
  181. # Init-Route
  182. class EverythingConverter(werkzeug.routing.PathConverter):
  183. regex = '.*?'
  184. class RegexConverter(werkzeug.routing.BaseConverter):
  185. def __init__(self, url_map, *items):
  186. super(RegexConverter, self).__init__(url_map)
  187. self.regex = items[0]
  188. app = flask.Flask(
  189. __name__,
  190. template_folder = './'
  191. )
  192. app.config['JSON_AS_ASCII'] = False
  193. app.config['JSONIFY_PRETTYPRINT_REGULAR'] = True
  194. log = logging.getLogger('werkzeug')
  195. log.setLevel(logging.ERROR)
  196. app.jinja_env.filters['md5_replace'] = md5_replace
  197. app.jinja_env.filters['load_lang'] = load_lang
  198. app.jinja_env.filters['cut_100'] = cut_100
  199. app.url_map.converters['everything'] = EverythingConverter
  200. app.url_map.converters['regex'] = RegexConverter
  201. curs.execute(db_change('select data from other where name = "key"'))
  202. sql_data = curs.fetchall()
  203. app.secret_key = sql_data[0][0]
  204. print('----')
  205. # Init-DB_Data
  206. server_set = {}
  207. server_set_var = {
  208. 'host' : {
  209. 'display' : 'Host',
  210. 'require' : 'conv',
  211. 'default' : '0.0.0.0'
  212. }, 'port' : {
  213. 'display' : 'Port',
  214. 'require' : 'conv',
  215. 'default' : '3000'
  216. }, 'language' : {
  217. 'display' : 'Language',
  218. 'require' : 'select',
  219. 'default' : 'ko-KR',
  220. 'list' : ['ko-KR', 'en-US']
  221. }, 'markup' : {
  222. 'display' : 'Markup',
  223. 'require' : 'select',
  224. 'default' : 'namumark',
  225. 'list' : ['namumark', 'custom', 'raw']
  226. }, 'encode' : {
  227. 'display' : 'Encryption method',
  228. 'require' : 'select',
  229. 'default' : 'sha3',
  230. 'list' : ['sha3', 'sha256']
  231. }
  232. }
  233. server_set_env = {
  234. 'host' : os.getenv('NAMU_HOST'),
  235. 'port' : os.getenv('NAMU_PORT'),
  236. 'language' : os.getenv('NAMU_LANG'),
  237. 'markup' : os.getenv('NAMU_MARKUP'),
  238. 'encode' : os.getenv('NAMU_ENCRYPT')
  239. }
  240. for i in server_set_var:
  241. curs.execute(db_change('select data from other where name = ?'), [i])
  242. server_set_val = curs.fetchall()
  243. if server_set_val:
  244. server_set_val = server_set_val[0][0]
  245. elif server_set_env[i] != None:
  246. server_set_val = server_set_env[i]
  247. else:
  248. if 'list' in server_set_var[i]:
  249. print(server_set_var[i]['display'] + ' (' + server_set_var[i]['default'] + ') [' + ', '.join(server_set_var[i]['list']) + ']' + ' : ', end = '')
  250. else:
  251. print(server_set_var[i]['display'] + ' (' + server_set_var[i]['default'] + ') : ', end = '')
  252. server_set_val = input()
  253. if server_set_val == '':
  254. server_set_val = server_set_var[i]['default']
  255. elif server_set_var[i]['require'] == 'select':
  256. if not server_set_val in server_set_var[i]['list']:
  257. server_set_val = server_set_var[i]['default']
  258. curs.execute(db_change('insert into other (name, data) values (?, ?)'), [i, server_set_val])
  259. print(server_set_var[i]['display'] + ' : ' + server_set_val)
  260. server_set[i] = server_set_val
  261. print('----')
  262. # Init-DB_care
  263. if data_db_set['type'] == 'sqlite':
  264. def back_up(back_time, back_up_where):
  265. print('----')
  266. try:
  267. shutil.copyfile(
  268. data_db_set['name'] + '.db',
  269. back_up_where
  270. )
  271. print('Back up : OK')
  272. except:
  273. print('Back up : Error')
  274. threading.Timer(
  275. 60 * 60 * back_time,
  276. back_up,
  277. [back_time, back_up_where]
  278. ).start()
  279. curs.execute(db_change('select data from other where name = "back_up"'))
  280. back_time = curs.fetchall()
  281. back_time = int(number_check(back_time[0][0])) if back_time else 0
  282. if back_time != 0:
  283. curs.execute(db_change('select data from other where name = "backup_where"'))
  284. back_up_where = curs.fetchall()
  285. if back_up_where and back_up_where[0][0] != '':
  286. back_up_where = back_up_where[0][0]
  287. else:
  288. back_up_where = 'back_' + data_db_set['name'] + '.db'
  289. print('Back up state : ' + str(back_time) + ' hours')
  290. back_up(back_time, back_up_where)
  291. else:
  292. print('Back up state : Turn off')
  293. print('Now running... http://localhost:' + server_set['port'])
  294. conn.commit()
  295. # Init-custom
  296. if os.path.exists('custom.py'):
  297. from custom import custom_run
  298. custom_run(load_db.db_get(), app)
  299. # Func
  300. # Func-inter_wiki
  301. app.route('/inter_wiki', defaults = { 'tool' : 'inter_wiki' })(filter_inter_wiki)
  302. app.route('/inter_wiki/del/<name>', defaults = { 'tool' : 'del_inter_wiki' })(filter_inter_wiki_delete)
  303. app.route('/inter_wiki/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_inter_wiki' })(filter_inter_wiki_add)
  304. app.route('/inter_wiki/add/<name>', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_inter_wiki' })(filter_inter_wiki_add)
  305. app.route('/filter/document/list')(filter_document)
  306. app.route('/filter/document/add/<name>', methods = ['POST', 'GET'])(filter_document_add)
  307. app.route('/filter/document/add', methods = ['POST', 'GET'])(filter_document_add)
  308. app.route('/filter/document/del/<name>')(filter_document_delete)
  309. app.route('/edit_top', defaults = { 'tool' : 'edit_top' })(filter_inter_wiki)
  310. app.route('/edit_top/del/<name>', defaults = { 'tool' : 'del_edit_top' })(filter_inter_wiki_delete)
  311. app.route('/edit_top/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_edit_top' })(filter_inter_wiki_add)
  312. app.route('/image_license', defaults = { 'tool' : 'image_license' })(filter_inter_wiki)
  313. app.route('/image_license/del/<name>', defaults = { 'tool' : 'del_image_license' })(filter_inter_wiki_delete)
  314. app.route('/image_license/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_image_license' })(filter_inter_wiki_add)
  315. app.route('/edit_filter', defaults = { 'tool' : 'edit_filter' })(filter_inter_wiki)
  316. app.route('/edit_filter/del/<name>', defaults = { 'tool' : 'del_edit_filter' })(filter_inter_wiki_delete)
  317. app.route('/edit_filter/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_edit_filter' })(filter_inter_wiki_add)
  318. app.route('/edit_filter/add/<name>', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_edit_filter' })(filter_inter_wiki_add)
  319. app.route('/email_filter', defaults = { 'tool' : 'email_filter' })(filter_inter_wiki)
  320. app.route('/email_filter/del/<name>', defaults = { 'tool' : 'del_email_filter' })(filter_inter_wiki_delete)
  321. app.route('/email_filter/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_email_filter' })(filter_inter_wiki_add)
  322. app.route('/file_filter', defaults = { 'tool' : 'file_filter' })(filter_inter_wiki)
  323. app.route('/file_filter/del/<name>', defaults = { 'tool' : 'del_file_filter' })(filter_inter_wiki_delete)
  324. app.route('/file_filter/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_file_filter' })(filter_inter_wiki_add)
  325. app.route('/name_filter', defaults = { 'tool' : 'name_filter' })(filter_inter_wiki)
  326. app.route('/name_filter/del/<name>', defaults = { 'tool' : 'del_name_filter' })(filter_inter_wiki_delete)
  327. app.route('/name_filter/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_name_filter' })(filter_inter_wiki_add)
  328. app.route('/extension_filter', defaults = { 'tool' : 'extension_filter' })(filter_inter_wiki)
  329. app.route('/extension_filter/del/<name>', defaults = { 'tool' : 'del_extension_filter' })(filter_inter_wiki_delete)
  330. app.route('/extension_filter/add', methods = ['POST', 'GET'], defaults = { 'tool' : 'plus_extension_filter' })(filter_inter_wiki_add)
  331. # Func-list
  332. # /list/document/old
  333. app.route('/old_page')(list_old_page)
  334. # /list/document/acl
  335. @app.route('/acl_list')
  336. def list_acl():
  337. return list_acl_2(load_db.db_get())
  338. # /list/document/acl/add
  339. @app.route('/acl/<everything:name>', methods = ['POST', 'GET'])
  340. def give_acl(name = None):
  341. return give_acl_2(load_db.db_get(), name)
  342. # /list/document/need
  343. @app.route('/please')
  344. def list_please():
  345. return list_please_2(load_db.db_get())
  346. # /list/document/all
  347. @app.route('/title_index')
  348. def list_title_index():
  349. return list_title_index_2(load_db.db_get())
  350. # /list/document/long
  351. @app.route('/long_page')
  352. def list_long_page():
  353. return list_long_page_2(load_db.db_get(), 'long_page')
  354. # /list/document/short
  355. @app.route('/short_page')
  356. def list_short_page():
  357. return list_long_page_2(load_db.db_get(), 'short_page')
  358. # /list/file
  359. @app.route('/image_file_list')
  360. def list_image_file():
  361. return list_image_file_2(load_db.db_get())
  362. # /list/admin
  363. # /list/admin/list
  364. @app.route('/admin_list')
  365. def list_admin():
  366. return list_admin_2(load_db.db_get())
  367. # /list/admin/auth_use
  368. @app.route('/admin_log', methods = ['POST', 'GET'])
  369. def list_admin_use():
  370. return list_admin_use_2(load_db.db_get())
  371. # /list/user
  372. @app.route('/user_log')
  373. def list_user():
  374. return list_user_2(load_db.db_get())
  375. # /list/user/check
  376. @app.route('/check/<name>')
  377. def give_user_check(name = None):
  378. return give_user_check_2(load_db.db_get(), name)
  379. # /list/user/check/delete
  380. @app.route('/check_delete', methods = ['POST', 'GET'])
  381. def give_user_check_delete():
  382. return give_user_check_delete_2(load_db.db_get())
  383. # Func-auth
  384. # /auth/give
  385. # /auth/give/<name>
  386. @app.route('/admin/<name>', methods = ['POST', 'GET'])
  387. def give_admin(name = None):
  388. return give_admin_2(load_db.db_get(), name)
  389. # /auth/give
  390. # /auth/give/<name>
  391. @app.route('/ban', methods = ['POST', 'GET'])
  392. @app.route('/ban/<name>', methods = ['POST', 'GET'])
  393. def give_user_ban(name = None):
  394. return give_user_ban_2(load_db.db_get(), name)
  395. # /auth/list
  396. @app.route('/admin_group')
  397. def list_admin_group():
  398. return list_admin_group_2(load_db.db_get())
  399. # /auth/list/add/<name>
  400. @app.route('/admin_plus/<name>', methods = ['POST', 'GET'])
  401. def give_admin_groups(name = None):
  402. return give_admin_groups_2(load_db.db_get(), name)
  403. # /auth/list/delete/<name>
  404. @app.route('/delete_admin_group/<name>', methods = ['POST', 'GET'])
  405. def give_delete_admin_group(name = None):
  406. return give_delete_admin_group_2(load_db.db_get(), name)
  407. # /auth/history
  408. # ongoing 반영 필요
  409. @app.route('/block_log')
  410. @app.route('/block_log/<regex("user"):tool>/<name>')
  411. @app.route('/block_log/<regex("admin"):tool>/<name>')
  412. def recent_block(name = 'Test', tool = 'all'):
  413. return recent_block_2(load_db.db_get(), name, tool)
  414. # Func-history
  415. @app.route('/recent_change')
  416. @app.route('/recent_changes')
  417. def recent_change(name = None):
  418. return recent_change_2(load_db.db_get(), name, '')
  419. @app.route('/record/<name>')
  420. def recent_record(name = None):
  421. return recent_change_2(load_db.db_get(), name, 'record')
  422. @app.route('/history/<everything:name>', methods = ['POST', 'GET'])
  423. def recent_history(name = None):
  424. return recent_change_2(load_db.db_get(), name, 'history')
  425. @app.route('/history/tool/<int(signed = True):rev>/<everything:name>')
  426. def recent_history_tool(name = 'Test', rev = 1):
  427. return recent_history_tool_2(load_db.db_get(), name, rev)
  428. @app.route('/history/delete/<int(signed = True):rev>/<everything:name>', methods = ['POST', 'GET'])
  429. def recent_history_delete(name = 'Test', rev = 1):
  430. return recent_history_delete_2(load_db.db_get(), name, rev)
  431. @app.route('/history/hidden/<int(signed = True):rev>/<everything:name>')
  432. def recent_history_hidden(name = 'Test', rev = 1):
  433. return recent_history_hidden_2(load_db.db_get(), name, rev)
  434. @app.route('/history/send/<int(signed = True):rev>/<everything:name>', methods = ['POST', 'GET'])
  435. def recent_history_send(name = 'Test', rev = 1):
  436. return recent_history_send_2(load_db.db_get(), name, rev)
  437. @app.route('/history/reset/<everything:name>', methods = ['POST', 'GET'])
  438. def recent_history_reset(name = 'Test'):
  439. return recent_history_reset_2(load_db.db_get(), name)
  440. @app.route('/history/add/<everything:name>', methods = ['POST', 'GET'])
  441. def recent_history_add(name = 'Test'):
  442. return recent_history_add_2(load_db.db_get(), name)
  443. @app.route('/record/reset/<name>', methods = ['POST', 'GET'])
  444. def recent_record_reset(name = 'Test'):
  445. return recent_record_reset_2(load_db.db_get(), name)
  446. @app.route('/record/topic/<name>')
  447. def recent_record_topic(name = 'Test'):
  448. return recent_record_topic_2(load_db.db_get(), name)
  449. # 거처를 고심중
  450. @app.route('/app_submit', methods = ['POST', 'GET'])
  451. def recent_app_submit():
  452. return recent_app_submit_2(load_db.db_get())
  453. # Func-search
  454. @app.route('/search', methods=['POST'])
  455. def search():
  456. return search_2(load_db.db_get())
  457. @app.route('/goto', methods=['POST'])
  458. @app.route('/goto/<everything:name>', methods=['POST'])
  459. def search_goto(name = 'test'):
  460. return search_goto_2(load_db.db_get(), name)
  461. @app.route('/search/<everything:name>')
  462. def search_deep(name = 'test'):
  463. return search_deep_2(load_db.db_get(), name)
  464. # Func-view
  465. @app.route('/xref/<everything:name>')
  466. def view_xref(name = 'Test'):
  467. return view_xref_2(load_db.db_get(), name)
  468. @app.route('/xref/this/<everything:name>')
  469. def view_xref_this(name = 'Test'):
  470. return view_xref_2(load_db.db_get(), name, xref_type = '2')
  471. @app.route('/raw/<everything:name>')
  472. @app.route('/thread/<int:topic_num>/raw/<int:num>')
  473. def view_raw(name = None, topic_num = None, num = None):
  474. return view_raw_2(load_db.db_get(), name, topic_num, num)
  475. @app.route('/diff/<int(signed = True):num_a>/<int(signed = True):num_b>/<everything:name>')
  476. def view_diff(name = 'Test', num_a = 1, num_b = 1):
  477. return view_diff_2(load_db.db_get(), name, num_a, num_b)
  478. @app.route('/down/<everything:name>')
  479. def view_down(name = None):
  480. return view_down_2(load_db.db_get(), name)
  481. @app.route('/w/<everything:name>/doc_rev/<int(signed = True):doc_rev>')
  482. @app.route('/w/<everything:name>/doc_from/<everything:doc_from>')
  483. @app.route('/w/<everything:name>')
  484. def view_read(name = 'Test', doc_rev = 0, doc_from = ''):
  485. return view_read_2(load_db.db_get(), name, doc_rev, doc_from)
  486. # Func-edit
  487. @app.route('/revert/<everything:name>', methods = ['POST', 'GET'])
  488. def edit_revert(name = None):
  489. return edit_revert_2(load_db.db_get(), name)
  490. app.route('/edit/<everything:name>', methods = ['POST', 'GET'])(edit)
  491. app.route('/edit/<everything:name>/doc_from/<everything:name_load>', methods = ['POST', 'GET'])(edit)
  492. app.route('/edit/<everything:name>/doc_section/<int:section>', methods = ['POST', 'GET'])(edit)
  493. # 개편 예정
  494. @app.route('/backlink_reset/<everything:name>')
  495. def edit_backlink_reset(name = 'Test'):
  496. return edit_backlink_reset_2(load_db.db_get(), name)
  497. @app.route('/delete/<everything:name>', methods = ['POST', 'GET'])
  498. def edit_delete(name = None):
  499. return edit_delete_2(load_db.db_get(), name)
  500. @app.route('/delete/doc_file/<everything:name>', methods = ['POST', 'GET'])
  501. def edit_delete_file(name = 'test.jpg'):
  502. return edit_delete_file_2(load_db.db_get(), name)
  503. @app.route('/delete/doc_mutiple', methods = ['POST', 'GET'])
  504. def edit_delete_mutiple():
  505. return edit_delete_mutiple_2(load_db.db_get())
  506. @app.route('/move/<everything:name>', methods = ['POST', 'GET'])
  507. def edit_move(name = None):
  508. return edit_move_2(load_db.db_get(), name)
  509. # Func-topic
  510. @app.route('/recent_discuss')
  511. def recent_discuss():
  512. return recent_discuss_2(load_db.db_get(), 'normal')
  513. @app.route('/recent_discuss/close')
  514. def recent_discuss_close():
  515. return recent_discuss_2(load_db.db_get(), 'close')
  516. @app.route('/recent_discuss/open')
  517. def recent_discuss_open():
  518. return recent_discuss_2(load_db.db_get(), 'open')
  519. @app.route('/thread/<int:topic_num>/b/<int:num>')
  520. def topic_block(topic_num = 1, num = 1):
  521. return topic_block_2(load_db.db_get(), topic_num, num)
  522. @app.route('/thread/<int:topic_num>/notice/<int:num>')
  523. def topic_top(topic_num = 1, num = 1):
  524. return topic_top_2(load_db.db_get(), topic_num, num)
  525. @app.route('/thread/<int:topic_num>/setting', methods = ['POST', 'GET'])
  526. def topic_stop(topic_num = 1):
  527. return topic_stop_2(load_db.db_get(), topic_num)
  528. @app.route('/thread/<int:topic_num>/acl', methods = ['POST', 'GET'])
  529. def topic_acl(topic_num = 1):
  530. return topic_acl_2(load_db.db_get(), topic_num)
  531. @app.route('/thread/<int:topic_num>/delete', methods = ['POST', 'GET'])
  532. def topic_delete(topic_num = 1):
  533. return topic_delete_2(load_db.db_get(), topic_num)
  534. @app.route('/thread/<int:topic_num>/tool')
  535. def topic_tool(topic_num = 1):
  536. return topic_tool_2(load_db.db_get(), topic_num)
  537. @app.route('/thread/<int:topic_num>/change', methods = ['POST', 'GET'])
  538. def topic_change(topic_num = 1):
  539. return topic_change_2(load_db.db_get(), topic_num)
  540. @app.route('/thread/<int:topic_num>/admin/<int:num>')
  541. def topic_admin(topic_num = 1, num = 1):
  542. return topic_admin_2(load_db.db_get(), topic_num, num)
  543. app.route('/thread/<int:topic_num>', methods = ['POST', 'GET'])(topic)
  544. app.route('/topic/<everything:name>', methods = ['POST', 'GET'])(topic_close_list)
  545. # Func-user
  546. @app.route('/change', methods = ['POST', 'GET'])
  547. def user_setting():
  548. return user_setting_2(load_db.db_get(), server_set_var)
  549. @app.route('/change/email', methods = ['POST', 'GET'])
  550. def user_setting_email():
  551. return user_setting_email_2(load_db.db_get())
  552. app.route('/change/email/delete')(user_setting_email_delete)
  553. @app.route('/change/email/check', methods = ['POST', 'GET'])
  554. def user_setting_email_check():
  555. return user_setting_email_check_2(load_db.db_get())
  556. app.route('/change/key')(user_setting_key)
  557. app.route('/change/key/delete')(user_setting_key_delete)
  558. @app.route('/change/pw', methods = ['POST', 'GET'])
  559. def user_setting_pw_change():
  560. return user_setting_pw_change_2(load_db.db_get())
  561. @app.route('/change/head', methods=['GET', 'POST'])
  562. def user_setting_head():
  563. return user_setting_head_2(load_db.db_get())
  564. @app.route('/user')
  565. @app.route('/user/<name>')
  566. def user_info(name = ''):
  567. return user_info_2(load_db.db_get(), name)
  568. @app.route('/count')
  569. @app.route('/count/<name>')
  570. def user_count_edit(name = None):
  571. return user_count_edit_2(load_db.db_get(), name)
  572. app.route('/alarm')(user_alarm)
  573. app.route('/alarm/delete')(user_alarm_del)
  574. @app.route('/watch_list')
  575. def user_watch_list():
  576. return user_watch_list_2(load_db.db_get(), 'watch_list')
  577. @app.route('/watch_list/<everything:name>')
  578. def user_watch_list_name(name = 'Test'):
  579. return user_watch_list_name_2(load_db.db_get(), 'watch_list', name)
  580. @app.route('/star_doc')
  581. def user_star_doc():
  582. return user_watch_list_2(load_db.db_get(), 'star_doc')
  583. @app.route('/star_doc/<everything:name>')
  584. def user_star_doc_name(name = 'Test'):
  585. return user_watch_list_name_2(load_db.db_get(), 'star_doc', name)
  586. # Func-login
  587. # 개편 예정
  588. # login -> login/2fa -> login/2fa/email with login_id
  589. # register -> register/email -> regiter/email/check with reg_id
  590. # pass_find -> pass_find/email with find_id
  591. @app.route('/login', methods = ['POST', 'GET'])
  592. def login_login():
  593. return login_login_2(load_db.db_get())
  594. @app.route('/login/2fa', methods = ['POST', 'GET'])
  595. def login_login_2fa():
  596. return login_login_2fa_2(load_db.db_get())
  597. @app.route('/register', methods = ['POST', 'GET'])
  598. def login_register():
  599. return login_register_2(load_db.db_get())
  600. @app.route('/register/email', methods = ['POST', 'GET'])
  601. def login_register_email():
  602. return login_register_email_2(load_db.db_get())
  603. @app.route('/register/email/check', methods = ['POST', 'GET'])
  604. def login_register_email_check():
  605. return login_register_email_check_2(load_db.db_get())
  606. @app.route('/register/submit', methods = ['POST', 'GET'])
  607. def login_register_submit():
  608. return login_register_submit_2(load_db.db_get())
  609. app.route('/login/find')(login_find)
  610. app.route('/login/find/key', methods = ['POST', 'GET'])(login_find_key)
  611. app.route('/login/find/email', methods = ['POST', 'GET'], defaults = { 'tool' : 'pass_find' })(login_find_email)
  612. app.route('/login/find/email/check', methods = ['POST', 'GET'], defaults = { 'tool' : 'check_key' })(login_find_email_check)
  613. @app.route('/logout')
  614. def login_logout():
  615. return login_logout_2(load_db.db_get())
  616. # Func-vote
  617. @app.route('/vote/<int:num>', methods = ['POST', 'GET'])
  618. def vote_select(num = 1):
  619. return vote_select_2(load_db.db_get(), str(num))
  620. @app.route('/vote/end/<int:num>')
  621. def vote_end(num = 1):
  622. return vote_end_2(load_db.db_get(), str(num))
  623. @app.route('/vote/close/<int:num>')
  624. def vote_close(num = 1):
  625. return vote_close_2(load_db.db_get(), str(num))
  626. @app.route('/vote')
  627. @app.route('/vote/list')
  628. @app.route('/vote/list/<int:num>')
  629. def vote_list(num = 1):
  630. return vote_list_2(load_db.db_get(), 'normal', num)
  631. @app.route('/vote/list/close')
  632. @app.route('/vote/list/close/<int:num>')
  633. def vote_list_close(num = 1):
  634. return vote_list_2(load_db.db_get(), 'close', num)
  635. @app.route('/vote/add', methods = ['POST', 'GET'])
  636. def vote_add():
  637. return vote_add_2(load_db.db_get())
  638. # Func-api
  639. app.route('/api/w/<everything:name>/doc_tool/<tool>/doc_rev/<int(signed = True):rev>')(api_w)
  640. app.route('/api/w/<everything:name>/doc_tool/<tool>', methods = ['GET', 'POST'])(api_w)
  641. app.route('/api/w/<everything:name>', methods = ['GET', 'POST'])(api_w)
  642. app.route('/api/raw/<everything:name>')(api_raw)
  643. app.route('/api/version', defaults = { 'version_list' : version_list })(api_version)
  644. app.route('/api/skin_info')(api_skin_info)
  645. app.route('/api/skin_info/<name>')(api_skin_info)
  646. app.route('/api/markup')(api_markup)
  647. app.route('/api/user_info/<name>')(api_user_info)
  648. app.route('/api/setting/<name>')(api_setting)
  649. app.route('/api/thread/<int:topic_num>/<tool>/<int:num>')(api_topic_sub)
  650. app.route('/api/thread/<int:topic_num>/<tool>')(api_topic_sub)
  651. app.route('/api/thread/<int:topic_num>')(api_topic_sub)
  652. app.route('/api/search/<everything:name>/doc_num/<int:num>/<int:page>')(api_search)
  653. app.route('/api/search/<everything:name>')(api_search)
  654. app.route('/api/recent_change/<int:num>')(api_recent_change)
  655. app.route('/api/recent_change')(api_recent_change)
  656. # recent_changes -> recent_change
  657. app.route('/api/recent_changes')(api_recent_change)
  658. app.route('/api/recent_discuss/<get_type>/<int:num>')(api_recent_discuss)
  659. app.route('/api/recent_discuss/<int:num>')(api_recent_discuss)
  660. app.route('/api/recent_discuss')(api_recent_discuss)
  661. app.route('/api/sha224/<everything:data>', methods = ['POST', 'GET'])(api_sha224)
  662. app.route('/api/title_index')(api_title_index)
  663. app.route('/api/image/<everything:name>', methods = ['POST', 'GET'])(api_image_view)
  664. # 이건 API 영역이 아닌 것 같아서 고심 중
  665. app.route('/api/sitemap.xml')(api_sitemap)
  666. # Func-main
  667. # 여기도 전반적인 조정 시행 예정
  668. app.route('/other')(main_tool_other)
  669. app.route('/manager', methods = ['POST', 'GET'])(main_tool_admin)
  670. app.route('/manager/<int:num>', methods = ['POST', 'GET'])(main_tool_admin)
  671. app.route('/manager/<int:num>/<add_2>', methods = ['POST', 'GET'])(main_tool_admin)
  672. app.route('/random')(main_func_random)
  673. app.route('/upload', methods = ['POST', 'GET'])(main_func_upload)
  674. app.route('/setting', defaults = { 'db_set' : data_db_set['type'] })(main_func_setting)
  675. app.route('/setting/<int:num>', methods = ['POST', 'GET'], defaults = { 'db_set' : data_db_set['type'] })(main_func_setting)
  676. app.route('/skin_set')(main_func_skin_set)
  677. app.route('/main_skin_set')(main_func_skin_set)
  678. app.route('/easter_egg.xml')(main_func_easter_egg)
  679. # views -> view
  680. app.route('/view/<everything:name>')(main_view)
  681. app.route('/views/<everything:name>')(main_view)
  682. app.route('/image/<everything:name>')(main_view_image)
  683. # 조정 계획 중
  684. app.route('/<regex("[^.]+\.(?:txt|xml)"):data>')(main_view_file)
  685. app.route('/shutdown', methods = ['POST', 'GET'])(main_sys_shutdown)
  686. app.route('/restart', methods = ['POST', 'GET'])(main_sys_restart)
  687. app.route('/update', methods = ['POST', 'GET'])(main_sys_update)
  688. app.errorhandler(404)(main_error_404)
  689. if __name__ == "__main__":
  690. waitress.serve(
  691. app,
  692. host = server_set['host'],
  693. port = int(server_set['port']),
  694. threads = 1
  695. )