login_login_2fa_email.py 2.4 KB

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