view_read.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. from .tool.func import *
  2. def view_read_2(conn, name):
  3. curs = conn.cursor()
  4. sub = ''
  5. acl = ''
  6. div = ''
  7. num = flask.request.args.get('num', None)
  8. if num:
  9. num = int(number_check(num))
  10. else:
  11. if not flask.request.args.get('from', None):
  12. curs.execute("select title from back where link = ? and type = 'redirect'", [name])
  13. r_db = curs.fetchall()
  14. if r_db:
  15. r_data = link_fix(r_db[0][0])
  16. return redirect('/w/' + r_data[0] + '?from=' + name + r_data[1])
  17. curs.execute("select sub from rd where title = ? and not stop = 'O' order by date desc", [name])
  18. if curs.fetchall():
  19. sub += ' (' + load_lang('discussion') + ')'
  20. curs.execute("select link from back where title = ? and type = 'cat' order by link asc", [name])
  21. curs.execute("select title from data where title like ?", ['%' + name + '/%'])
  22. if curs.fetchall():
  23. down = 1
  24. else:
  25. down = 0
  26. m = re.search("^(.*)\/(.*)$", name)
  27. if m:
  28. uppage = m.groups()[0]
  29. else:
  30. uppage = 0
  31. if re.search('^category:', name):
  32. curs.execute("select link from back where title = ? and type = 'cat' order by link asc", [name])
  33. back = curs.fetchall()
  34. if back:
  35. div = '<br><h2 id="cate_normal">' + load_lang('category') + '</h2><ul>'
  36. u_div = ''
  37. for data in back:
  38. if re.search('^category:', data[0]):
  39. u_div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  40. else:
  41. curs.execute("select title from back where title = ? and type = 'include'", [data[0]])
  42. db_data = curs.fetchall()
  43. if db_data:
  44. 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>'
  45. else:
  46. div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  47. div += '</ul>'
  48. if div == '<br><h2 id="cate_normal">' + load_lang('category') + '</h2><ul></ul>':
  49. div = ''
  50. if u_div != '':
  51. div += '<br><h2 id="cate_under">' + load_lang('under_category') + '</h2><ul>' + u_div + '</ul>'
  52. if num:
  53. curs.execute("select title from history where title = ? and id = ? and hide = 'O'", [name, str(num)])
  54. if curs.fetchall() and admin_check(6) != 1:
  55. return redirect('/history/' + url_pas(name))
  56. curs.execute("select title, data from history where title = ? and id = ?", [name, str(num)])
  57. else:
  58. curs.execute("select title, data from data where title = ?", [name])
  59. data = curs.fetchall()
  60. if data:
  61. else_data = data[0][1]
  62. else:
  63. else_data = None
  64. m = re.search("^user:([^/]*)", name)
  65. if m:
  66. g = m.groups()
  67. curs.execute("select acl from user where id = ?", [g[0]])
  68. test = curs.fetchall()
  69. if test and test[0][0] != 'user':
  70. acl = ' (' + load_lang('admin') + ')'
  71. else:
  72. if ban_check(g[0]) == 1:
  73. sub += ' (' + load_lang('blocked') + ')'
  74. else:
  75. acl = ''
  76. curs.execute("select dec from acl where title = ?", [name])
  77. data = curs.fetchall()
  78. if data:
  79. acl += ' (' + load_lang('acl') + ')'
  80. if flask.request.args.get('from', None) and else_data:
  81. else_data = re.sub('^\r\n', '', else_data)
  82. else_data = re.sub('\r\n$', '', else_data)
  83. end_data = render_set(
  84. title = name,
  85. data = else_data
  86. )
  87. if end_data == 'HTTP Request 401.3':
  88. response_data = 401
  89. curs.execute('select data from other where name = "error_401"')
  90. sql_d = curs.fetchall()
  91. if sql_d and sql_d[0][0] != '':
  92. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + sql_d[0][0] + '</li></ul>'
  93. else:
  94. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + load_lang('authority_error') + '</li></ul>'
  95. elif end_data == 'HTTP Request 404':
  96. response_data = 404
  97. curs.execute('select data from other where name = "error_404"')
  98. sql_d = curs.fetchall()
  99. if sql_d and sql_d[0][0] != '':
  100. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + sql_d[0][0] + '</li></ul>'
  101. else:
  102. end_data = '<h2>' + load_lang('error') + '</h2><ul><li>' + load_lang('decument_404_error') + '</li></ul>'
  103. else:
  104. response_data = 200
  105. if num:
  106. menu = [['history/' + url_pas(name), load_lang('history')]]
  107. sub = ' (r' + str(num) + ')'
  108. acl = ''
  109. r_date = 0
  110. else:
  111. if response_data == 404:
  112. menu = [['edit/' + url_pas(name), load_lang('create')]]
  113. else:
  114. menu = [['edit/' + url_pas(name), load_lang('edit')]]
  115. menu += [['topic/' + url_pas(name), load_lang('discussion')], ['history/' + url_pas(name), load_lang('history')], ['xref/' + url_pas(name), load_lang('backlink')], ['acl/' + url_pas(name), load_lang('acl')]]
  116. if flask.request.args.get('from', None):
  117. menu += [['w/' + url_pas(name), load_lang('pass')]]
  118. end_data = '''
  119. <div id="redirect">
  120. <a href="/w/''' + url_pas(flask.request.args.get('from', None)) + '?from=' + url_pas(name) + '">' + flask.request.args.get('from', None) + '</a> → ' + name + '''
  121. </div>
  122. <br>
  123. ''' + end_data
  124. if uppage != 0:
  125. menu += [['w/' + url_pas(uppage), load_lang('upper')]]
  126. if down:
  127. menu += [['down/' + url_pas(name), load_lang('sub')]]
  128. curs.execute("select date from history where title = ? order by date desc limit 1", [name])
  129. date = curs.fetchall()
  130. if date:
  131. r_date = date[0][0]
  132. else:
  133. r_date = 0
  134. div = end_data + div
  135. adsense_code = '<div align="center" style="display: block; margin-bottom: 10px;">{}</div>'
  136. curs.execute("select data from other where name = 'adsense'")
  137. adsense_enabled = curs.fetchall()[0][0]
  138. if adsense_enabled == 'True':
  139. curs.execute("select data from other where name = 'adsense_code'")
  140. adsense_code = adsense_code.format(curs.fetchall()[0][0])
  141. else:
  142. adsense_code = adsense_code.format('')
  143. curs.execute("select data from other where name = 'body'")
  144. body = curs.fetchall()
  145. if body:
  146. div = body[0][0] + '<hr class=\"main_hr\">' + div
  147. div = adsense_code + '<div>' + div + '</div>'
  148. return easy_minify(flask.render_template(skin_check(),
  149. imp = [flask.request.args.get('show', name), wiki_set(), custom(), other2([sub + acl, r_date])],
  150. data = div,
  151. menu = menu
  152. )), response_data