login_login.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. from .tool.func import *
  2. async def login_login():
  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 (await ban_check(None, 'login'))[0] == 1:
  9. return await re_error(conn, 0)
  10. if flask.request.method == 'POST':
  11. if await captcha_post(conn, flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  12. return await re_error(conn, 13)
  13. user_agent = flask.request.headers.get('User-Agent', '')
  14. user_id = flask.request.form.get('id', '')
  15. user_pw = flask.request.form.get('pw', '')
  16. curs.execute(db_change("select data from user_set where id = ? and name = 'pw'"), [user_id])
  17. db_data = curs.fetchall()
  18. if not db_data:
  19. return await re_error(conn, 2)
  20. else:
  21. db_user_pw = db_data[0][0]
  22. curs.execute(db_change("select data from user_set where id = ? and name = 'encode'"), [user_id])
  23. db_data = curs.fetchall()
  24. if not db_data:
  25. return await re_error(conn, 2)
  26. else:
  27. db_user_encode = db_data[0][0]
  28. if pw_check(conn, user_pw, db_user_pw, db_user_encode, user_id) != 1:
  29. return await re_error(conn, 10)
  30. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [user_id])
  31. fa_data = curs.fetchall()
  32. if fa_data and fa_data[0][0] != '':
  33. flask.session['login_id'] = user_id
  34. return redirect(conn, '/login/2fa')
  35. else:
  36. flask.session['id'] = user_id
  37. ua_plus(conn, user_id, ip, user_agent, get_time())
  38. return redirect(conn, '/user')
  39. else:
  40. return await render_template(
  41. await get_lang('login'),
  42. '''
  43. <form method="post">
  44. <input class="__ON_INPUT__" placeholder="''' + await get_lang('id') + '''" name="id" type="text">
  45. <hr class="main_hr">
  46. <input class="__ON_INPUT__" placeholder="''' + await get_lang('password') + '''" name="pw" type="password">
  47. <hr class="main_hr">
  48. <!-- <label><input class="__ON_CHECKBOX__" type="checkbox" name="auto_login"> ''' + await get_lang('auto_login') + ''' (''' + await get_lang('not_working') + ''')</label>
  49. <hr class="main_hr"> -->
  50. ''' + await captcha_get(conn) + '''
  51. <button class="__ON_BUTTON__" type="submit">''' + await get_lang('login') + '''</button>
  52. ''' + await http_warning() + '''
  53. </form>
  54. ''',
  55. 0,
  56. [['user', await get_lang('return')]]
  57. )