view_read.py 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. from .tool.func import *
  2. def view_read_2(conn, name):
  3. curs = conn.cursor()
  4. sub = ''
  5. acl = 0
  6. div = ''
  7. ip = ip_check()
  8. num = flask.request.args.get('num', None)
  9. if num:
  10. num = int(number_check(num))
  11. else:
  12. if not flask.request.args.get('from', None):
  13. curs.execute(db_change("select title from back where link = ? and type = 'redirect'"), [name])
  14. r_db = curs.fetchall()
  15. if r_db:
  16. r_data = link_fix(r_db[0][0])
  17. return redirect('/w/' + url_pas(r_data[0]) + '?from=' + name + r_data[1])
  18. curs.execute(db_change("select sub from rd where title = ? and not stop = 'O' order by date desc"), [name])
  19. if curs.fetchall():
  20. topic = 1
  21. else:
  22. topic = 0
  23. curs.execute(db_change("select link from back where title = ? and type = 'cat' order by link asc"), [name])
  24. curs.execute(db_change("select title from data where title like ?"), ['%' + name + '/%'])
  25. if curs.fetchall():
  26. down = 1
  27. else:
  28. down = 0
  29. m = re.search("^(.*)\/(.*)$", name)
  30. if m:
  31. uppage = m.groups()[0]
  32. else:
  33. uppage = 0
  34. if re.search('^category:', name):
  35. curs.execute(db_change("select link from back where title = ? and type = 'cat' order by link asc"), [name])
  36. back = curs.fetchall()
  37. if back:
  38. div = '<br><h2 id="cate_normal">' + load_lang('category') + '</h2><ul>'
  39. u_div = ''
  40. for data in back:
  41. if re.search('^category:', data[0]):
  42. u_div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  43. else:
  44. curs.execute(db_change("select title from back where title = ? and type = 'include'"), [data[0]])
  45. db_data = curs.fetchall()
  46. if db_data:
  47. div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a> <a id="inside" href="/xref/' + url_pas(data[0]) + '">(' + load_lang('backlink') + ')</a></li>'
  48. else:
  49. div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  50. div += '</ul>'
  51. if div == '<br><h2 id="cate_normal">' + load_lang('category') + '</h2><ul></ul>':
  52. div = ''
  53. if u_div != '':
  54. div += '<br><h2 id="cate_under">' + load_lang('under_category') + '</h2><ul>' + u_div + '</ul>'
  55. cache_data = None
  56. if num:
  57. curs.execute(db_change("select title from history where title = ? and id = ? and hide = 'O'"), [name, str(num)])
  58. if curs.fetchall() and admin_check(6) != 1:
  59. return redirect('/history/' + url_pas(name))
  60. curs.execute(db_change("select data from history where title = ? and id = ?"), [name, str(num)])
  61. else:
  62. if not flask.request.args.get('reload', None):
  63. curs.execute(db_change("select data from cache_data where title = ?"), [name])
  64. cache_data = curs.fetchall()
  65. if not cache_data or cache_data[0][0] == 'HTTP Request 404':
  66. curs.execute(db_change("select data from data where title = ?"), [name])
  67. cache_data = None
  68. else:
  69. curs.execute(db_change("select data from data where title = ?"), [name])
  70. if cache_data:
  71. end_data = cache_data[0][0]
  72. else:
  73. data = curs.fetchall()
  74. if data:
  75. else_data = data[0][0]
  76. else:
  77. else_data = None
  78. curs.execute(db_change("select decu from acl where title = ?"), [name])
  79. data = curs.fetchall()
  80. if data:
  81. acl = 1
  82. if flask.request.args.get('from', None) and else_data:
  83. else_data = re.sub('^\r\n', '', else_data)
  84. else_data = re.sub('\r\n$', '', else_data)
  85. end_data = render_set(
  86. title = name,
  87. data = else_data
  88. )
  89. curs.execute(db_change("delete from cache_data where title = ?"), [name])
  90. curs.execute(db_change("insert into cache_data (title, data) values (?, ?)"), [name, end_data])
  91. if end_data == 'HTTP Request 401.3':
  92. response_data = 401
  93. curs.execute(db_change('select data from other where name = "error_401"'))
  94. sql_d = curs.fetchall()
  95. if sql_d and sql_d[0][0] != '':
  96. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + sql_d[0][0] + '</li></ul>'
  97. else:
  98. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + load_lang('authority_error') + '</li></ul>'
  99. elif end_data == 'HTTP Request 404':
  100. response_data = 404
  101. curs.execute(db_change('select data from other where name = "error_404"'))
  102. sql_d = curs.fetchall()
  103. if sql_d and sql_d[0][0] != '':
  104. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + sql_d[0][0] + '</li></ul>'
  105. else:
  106. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + load_lang('decument_404_error') + '</li></ul>'
  107. curs.execute(db_change('select ip, date, leng, send from history where title = ? order by id desc limit 3'), [name])
  108. sql_d = curs.fetchall()
  109. if sql_d:
  110. end_data += '<h2>' + load_lang('history') + '</h2><ul>'
  111. for i in sql_d:
  112. if re.search("\+", i[2]):
  113. leng = '<span style="color:green;">(' + i[2] + ')</span>'
  114. elif re.search("\-", i[2]):
  115. leng = '<span style="color:red;">(' + i[2] + ')</span>'
  116. else:
  117. leng = '<span style="color:gray;">(' + i[2] + ')</span>'
  118. end_data += '<li>' + i[1] + ' | ' + ip_pas(i[0]) + ' | ' + leng + (' | ' + i[3] if i[3] != '' else '') + '</li>'
  119. end_data += '<li><a href="/history/' + url_pas(name) + '">(...)</a></li></ul>'
  120. else:
  121. response_data = 200
  122. if num:
  123. menu = [['history/' + url_pas(name), load_lang('history')]]
  124. sub = ' (r' + str(num) + ')'
  125. acl = 0
  126. r_date = 0
  127. else:
  128. if response_data == 404:
  129. menu = [['edit/' + url_pas(name), load_lang('create')]]
  130. else:
  131. menu = [['edit/' + url_pas(name), load_lang('edit')]]
  132. menu += [
  133. ['topic/' + url_pas(name), load_lang('discussion'), topic],
  134. ['history/' + url_pas(name), load_lang('history')],
  135. ['xref/' + url_pas(name), load_lang('backlink')],
  136. ['acl/' + url_pas(name), load_lang('acl'), acl],
  137. ['w/' + url_pas(name) + '?reload=true', load_lang('reload')]
  138. ]
  139. if flask.request.args.get('from', None):
  140. menu += [['w/' + url_pas(name), load_lang('pass')]]
  141. end_data = '''
  142. <div id="redirect">
  143. <a href="/w/''' + url_pas(flask.request.args.get('from', None)) + '?from=' + url_pas(name) + '">' + flask.request.args.get('from', None) + '</a> ⇨ <b>' + name + '''</b>
  144. </div>
  145. <br>
  146. ''' + end_data
  147. if uppage != 0:
  148. menu += [['w/' + url_pas(uppage), load_lang('upper')]]
  149. if down:
  150. menu += [['down/' + url_pas(name), load_lang('sub')]]
  151. curs.execute(db_change("select date from history where title = ? order by date desc limit 1"), [name])
  152. date = curs.fetchall()
  153. if date:
  154. r_date = date[0][0]
  155. else:
  156. r_date = 0
  157. div = end_data + div
  158. adsense_code = '<div align="center" style="display: block; margin-bottom: 10px;">{}</div>'
  159. curs.execute(db_change("select data from other where name = 'adsense'"))
  160. adsense_enabled = curs.fetchall()[0][0]
  161. if adsense_enabled == 'True':
  162. curs.execute(db_change("select data from other where name = 'adsense_code'"))
  163. adsense_code = adsense_code.format(curs.fetchall()[0][0])
  164. else:
  165. adsense_code = adsense_code.format('')
  166. div = adsense_code + '<div>' + div + '</div>'
  167. match = re.search("^user:([^/]*)", name)
  168. if match:
  169. user_name = match.groups()[0]
  170. div = '''
  171. <div id="get_user_info"></div>
  172. <script>load_user_info("''' + user_name + '''");</script>
  173. ''' + div
  174. curs.execute(db_change("select data from other where name = 'body'"))
  175. body = curs.fetchall()
  176. if body:
  177. div = body[0][0] + '<hr class=\"main_hr\">' + div
  178. curs.execute(db_change("select data from other where name = 'bottom_body'"))
  179. body = curs.fetchall()
  180. if body:
  181. div += '<hr class=\"main_hr\">' + body[0][0]
  182. if ip_or_user(ip) == 0:
  183. curs.execute(db_change("select title from scan where user = ? and title = ?"), [ip, name])
  184. if curs.fetchall():
  185. watch_list = 2
  186. else:
  187. watch_list = 1
  188. else:
  189. watch_list = 0
  190. return easy_minify(flask.render_template(skin_check(),
  191. imp = [flask.request.args.get('show', name), wiki_set(), custom(), other2([sub, r_date, watch_list])],
  192. data = div,
  193. menu = menu
  194. )), response_data