login_login.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. from .tool.func import *
  2. def login_login_2():
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. ip = ip_check()
  6. if ip_or_user(ip) == 0:
  7. return redirect(conn, '/user')
  8. if ban_check(None, 'login')[0] == 1:
  9. return re_error(conn, '/ban')
  10. if flask.request.method == 'POST':
  11. if 'login_count' in flask.session:
  12. count = int(number_check(flask.session['login_count']))
  13. if count > 3:
  14. if captcha_post(conn, flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  15. return re_error(conn, '/error/13')
  16. else:
  17. captcha_post(conn, '', 0)
  18. user_agent = flask.request.headers.get('User-Agent', '')
  19. user_id = flask.request.form.get('id', '')
  20. user_pw = flask.request.form.get('pw', '')
  21. curs.execute(db_change("select data from user_set where id = ? and name = 'pw'"), [user_id])
  22. db_data = curs.fetchall()
  23. if not db_data:
  24. return re_error(conn, '/error/2')
  25. else:
  26. db_user_pw = db_data[0][0]
  27. curs.execute(db_change("select data from user_set where id = ? and name = 'encode'"), [user_id])
  28. db_data = curs.fetchall()
  29. if not db_data:
  30. return re_error(conn, '/error/2')
  31. else:
  32. db_user_encode = db_data[0][0]
  33. if pw_check(conn, user_pw, db_user_pw, db_user_encode, user_id) != 1:
  34. if not 'login_count' in flask.session:
  35. flask.session['login_count'] = 1
  36. else:
  37. flask.session['login_count'] = int(number_check(flask.session['login_count'])) + 1
  38. return re_error(conn, '/error/10')
  39. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [user_id])
  40. fa_data = curs.fetchall()
  41. if fa_data and fa_data[0][0] != '':
  42. flask.session['login_id'] = user_id
  43. return redirect(conn, '/login/2fa')
  44. else:
  45. flask.session['id'] = user_id
  46. ua_plus(conn, user_id, ip, user_agent, get_time())
  47. return redirect(conn, '/user')
  48. else:
  49. captcha_data = ''
  50. if 'login_count' in flask.session:
  51. count = int(number_check(flask.session['login_count']))
  52. if count > 3:
  53. captcha_data = captcha_get(conn)
  54. return easy_minify(conn, flask.render_template(skin_check(conn),
  55. imp = [get_lang(conn, 'login'), wiki_set(conn), wiki_custom(conn), wiki_css([0, 0])],
  56. data = '''
  57. <form method="post">
  58. <input placeholder="''' + get_lang(conn, 'id') + '''" name="id" type="text">
  59. <hr class="main_hr">
  60. <input placeholder="''' + get_lang(conn, 'password') + '''" name="pw" type="password">
  61. <hr class="main_hr">
  62. <!-- <input type="checkbox" name="auto_login"> ''' + get_lang(conn, 'auto_login') + ''' (''' + get_lang(conn, 'not_working') + ''')
  63. <hr class="main_hr"> -->
  64. ''' + captcha_data + '''
  65. <button type="submit">''' + get_lang(conn, 'login') + '''</button>
  66. ''' + http_warning(conn) + '''
  67. </form>
  68. ''',
  69. menu = [['user', get_lang(conn, 'return')]]
  70. ))