recent_change.py 9.5 KB

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