2
0

view_w.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. from .tool.func import *
  2. from .go_api_w_render import api_w_render
  3. async def view_w(name = 'Test', do_type = '', doc_rev = ''):
  4. with get_db_connect() as conn:
  5. curs = conn.cursor()
  6. sub = 0
  7. history_color = 0
  8. menu = []
  9. user_doc = ''
  10. category_total = ''
  11. file_data = ''
  12. doc_type = ''
  13. redirect_to = None
  14. now_time = get_time()
  15. ip = ip_check()
  16. uppage = re.sub(r"/([^/]+)$", '', name)
  17. uppage = 0 if uppage == name else uppage
  18. curs.execute(db_change("select sub from rd where title = ? and not stop = 'O' order by date desc"), [name])
  19. topic = 1 if curs.fetchall() else 0
  20. curs.execute(db_change("select title from data where title like ?"), [name + '/%'])
  21. down = 1 if curs.fetchall() else 0
  22. if re.search(r'^category:', name):
  23. name_view = name
  24. doc_type = 'category'
  25. category_doc = ''
  26. category_sub = ''
  27. count_sub_category = 0
  28. count_category = 0
  29. curs.execute(db_change("select distinct link from back where title = ? and type = 'cat' order by link asc"), [name])
  30. category_sql = curs.fetchall()
  31. for data in category_sql:
  32. link_view = data[0]
  33. if get_main_skin_set(conn, flask.session, 'main_css_category_change_title', ip) != 'off':
  34. curs.execute(db_change("select data from back where title = ? and link = ? and type = 'cat_view' limit 1"), [name, data[0]])
  35. db_data = curs.fetchall()
  36. if db_data and db_data[0][0] != '':
  37. link_view = db_data[0][0]
  38. link_blur = ''
  39. curs.execute(db_change("select data from back where title = ? and link = ? and type = 'cat_blur' limit 1"), [name, data[0]])
  40. db_data = curs.fetchall()
  41. if db_data:
  42. link_blur = 'opennamu_category_blur'
  43. if data[0].startswith('category:'):
  44. category_sub += '<li><a class="' + link_blur + '" href="/w/' + url_pas(data[0]) + '">' + html.escape(link_view) + '</a></li>'
  45. count_sub_category += 1
  46. else:
  47. category_doc += '' + \
  48. '<li>' + \
  49. '<a class="' + link_blur + '" href="/w/' + url_pas(data[0]) + '">' + html.escape(link_view) + '</a> ' + \
  50. '<a class="opennamu_link_inter" href="/xref/' + url_pas(data[0]) + '">(' + await get_lang('backlink') + ')</a>' + \
  51. '</li>' + \
  52. ''
  53. count_category += 1
  54. if category_sub != '':
  55. category_total += '' + \
  56. '<h2 id="cate_under">' + await get_lang('under_category') + '</h2>' + \
  57. '<ul>' + \
  58. '<li>' + await get_lang('all') + ' : ' + str(count_sub_category) + '</li>' + \
  59. category_sub + \
  60. '</ul>' + \
  61. ''
  62. if category_doc != '':
  63. category_total += '' + \
  64. '<h2 id="cate_normal">' + await get_lang('category_title') + '</h2>' + \
  65. '<ul>' + \
  66. '<li>' + await get_lang('all') + ' : ' + str(count_category) + '</li>' + \
  67. category_doc + \
  68. '</ul>' + \
  69. ''
  70. elif re.search(r"^user:([^/]*)", name):
  71. name_view = name
  72. doc_type = 'user'
  73. user_name = ''
  74. match = re.search(r"^user:([^/]*)", name)
  75. if match:
  76. user_name = html.escape(match.group(1))
  77. user_doc = ''
  78. # S admin or owner 특수 틀 추가
  79. if await acl_check(tool = 'all_admin_auth', ip = user_name) != 1:
  80. if await acl_check(tool = 'owner_auth', ip = user_name) != 1:
  81. curs.execute(db_change('select data from other where name = "phrase_user_page_owner"'))
  82. db_data = curs.fetchall()
  83. if db_data and db_data[0][0] != '':
  84. user_doc += db_data[0][0] + '<br>'
  85. else:
  86. curs.execute(db_change('select data from other where name = "phrase_user_page_admin"'))
  87. db_data = curs.fetchall()
  88. if db_data and db_data[0][0] != '':
  89. user_doc += db_data[0][0] + '<br>'
  90. else:
  91. curs.execute(db_change('select data from other where name = "phrase_user_page_admin"'))
  92. db_data = curs.fetchall()
  93. if db_data and db_data[0][0] != '':
  94. user_doc += db_data[0][0] + '<br>'
  95. # E
  96. user_doc += '''
  97. <div id="opennamu_get_user_info">''' + html.escape(user_name) + '''</div>
  98. <hr class="main_hr">
  99. '''
  100. if name == 'user:' + user_name:
  101. menu += [['w/' + url_pas(name) + '/' + url_pas(now_time.split()[0]), await get_lang('today_doc')]]
  102. elif re.search(r"^file:", name):
  103. curs.execute(db_change('select id from history where title = ? order by date desc limit 1'), [name])
  104. db_data = curs.fetchall()
  105. rev = db_data[0][0] if db_data else '1'
  106. name_view = name
  107. doc_type = 'file'
  108. mime_type = re.search(r'([^.]+)$', name)
  109. if mime_type:
  110. mime_type = mime_type.group(1)
  111. else:
  112. mime_type = 'jpg'
  113. file_name = re.sub(r'\.([^.]+)$', '', name)
  114. file_name = re.sub(r'^file:', '', file_name)
  115. file_all_name = sha224_replace(file_name) + '.' + mime_type
  116. file_path_name = os.path.join(load_image_url(conn), file_all_name)
  117. if os.path.exists(file_path_name):
  118. try:
  119. img = Image.open(file_path_name)
  120. width, height = img.size
  121. file_res = str(width) + 'x' + str(height)
  122. except:
  123. file_res = 'Vector'
  124. file_size = str(round(os.path.getsize(file_path_name) / 1000, 1))
  125. file_data = '''
  126. <img src="/image/''' + url_pas(file_all_name) + '''.cache_v''' + rev + '''">
  127. <h2>''' + await get_lang('data') + '''</h2>
  128. <table>
  129. <tr><td>''' + await get_lang('url') + '''</td><td><a href="/image/''' + url_pas(file_all_name) + '''">''' + await get_lang('link') + '''</a></td></tr>
  130. <tr><td>''' + await get_lang('volume') + '''</td><td>''' + file_size + '''KB</td></tr>
  131. <tr><td>''' + await get_lang('resolution') + '''</td><td>''' + file_res + '''</td></tr>
  132. </table>
  133. <h2>''' + await get_lang('content') + '''</h2>
  134. '''
  135. menu += [['delete_file/' + url_pas(name), await get_lang('file_delete')]]
  136. else:
  137. file_data = ''
  138. else:
  139. curs.execute(db_change("select link from back where title = ? and type = 'include' limit 1"), [name])
  140. doc_type = 'include' if curs.fetchall() else doc_type
  141. curs.execute(db_change("select title, data from back where link = ? and type = 'redirect' limit 1"), [name])
  142. db_data = curs.fetchall()
  143. if db_data:
  144. doc_type = 'redirect'
  145. curs.execute(db_change("select title from data where title = ?"), [db_data[0][0]])
  146. if curs.fetchall():
  147. redirect_to = url_pas(db_data[0][0]) + db_data[0][1]
  148. name_view = name
  149. if doc_rev == '':
  150. doc_data = await python_to_golang("get_json", path = "v2/raw/" + url_pas(name))
  151. else:
  152. doc_data = await python_to_golang("get_json", path = "v2/raw_rev/" + str(doc_rev) + '/' + url_pas(name))
  153. length_doc_data = 0
  154. if doc_data["response"] == "ok":
  155. render_data = await api_w_render(name, request_method = 'POST', request_data = {
  156. 'name' : name,
  157. 'data' : doc_data["data"]
  158. })
  159. end_data = render_data["data"] + '<script>document.addEventListener("DOMContentLoaded", function() {' + render_data["js_data"] + '});</script>'
  160. length_doc_data = len(doc_data["data"])
  161. else:
  162. end_data = ''
  163. if doc_rev == '':
  164. await python_to_golang("get_json", path = "v2/page_view_post/" + url_pas(name))
  165. curs.execute(db_change("select data from data where title = ?"), [name])
  166. else:
  167. curs.execute(db_change("select data from history where title = ? and id = ?"), [name, doc_rev])
  168. data = curs.fetchall()
  169. description = ''
  170. if await acl_check(name, 'render') == 1:
  171. response_data = 401
  172. curs.execute(db_change('select data from other where name = "error_401"'))
  173. sql_d = curs.fetchall()
  174. if sql_d and sql_d[0][0] != '':
  175. end_data = '<h2>' + await get_lang('error') + '</h2><ul><li>' + sql_d[0][0] + '</li></ul>'
  176. else:
  177. end_data = '<h2>' + await get_lang('error') + '</h2><ul><li>' + await get_lang('authority_error') + '</li></ul>'
  178. elif not data:
  179. response_data = 404
  180. curs.execute(db_change('select data from other where name = "error_404"'))
  181. db_data = curs.fetchall()
  182. if db_data and db_data[0][0] != '':
  183. end_data = '<h2>' + await get_lang('error') + '</h2><ul><li>' + db_data[0][0] + '</li></ul>'
  184. else:
  185. end_data = '<h2>' + await get_lang('error') + '</h2><ul><li>' + await get_lang('document_404_error') + '</li></ul>'
  186. curs.execute(db_change('select ip from history where title = ? limit 1'), [name])
  187. db_data = curs.fetchall()
  188. history_color = 1 if db_data else 0
  189. else:
  190. response_data = 200
  191. description = data[0][0].replace('\r', '').replace('\n', ' ')[0:200]
  192. curs.execute(db_change("select title from acl where title = ?"), [name])
  193. acl = 1 if curs.fetchall() else 0
  194. menu_acl = 1 if await acl_check(name, 'document_edit') == 1 else 0
  195. if response_data == 404:
  196. menu += [['edit/' + url_pas(name), await get_lang('create'), menu_acl]]
  197. else:
  198. menu += [['edit/' + url_pas(name), await get_lang('edit'), menu_acl]]
  199. menu += [
  200. ['topic/' + url_pas(name), await get_lang('discussion'), topic],
  201. ['history/' + url_pas(name), await get_lang('history'), history_color],
  202. ['xref/' + url_pas(name), await get_lang('backlink')],
  203. ['acl/' + url_pas(name), await get_lang('setting'), acl],
  204. ]
  205. if flask.session and 'lastest_document' in flask.session:
  206. if type(flask.session['lastest_document']) != type([]):
  207. flask.session['lastest_document'] = []
  208. else:
  209. flask.session['lastest_document'] = []
  210. if do_type == 'from':
  211. menu += [['w/' + url_pas(name), await get_lang('pass')]]
  212. last_page = ''
  213. for for_a in reversed(range(0, len(flask.session['lastest_document']))):
  214. last_page = flask.session['lastest_document'][for_a]
  215. curs.execute(db_change("select link from back where (title = ? or link = ?) and type = 'redirect' limit 1"), [last_page, last_page])
  216. if curs.fetchall():
  217. break
  218. if last_page != name:
  219. redirect_text = '{0} ➤ {1}'
  220. curs.execute(db_change('select data from other where name = "redirect_text"'))
  221. db_data = curs.fetchall()
  222. if db_data and db_data[0][0] != '':
  223. redirect_text = db_data[0][0]
  224. try:
  225. redirect_text = redirect_text.format('<a href="/w_from/' + url_pas(last_page) + '">' + html.escape(last_page) + '</a>', '<b>' + html.escape(name) + '</b>')
  226. except:
  227. redirect_text = '{0} ➤ {1}'
  228. redirect_text = redirect_text.format('<a href="/w_from/' + url_pas(last_page) + '">' + html.escape(last_page) + '</a>', '<b>' + html.escape(name) + '</b>')
  229. end_data = '''
  230. <div class="opennamu_redirect" id="redirect">
  231. ''' + redirect_text + '''
  232. </div>
  233. <hr class="main_hr">
  234. ''' + end_data
  235. if len(flask.session['lastest_document']) >= 10:
  236. flask.session['lastest_document'] = flask.session['lastest_document'][-9:] + [name]
  237. else:
  238. flask.session['lastest_document'] += [name]
  239. flask.session['lastest_document'] = list(reversed(dict.fromkeys(reversed(flask.session['lastest_document']))))
  240. if redirect_to and do_type != 'from':
  241. return redirect(conn, '/w_from/' + redirect_to)
  242. view_history_on = get_main_skin_set(conn, flask.session, 'main_css_view_history', ip)
  243. if view_history_on == 'on':
  244. end_data = '' + \
  245. '<div class="opennamu_trace">' + \
  246. '<a class="opennamu_trace_button" href="javascript:opennamu_do_trace_spread();"> (+)</a>' + \
  247. await get_lang('trace') + ' : ' + \
  248. ' ← '.join(
  249. [
  250. '<a href="/w/' + url_pas(for_a) + '">' + html.escape(for_a) + '</a>'
  251. for for_a in reversed(flask.session['lastest_document'])
  252. ]
  253. ) + \
  254. '</div>' + \
  255. '<hr class="main_hr">' + \
  256. '' + end_data
  257. if uppage != 0:
  258. menu += [['w/' + url_pas(uppage), await get_lang('upper')]]
  259. if down:
  260. menu += [['down/' + url_pas(name), await get_lang('sub')]]
  261. curs.execute(db_change("select set_data from data_set where doc_name = ? and set_name = 'last_edit'"), [name])
  262. r_date = curs.fetchall()
  263. r_date = r_date[0][0] if r_date else 0
  264. div = file_data + user_doc + end_data + category_total
  265. if doc_type == '':
  266. curs.execute(db_change('select data from other where name = "outdated_doc_warning_date"'))
  267. db_data = curs.fetchall()
  268. if db_data and db_data[0][0] != '' and r_date != 0:
  269. time_1 = datetime.datetime.strptime(r_date, '%Y-%m-%d %H:%M:%S') + datetime.timedelta(days = int(number_check(db_data[0][0])))
  270. time_2 = datetime.datetime.strptime(now_time, '%Y-%m-%d %H:%M:%S')
  271. if time_2 > time_1:
  272. curs.execute(db_change('select data from other where name = "outdated_doc_warning"'))
  273. db_data = curs.fetchall()
  274. div = (db_data[0][0] if db_data and db_data[0][0] != '' else await get_lang('old_page_warning')) + '<hr class="main_hr">' + div
  275. curs.execute(db_change("select data from other where name = 'body'"))
  276. body = curs.fetchall()
  277. div = (body[0][0] + div) if body else div
  278. curs.execute(db_change("select data from other where name = 'bottom_body'"))
  279. body = curs.fetchall()
  280. div += body[0][0] if body else ''
  281. curs.execute(db_change("select set_data from data_set where doc_name = ? and set_name = 'document_top'"), [name])
  282. body = curs.fetchall()
  283. div = (body[0][0] + div) if body else div
  284. if ip_or_user(ip) == 0:
  285. curs.execute(db_change("select data from user_set where id = ? and data = ?"), [ip, name])
  286. watch_list = 2 if curs.fetchall() else 1
  287. menu += [['star_doc_from/' + url_pas(name), ('☆' if watch_list == 1 else '★'), watch_list - 1]]
  288. else:
  289. watch_list = 0
  290. menu += [['doc_watch_list/1/' + url_pas(name), await get_lang('watchlist')]]
  291. if doc_rev != '':
  292. sub = '(' + str(doc_rev) + ')'
  293. view_count_data = await python_to_golang("get_json", path = "v2/page_view/" + url_pas(name))
  294. view_count = view_count_data['data']
  295. other_set = {}
  296. other_set['doc_name'] = name
  297. div += '<div class="opennamu_clearfix"></div>'
  298. comment_api = await python_to_golang("api_w_comment", other_set = other_set)
  299. comment = comment_api['data']
  300. div += comment
  301. return await render_template(
  302. name_view,
  303. div,
  304. sub,
  305. menu,
  306. [r_date, watch_list, description, view_count],
  307. {
  308. "length_doc" : str(length_doc_data),
  309. }
  310. ), response_data