login.py 2.9 KB

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