login_login_2fa.py 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. from .tool.func import *
  2. def login_login_2fa_2(conn):
  3. curs = conn.cursor()
  4. # email 2fa
  5. # pw 2fa
  6. # q_a 2fa
  7. if not (flask.session and 'login_id' in flask.session):
  8. return redirect('/user')
  9. ip = ip_check()
  10. if ip_or_user(ip) == 0:
  11. return redirect('/user')
  12. if ban_check(None, 'login') == 1:
  13. return re_error('/ban')
  14. if flask.request.method == 'POST':
  15. if captcha_post(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  16. return re_error('/error/13')
  17. else:
  18. captcha_post('', 0)
  19. user_agent = flask.request.headers.get('User-Agent', '')
  20. user_id = flask.session['login_id']
  21. curs.execute(db_change('select data from user_set where name = "2fa_pw" and id = ?'), [user_id])
  22. user_1 = curs.fetchall()
  23. if user_1:
  24. curs.execute(db_change('select data from user_set where name = "2fa_pw_encode" and id = ?'), [user_id])
  25. user_1 = user_1[0][0]
  26. user_2 = curs.fetchall()[0][0]
  27. pw_check_d = pw_check(
  28. flask.request.form.get('pw', ''),
  29. user_1,
  30. user_2,
  31. user_id
  32. )
  33. if pw_check_d != 1:
  34. return re_error('/error/10')
  35. flask.session['id'] = user_id
  36. ua_plus(
  37. user_id,
  38. ip,
  39. user_agent,
  40. get_time()
  41. )
  42. conn.commit()
  43. flask.session.pop('b_id', None)
  44. return redirect('/user')
  45. else:
  46. return easy_minify(flask.render_template(skin_check(),
  47. imp = [load_lang('login'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  48. data = '''
  49. <form method="post">
  50. <input placeholder="''' + load_lang('2fa_password') + '''" name="pw" type="password">
  51. <hr class=\"main_hr\">
  52. ''' + captcha_get() + '''
  53. <button type="submit">''' + load_lang('login') + '''</button>
  54. ''' + http_warning() + '''
  55. </form>
  56. ''',
  57. menu = [['user', load_lang('return')]]
  58. ))