login_login.py 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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('/user')
  8. if ban_check(None, 'login') == 1:
  9. return re_error('/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(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  15. return re_error('/error/13')
  16. else:
  17. captcha_post('', 0)
  18. user_agent = flask.request.headers.get('User-Agent', '')
  19. user_id = flask.request.form.get('id', '')
  20. user_data = {}
  21. curs.execute(db_change(
  22. 'select name, data from user_set where id = ? and (name = "pw" or name = "encode")'
  23. ), [user_id])
  24. sql_data = curs.fetchall()
  25. if not sql_data:
  26. return re_error('/error/2')
  27. for i in sql_data:
  28. user_data[i[0]] = i[1]
  29. if len(user_data) < 2:
  30. return re_error('/error/2')
  31. if pw_check(
  32. flask.request.form.get('pw', ''),
  33. user_data['pw'],
  34. user_data['encode'],
  35. user_id
  36. ) != 1:
  37. if not 'login_count' in flask.session:
  38. flask.session['login_count'] = 1
  39. else:
  40. flask.session['login_count'] = int(number_check(flask.session['login_count'])) + 1
  41. return re_error('/error/10')
  42. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [user_id])
  43. fa_data = curs.fetchall()
  44. if fa_data and fa_data[0][0] != '':
  45. flask.session['login_id'] = user_id
  46. return redirect('/login/2fa')
  47. else:
  48. flask.session['id'] = user_id
  49. ua_plus(user_id, ip, user_agent, get_time())
  50. conn.commit()
  51. return redirect('/user')
  52. else:
  53. captcha_data = ''
  54. if 'login_count' in flask.session:
  55. count = int(number_check(flask.session['login_count']))
  56. if count > 3:
  57. captcha_data = captcha_get()
  58. return easy_minify(flask.render_template(skin_check(),
  59. imp = [load_lang('login'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  60. data = '''
  61. <form method="post">
  62. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  63. <hr class="main_hr">
  64. <input placeholder="''' + load_lang('password') + '''" name="pw" type="password">
  65. <hr class="main_hr">
  66. <!-- <input type="checkbox" name="auto_login"> ''' + load_lang('auto_login') + ''' (''' + load_lang('not_working') + ''')
  67. <hr class="main_hr"> -->
  68. ''' + captcha_data + '''
  69. <button type="submit">''' + load_lang('login') + '''</button>
  70. ''' + http_warning() + '''
  71. </form>
  72. ''',
  73. menu = [['user', load_lang('return')]]
  74. ))