login.py 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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(None, '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. user_agent = flask.request.headers.get('User-Agent', '')
  15. user_id = flask.request.form.get('id', '')
  16. user_data = {}
  17. curs.execute(db_change("" + \
  18. "select name, data from user_set " + \
  19. "where id = ? and (name = 'pw' or name = 'encode')" + \
  20. ""), [
  21. user_id
  22. ])
  23. sql_data = curs.fetchall()
  24. if not sql_data:
  25. return re_error('/error/2')
  26. else:
  27. for i in sql_data:
  28. user_data[i[0]] = i[1]
  29. pw_check_d = pw_check(
  30. flask.request.form.get('pw', ''),
  31. user_data['pw'],
  32. user_data['encode'],
  33. user_id
  34. )
  35. if pw_check_d != 1:
  36. return re_error('/error/10')
  37. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [user_id])
  38. fa_data = curs.fetchall()
  39. if fa_data and fa_data[0][0] != '':
  40. flask.session['b_id'] = user_id
  41. return redirect('/2fa_login')
  42. else:
  43. flask.session['id'] = user_id
  44. ua_plus(user_id, ip, user_agent, get_time())
  45. conn.commit()
  46. return redirect('/user')
  47. else:
  48. return easy_minify(flask.render_template(skin_check(),
  49. imp = [load_lang('login'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  50. data = '''
  51. <form method="post">
  52. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  53. <hr class=\"main_hr\">
  54. <input placeholder="''' + load_lang('password') + '''" name="pw" type="password">
  55. <hr class=\"main_hr\">
  56. ''' + captcha_get() + '''
  57. <button type="submit">''' + load_lang('login') + '''</button>
  58. ''' + http_warring() + '''
  59. </form>
  60. ''',
  61. menu = [['user', load_lang('return')]]
  62. ))