2
0

login_pw_change.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. from .tool.func import *
  2. def login_pw_change_2(conn):
  3. curs = conn.cursor()
  4. if ban_check() == 1:
  5. return re_error('/ban')
  6. ip = ip_check()
  7. if ip_or_user(ip) != 0:
  8. return redirect('/login')
  9. if flask.request.method == 'POST':
  10. if flask.request.form.get('pw4', None) and flask.request.form.get('pw2', None):
  11. if flask.request.form.get('pw2', None) != flask.request.form.get('pw3', None):
  12. return re_error('/error/20')
  13. curs.execute(db_change("select pw, encode from user where id = ?"), [flask.session['id']])
  14. user = curs.fetchall()
  15. if not user:
  16. return re_error('/error/2')
  17. pw_check_d = pw_check(
  18. flask.request.form.get('pw4', ''),
  19. user[0][0],
  20. user[0][1],
  21. ip
  22. )
  23. if pw_check_d != 1:
  24. return re_error('/error/10')
  25. hashed = pw_encode(flask.request.form.get('pw2', None))
  26. curs.execute(db_change("update user set pw = ? where id = ?"), [hashed, ip])
  27. return redirect('/user')
  28. else:
  29. return easy_minify(flask.render_template(skin_check(),
  30. imp = [load_lang('password_change'), wiki_set(), custom(), other2([0, 0])],
  31. data = '''
  32. <form method="post">
  33. <input placeholder="''' + load_lang('now_password') + '''" name="pw4" type="password">
  34. <hr class=\"main_hr\">
  35. <input placeholder="''' + load_lang('new_password') + '''" name="pw2" type="password">
  36. <hr class=\"main_hr\">
  37. <input placeholder="''' + load_lang('password_confirm') + '''" name="pw3" type="password">
  38. <hr class=\"main_hr\">
  39. <button type="submit">''' + load_lang('save') + '''</button>
  40. </form>
  41. ''',
  42. menu = [['change', load_lang('return')]]
  43. ))