edit_many_delete.py 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. from .tool.func import *
  2. def edit_many_delete_2(conn, app_var):
  3. curs = conn.cursor()
  4. ip = ip_check()
  5. if admin_check() != 1:
  6. return re_error('/ban')
  7. if flask.request.method == 'POST':
  8. all_title = re.findall(r'([^\n]+)\n', flask.request.form.get('content', '').replace('\r\n', '\n') + '\n')
  9. for name in all_title:
  10. curs.execute(db_change("select data from data where title = ?"), [name])
  11. data = curs.fetchall()
  12. if data:
  13. today = get_time()
  14. leng = '-' + str(len(data[0][0]))
  15. history_plus(
  16. name,
  17. '',
  18. today,
  19. ip,
  20. flask.request.form.get('send', ''),
  21. leng,
  22. 'delete'
  23. )
  24. curs.execute(db_change("select title, link from back where title = ? and not type = 'cat' and not type = 'no'"), [name])
  25. for data in curs.fetchall():
  26. curs.execute(db_change("insert into back (title, link, type) values (?, ?, 'no')"), [data[0], data[1]])
  27. curs.execute(db_change("delete from back where link = ?"), [name])
  28. curs.execute(db_change("delete from data where title = ?"), [name])
  29. conn.commit()
  30. file_check = re.search('^file:(.+)\.(.+)$', name)
  31. if file_check:
  32. file_check = file_check.groups()
  33. os.remove(os.path.join(
  34. app_var['path_data_image'],
  35. hashlib.sha224(bytes(file_check[0], 'utf-8')).hexdigest() + '.' + file_check[1]
  36. ))
  37. curs.execute(db_change('select data from other where name = "count_all_title"'))
  38. curs.execute(db_change("update other set data = ? where name = 'count_all_title'"), [str(int(curs.fetchall()[0][0]) - 1)])
  39. return redirect('/recent_changes')
  40. else:
  41. return easy_minify(flask.render_template(skin_check(),
  42. imp = [load_lang('many_delete'), wiki_set(), custom(), other2([0, 0])],
  43. data = '''
  44. <form method="post">
  45. <textarea rows="25" placeholder="''' + load_lang('many_delete_help') + '''" name="content"></textarea>
  46. <hr class=\"main_hr\">
  47. <input placeholder="''' + load_lang('why') + '''" name="send" type="text">
  48. <hr class=\"main_hr\">
  49. <button type="submit">''' + load_lang('delete') + '''</button>
  50. </form>
  51. ''',
  52. menu = [['manager/1', load_lang('return')]]
  53. ))