2
0

app.py 30 KB

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