view_read.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. from .tool.func import *
  2. def view_read(name = 'Test', do_type = ''):
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. sub = 0
  6. menu = []
  7. user_doc = ''
  8. category_total = ''
  9. file_data = ''
  10. doc_type = ''
  11. now_time = get_time()
  12. ip = ip_check()
  13. uppage = re.sub(r"/([^/]+)$", '', name)
  14. uppage = 0 if uppage == name else uppage
  15. curs.execute(db_change("select sub from rd where title = ? and not stop = 'O' order by date desc"), [name])
  16. topic = 1 if curs.fetchall() else 0
  17. curs.execute(db_change("select title from data where title like ?"), [name + '/%'])
  18. down = 1 if curs.fetchall() else 0
  19. if re.search(r'^category:', name):
  20. name_view = name
  21. doc_type = 'category'
  22. category_doc = ''
  23. category_sub = ''
  24. count_sub_category = 0
  25. count_category = 0
  26. curs.execute(db_change("select distinct link from back where title = ? and type = 'cat' order by link asc"), [name])
  27. category_sql = curs.fetchall()
  28. for data in category_sql:
  29. link_view = data[0]
  30. if get_main_skin_set(curs, flask.session, 'main_css_category_change_title', ip) != 'off':
  31. curs.execute(db_change("select data from back where title = ? and link = ? and type = 'cat_view' limit 1"), [name, data[0]])
  32. db_data = curs.fetchall()
  33. if db_data and db_data[0][0] != '':
  34. link_view = db_data[0][0]
  35. link_blur = ''
  36. curs.execute(db_change("select data from back where title = ? and link = ? and type = 'cat_blur' limit 1"), [name, data[0]])
  37. db_data = curs.fetchall()
  38. if db_data:
  39. link_blur = 'opennamu_category_blur'
  40. if data[0].startswith('category:'):
  41. category_sub += '<li><a class="' + link_blur + '" href="/w/' + url_pas(data[0]) + '">' + html.escape(link_view) + '</a></li>'
  42. count_sub_category += 1
  43. else:
  44. category_doc += '' + \
  45. '<li>' + \
  46. '<a class="' + link_blur + '" href="/w/' + url_pas(data[0]) + '">' + html.escape(link_view) + '</a> ' + \
  47. '<a class="opennamu_link_inter" href="/xref/' + url_pas(data[0]) + '">(' + load_lang('backlink') + ')</a>' + \
  48. '</li>' + \
  49. ''
  50. count_category += 1
  51. if category_sub != '':
  52. category_total += '' + \
  53. '<h2 id="cate_under">' + load_lang('under_category') + '</h2>' + \
  54. '<ul class="opennamu_ul">' + \
  55. '<li>' + load_lang('all') + ' : ' + str(count_sub_category) + '</li>' + \
  56. category_sub + \
  57. '</ul>' + \
  58. ''
  59. if category_doc != '':
  60. category_total += '' + \
  61. '<h2 id="cate_normal">' + load_lang('category_title') + '</h2>' + \
  62. '<ul class="opennamu_ul">' + \
  63. '<li>' + load_lang('all') + ' : ' + str(count_category) + '</li>' + \
  64. category_doc + \
  65. '</ul>' + \
  66. ''
  67. elif re.search(r"^user:([^/]*)", name):
  68. name_view = name
  69. doc_type = 'user'
  70. match = re.search(r"^user:([^/]*)", name)
  71. user_name = html.escape(match.group(1))
  72. user_doc = ''
  73. # S admin or owner 특수 틀 추가
  74. if admin_check('all', None, user_name) == 1:
  75. if admin_check(None, None, user_name) == 1:
  76. curs.execute(db_change('select data from other where name = "phrase_user_page_owner"'))
  77. db_data = curs.fetchall()
  78. if db_data and db_data[0][0] != '':
  79. user_doc += db_data[0][0] + '<br>'
  80. else:
  81. curs.execute(db_change('select data from other where name = "phrase_user_page_admin"'))
  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. # E
  91. user_doc += '''
  92. <div id="opennamu_get_user_info">''' + html.escape(user_name) + '''</div>
  93. <hr class="main_hr">
  94. '''
  95. if name == 'user:' + user_name:
  96. menu += [['w/' + url_pas(name) + '/' + url_pas(now_time.split()[0]), load_lang('today_doc')]]
  97. elif re.search(r"^file:", name):
  98. curs.execute(db_change('select id from history where title = ? order by date desc limit 1'), [name])
  99. db_data = curs.fetchall()
  100. rev = db_data[0][0] if db_data else '1'
  101. name_view = name
  102. doc_type = 'file'
  103. mime_type = re.search(r'([^.]+)$', name)
  104. if mime_type:
  105. mime_type = mime_type.group(1).lower()
  106. else:
  107. mime_type = 'jpg'
  108. file_name = re.sub(r'\.([^.]+)$', '', name)
  109. file_name = re.sub(r'^file:', '', file_name)
  110. file_all_name = sha224_replace(file_name) + '.' + mime_type
  111. file_path_name = os.path.join(load_image_url(), file_all_name)
  112. if os.path.exists(file_path_name):
  113. try:
  114. img = Image.open(file_path_name)
  115. width, height = img.size
  116. file_res = str(width) + 'x' + str(height)
  117. except:
  118. file_res = 'Vector'
  119. file_size = str(round(os.path.getsize(file_path_name) / 1000, 1))
  120. file_data = '''
  121. <img src="/image/''' + url_pas(file_all_name) + '''.cache_v''' + rev + '''">
  122. <h2>''' + load_lang('data') + '''</h2>
  123. <table>
  124. <tr><td>URL</td><td><a href="/image/''' + url_pas(file_all_name) + '''">''' + load_lang('link') + '''</a></td></tr>
  125. <tr><td>''' + load_lang('volume') + '''</td><td>''' + file_size + '''KB</td></tr>
  126. <tr><td>''' + load_lang('resolution') + '''</td><td>''' + file_res + '''</td></tr>
  127. </table>
  128. <h2>''' + load_lang('content') + '''</h2>
  129. '''
  130. menu += [['delete_file/' + url_pas(name), load_lang('file_delete')]]
  131. else:
  132. file_data = ''
  133. else:
  134. name_view = name
  135. curs.execute(db_change("select data from data where title = ?"), [name])
  136. data = curs.fetchall()
  137. end_data = render_set(
  138. doc_name = name,
  139. doc_data = data[0][0] if data else None,
  140. data_type = 'from' if do_type == 'from' else 'view'
  141. )
  142. if end_data == 'HTTP Request 401.3':
  143. response_data = 401
  144. curs.execute(db_change('select data from other where name = "error_401"'))
  145. sql_d = curs.fetchall()
  146. if sql_d and sql_d[0][0] != '':
  147. end_data = '<h2>' + load_lang('error') + '</h2><ul class="opennamu_ul"><li>' + sql_d[0][0] + '</li></ul>'
  148. else:
  149. end_data = '<h2>' + load_lang('error') + '</h2><ul class="opennamu_ul"><li>' + load_lang('authority_error') + '</li></ul>'
  150. elif end_data == 'HTTP Request 404':
  151. response_data = 404
  152. curs.execute(db_change('select data from other where name = "error_404"'))
  153. sql_d = curs.fetchall()
  154. if sql_d and sql_d[0][0] != '':
  155. end_data = '<h2>' + load_lang('error') + '</h2><ul class="opennamu_ul"><li>' + sql_d[0][0] + '</li></ul>'
  156. else:
  157. end_data = '<h2>' + load_lang('error') + '</h2><ul class="opennamu_ul"><li>' + load_lang('decument_404_error') + '</li></ul>'
  158. curs.execute(db_change('' + \
  159. 'select ip, date, leng, send, id from history ' + \
  160. 'where title = ? and hide != "O" order by id + 0 desc limit 3' + \
  161. ''), [name])
  162. sql_d = curs.fetchall()
  163. if sql_d:
  164. end_data += '<h2>' + load_lang('history') + '</h2><ul class="opennamu_ul">'
  165. for i in sql_d:
  166. if re.search(r"\+", i[2]):
  167. leng = '<span style="color:green;">(' + i[2] + ')</span>'
  168. elif re.search(r"\-", i[2]):
  169. leng = '<span style="color:red;">(' + i[2] + ')</span>'
  170. else:
  171. leng = '<span style="color:gray;">(' + i[2] + ')</span>'
  172. end_data += '<li>' + i[1] + ' | r' + i[4] + ' | ' + ip_pas(i[0]) + ' | ' + leng + (' | ' + i[3] if i[3] != '' else '') + '</li>'
  173. end_data += '<li><a href="/history/' + url_pas(name) + '">(...)</a></li></ul>'
  174. else:
  175. response_data = 200
  176. curs.execute(db_change("select title from acl where title = ?"), [name])
  177. acl = 1 if curs.fetchall() else 0
  178. menu_acl = 1 if acl_check(name) == 1 else 0
  179. if response_data == 404:
  180. menu += [['edit/' + url_pas(name), load_lang('create'), menu_acl]]
  181. else:
  182. menu += [['edit/' + url_pas(name), load_lang('edit'), menu_acl]]
  183. menu += [
  184. ['topic/' + url_pas(name), load_lang('discussion'), topic],
  185. ['history/' + url_pas(name), load_lang('history')],
  186. ['xref/' + url_pas(name), load_lang('backlink')],
  187. ['acl/' + url_pas(name), load_lang('setting'), acl],
  188. ]
  189. if flask.session and 'lastest_document' in flask.session:
  190. if type(flask.session['lastest_document']) != type([]):
  191. flask.session['lastest_document'] = []
  192. else:
  193. flask.session['lastest_document'] = []
  194. if do_type == 'from':
  195. menu += [['w/' + url_pas(name), load_lang('pass')]]
  196. last_page = ''
  197. for for_a in reversed(range(0, len(flask.session['lastest_document']))):
  198. last_page = flask.session['lastest_document'][for_a]
  199. curs.execute(db_change("select link from back where (title = ? or link = ?) and type = 'redirect' limit 1"), [last_page, last_page])
  200. if curs.fetchall():
  201. break
  202. redirect_text = '{0} ➤ {1}'
  203. curs.execute(db_change('select data from other where name = "redirect_text"'))
  204. db_data = curs.fetchall()
  205. if db_data and db_data[0][0] != '':
  206. redirect_text = db_data[0][0]
  207. try:
  208. redirect_text = redirect_text.format('<a href="/w_from/' + url_pas(last_page) + '">' + html.escape(last_page) + '</a>', '<b>' + html.escape(name) + '</b>')
  209. except:
  210. redirect_text = '{0} ➤ {1}'
  211. redirect_text = redirect_text.format('<a href="/w_from/' + url_pas(last_page) + '">' + html.escape(last_page) + '</a>', '<b>' + html.escape(name) + '</b>')
  212. end_data = '''
  213. <div class="opennamu_redirect" id="redirect">
  214. ''' + redirect_text + '''
  215. </div>
  216. <hr class="main_hr">
  217. ''' + end_data
  218. if len(flask.session['lastest_document']) >= 10:
  219. flask.session['lastest_document'] = flask.session['lastest_document'][-9:] + [name]
  220. else:
  221. flask.session['lastest_document'] += [name]
  222. flask.session['lastest_document'] = list(reversed(dict.fromkeys(reversed(flask.session['lastest_document']))))
  223. view_history_on = get_main_skin_set(curs, flask.session, 'main_css_view_history', ip)
  224. if view_history_on == 'on':
  225. end_data = '' + \
  226. '<div class="opennamu_trace">' + \
  227. '<a class="opennamu_trace_button" href="javascript:opennamu_do_trace_spread();"> (+)</a>' + \
  228. load_lang('trace') + ' : ' + \
  229. ' ➥ '.join(
  230. [
  231. '<a href="/w/' + url_pas(for_a) + '">' + html.escape(for_a) + '</a>'
  232. for for_a in flask.session['lastest_document']
  233. ]
  234. ) + \
  235. '</div>' + \
  236. '<hr class="main_hr">' + \
  237. '' + end_data
  238. if uppage != 0:
  239. menu += [['w/' + url_pas(uppage), load_lang('upper')]]
  240. if down:
  241. menu += [['down/' + url_pas(name), load_lang('sub')]]
  242. curs.execute(db_change("select set_data from data_set where doc_name = ? and set_name = 'last_edit'"), [name])
  243. r_date = curs.fetchall()
  244. r_date = r_date[0][0] if r_date else 0
  245. div = file_data + user_doc + end_data + category_total
  246. if doc_type == '':
  247. curs.execute(db_change('select data from other where name = "outdated_doc_warning_date"'))
  248. db_data = curs.fetchall()
  249. if db_data and db_data[0][0] != '' and r_date != 0:
  250. time_1 = datetime.datetime.strptime(r_date, '%Y-%m-%d %H:%M:%S') + datetime.timedelta(days = int(number_check(db_data[0][0])))
  251. time_2 = datetime.datetime.strptime(now_time, '%Y-%m-%d %H:%M:%S')
  252. if time_2 > time_1:
  253. curs.execute(db_change('select data from other where name = "outdated_doc_warning"'))
  254. db_data = curs.fetchall()
  255. div = (db_data[0][0] if db_data and db_data[0][0] != '' else load_lang('old_page_warning')) + '<hr class="main_hr">' + div
  256. curs.execute(db_change("select data from other where name = 'body'"))
  257. body = curs.fetchall()
  258. div = (body[0][0] + div) if body else div
  259. curs.execute(db_change("select data from other where name = 'bottom_body'"))
  260. body = curs.fetchall()
  261. div += body[0][0] if body else ''
  262. if ip_or_user(ip) == 0:
  263. curs.execute(db_change("select title from scan where user = ? and title = ?"), [ip, name])
  264. watch_list = 2 if curs.fetchall() else 1
  265. else:
  266. watch_list = 0
  267. return easy_minify(flask.render_template(skin_check(),
  268. imp = [name_view, wiki_set(), wiki_custom(), wiki_css([sub, r_date, watch_list])],
  269. data = div,
  270. menu = menu
  271. )), response_data