2
0

login_2fa.py 2.5 KB

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