recent_change.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. from .tool.func import *
  2. def recent_change_send_render(data):
  3. def send_render_href_replace(match):
  4. match = match.group(1)
  5. data_unescape = html.unescape(match)
  6. return '<a href="/w/' + url_pas(data_unescape) + '">' + match + '</a>'
  7. if data == '&lt;br&gt;' or data == '' or re.search(r'^ +$', data):
  8. data = '<br>'
  9. else:
  10. data = data.replace('javascript:', '')
  11. data = re.sub(r'&lt;a(?:(?:(?!&gt;).)*)&gt;((?:(?!&lt;\/a&gt;).)+)&lt;\/a&gt;', send_render_href_replace, data)
  12. return data
  13. def recent_change(name = '', tool = '', num = 1, set_type = 'normal'):
  14. with get_db_connect() as conn:
  15. curs = conn.cursor()
  16. ip = ip_check()
  17. all_admin = admin_check('all', None, ip)
  18. owner = admin_check(None, None, ip)
  19. if flask.request.method == 'POST':
  20. return redirect('/diff/' + flask.request.form.get('b', '1') + '/' + flask.request.form.get('a', '1') + '/' + url_pas(name))
  21. else:
  22. ban = ''
  23. select = ''
  24. sub = ''
  25. admin = owner
  26. div = '''
  27. <table id="main_table_set">
  28. <tbody>
  29. <tr id="main_table_top_tr">
  30. '''
  31. sql_num = (num * 50 - 50) if num * 50 > 0 else 0
  32. if tool == 'history':
  33. div += '''
  34. <td id="main_table_width">''' + load_lang('version') + '''</td>
  35. <td id="main_table_width">''' + load_lang('editor') + '''</td>
  36. <td id="main_table_width">''' + load_lang('time') + '''</td>
  37. '''
  38. sub = '(' + load_lang('history') + ')'
  39. set_type = '' if set_type == 'edit' else set_type
  40. if set_type != 'normal':
  41. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where title = ? and type = ? order by id + 0 desc limit ?, 50'), [name, set_type, sql_num])
  42. else:
  43. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where title = ? order by id + 0 desc limit ?, 50'), [name, sql_num])
  44. data_list = curs.fetchall()
  45. elif tool == 'record':
  46. div += '''
  47. <td id="main_table_width">''' + load_lang('document_name') + '''</td>
  48. <td id="main_table_width">''' + load_lang('editor') + '''</td>
  49. <td id="main_table_width">''' + load_lang('time') + '''</td>
  50. '''
  51. sub = '(' + load_lang('edit_record') + ')'
  52. set_type = '' if set_type == 'edit' else set_type
  53. if set_type != 'normal':
  54. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where ip = ? and type = ? order by date desc limit ?, 50'), [name, set_type, sql_num])
  55. else:
  56. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where ip = ? order by date desc limit ?, 50'), [name, sql_num])
  57. data_list = curs.fetchall()
  58. else:
  59. div += '''
  60. <td id="main_table_width">''' + load_lang('document_name') + '''</td>
  61. <td id="main_table_width">''' + load_lang('editor') + '''</td>
  62. <td id="main_table_width">''' + load_lang('time') + '''</td>
  63. '''
  64. sub = ''
  65. set_type = '' if set_type == 'edit' else set_type
  66. data_list = []
  67. if num == 1 or all_admin != 1:
  68. curs.execute(db_change('select title, id from rc where type = ? order by date desc limit 50'), [set_type])
  69. for for_a in curs.fetchall():
  70. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where title = ? and id = ?'), for_a)
  71. data_list += curs.fetchall()
  72. else:
  73. if set_type != 'normal':
  74. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history where type = ? order by date desc limit ?, 50'), [sql_num])
  75. else:
  76. curs.execute(db_change('select id, title, date, ip, send, leng, hide from history order by date desc limit ?, 50'), [sql_num])
  77. data_list = curs.fetchall()
  78. div += '</tr>'
  79. all_ip = ip_pas([i[3] for i in data_list])
  80. for data in data_list:
  81. select += '<option value="' + data[0] + '">' + data[0] + '</option>'
  82. send = data[4]
  83. if re.search(r"\+", data[5]):
  84. leng = '<span style="color:green;">(' + data[5] + ')</span>'
  85. elif re.search(r"\-", data[5]):
  86. leng = '<span style="color:red;">(' + data[5] + ')</span>'
  87. else:
  88. leng = '<span style="color:gray;">(' + data[5] + ')</span>'
  89. ip = all_ip[data[3]]
  90. m_tool = '<a href="/history_tool/' + data[0] + '/' + url_pas(data[1]) + '">(' + load_lang('tool') + ')</a>'
  91. style = ['', '']
  92. date = data[2]
  93. if data[6] == 'O':
  94. if admin == 1:
  95. style[0] = 'class="opennamu_history_blind"'
  96. style[1] = 'class="opennamu_history_blind"'
  97. else:
  98. ip = ''
  99. ban = ''
  100. date = ''
  101. send = ''
  102. style[0] = 'style="display: none;"'
  103. style[1] = 'class="opennamu_history_blind"'
  104. if tool == 'history':
  105. title = '<a href="/w_rev/' + data[0] + '/' + url_pas(name) + '">r' + data[0] + '</a> '
  106. else:
  107. title = '<a href="/w/' + url_pas(data[1]) + '">' + html.escape(data[1]) + '</a> '
  108. if int(data[0]) < 2:
  109. title += '<a href="/history/' + url_pas(data[1]) + '">(r' + data[0] + ')</a> '
  110. else:
  111. title += '<a href="/diff/' + str(int(data[0]) - 1) + '/' + data[0] + '/' + url_pas(data[1]) + '">(r' + data[0] + ')</a> '
  112. div += '''
  113. <tr ''' + style[0] + '''>
  114. <td>''' + title + m_tool + ' ' + leng + '''</td>
  115. <td>''' + ip + ban + '''</td>
  116. <td>''' + date + '''</td>
  117. </tr>
  118. <tr ''' + style[1] + '''>
  119. <td colspan="3">''' + recent_change_send_render(html.escape(send)) + '''</td>
  120. </tr>
  121. '''
  122. div += '''
  123. </tbody>
  124. </table>
  125. '''
  126. if tool == 'history':
  127. div = '' + \
  128. '<a href="/history_page/1/normal/' + url_pas(name) + '">(' + load_lang('normal') + ')</a> ' + \
  129. '<a href="/history_page/1/edit/' + url_pas(name) + '">(' + load_lang('edit') + ')</a> ' + \
  130. '<a href="/history_page/1/move/' + url_pas(name) + '">(' + load_lang('move') + ')</a> ' + \
  131. '<a href="/history_page/1/delete/' + url_pas(name) + '">(' + load_lang('delete') + ')</a> ' + \
  132. '<a href="/history_page/1/revert/' + url_pas(name) + '">(' + load_lang('revert') + ')</a>' + \
  133. '<hr class="main_hr">' + div + \
  134. ''
  135. menu = [['w/' + url_pas(name), load_lang('return')]]
  136. if set_type == 'normal':
  137. div = '''
  138. <form method="post">
  139. <select name="a">''' + select + '''</select> <select name="b">''' + select + '''</select>
  140. <button type="submit">''' + load_lang('compare') + '''</button>
  141. </form>
  142. <hr class="main_hr">
  143. ''' + div
  144. if admin == 1:
  145. menu += [
  146. ['history_add/' + url_pas(name), load_lang('history_add')],
  147. ['history_reset/' + url_pas(name), load_lang('history_reset')]
  148. ]
  149. title = name
  150. div += get_next_page_bottom('/history_page/{}/' + set_type + '/' + url_pas(name), num, data_list)
  151. elif tool == 'record':
  152. div = '' + \
  153. '<a href="/record/1/normal/' + url_pas(name) + '">(' + load_lang('normal') + ')</a> ' + \
  154. '<a href="/record/1/edit/' + url_pas(name) + '">(' + load_lang('edit') + ')</a> ' + \
  155. '<a href="/record/1/move/' + url_pas(name) + '">(' + load_lang('move') + ')</a> ' + \
  156. '<a href="/record/1/delete/' + url_pas(name) + '">(' + load_lang('delete') + ')</a> ' + \
  157. '<a href="/record/1/revert/' + url_pas(name) + '">(' + load_lang('revert') + ')</a>' + \
  158. '<hr class="main_hr">' + div + \
  159. ''
  160. title = name
  161. menu = [
  162. ['other', load_lang('other')],
  163. ['user', load_lang('user')]
  164. ]
  165. if admin == 1:
  166. menu += [['record/reset/' + url_pas(name), load_lang('record_reset')]]
  167. div += get_next_page_bottom('/record/{}/' + url_pas(name), num, data_list)
  168. else:
  169. div = '' + \
  170. '<a href="/recent_change/1/normal">(' + load_lang('normal') + ')</a> ' + \
  171. '<a href="/recent_change/1/edit">(' + load_lang('edit') + ')</a> ' + \
  172. '<a href="/recent_change/1/user">(' + load_lang('user_document') + ')</a> ' + \
  173. '<a href="/recent_change/1/move">(' + load_lang('move') + ')</a> ' + \
  174. '<a href="/recent_change/1/delete">(' + load_lang('delete') + ')</a> ' + \
  175. '<a href="/recent_change/1/revert">(' + load_lang('revert') + ')</a>' + \
  176. '<hr class="main_hr">' + div + \
  177. ''
  178. menu = [['other', load_lang('return')]]
  179. title = load_lang('recent_change')
  180. if all_admin == 1:
  181. div += get_next_page_bottom('/recent_change/{}/' + set_type, num, data_list)
  182. if sub == '':
  183. sub = 0
  184. return easy_minify(flask.render_template(skin_check(),
  185. imp = [title, wiki_set(), wiki_custom(), wiki_css([sub, 0])],
  186. data = div,
  187. menu = menu
  188. ))