login.py 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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', '')) == 1:
  11. return re_error('/error/13')
  12. else:
  13. captcha_post('', 0)
  14. agent = flask.request.headers.get('User-Agent')
  15. curs.execute(db_change("select pw, encode from user where id = ?"), [flask.request.form.get('id', None)])
  16. user = curs.fetchall()
  17. if not user:
  18. return re_error('/error/2')
  19. pw_check_d = pw_check(
  20. flask.request.form.get('pw', ''),
  21. user[0][0],
  22. user[0][1],
  23. flask.request.form.get('id', None)
  24. )
  25. if pw_check_d != 1:
  26. return re_error('/error/10')
  27. flask.session['state'] = 1
  28. flask.session['id'] = flask.request.form.get('id', None)
  29. curs.execute(db_change("select css from custom where user = ?"), [flask.request.form.get('id', None)])
  30. css_data = curs.fetchall()
  31. if css_data:
  32. flask.session['head'] = css_data[0][0]
  33. else:
  34. flask.session['head'] = ''
  35. curs.execute(db_change("insert into ua_d (name, ip, ua, today, sub) values (?, ?, ?, ?, '')"), [flask.request.form.get('id', None), ip_check(1), agent, get_time()])
  36. conn.commit()
  37. return redirect('/user')
  38. else:
  39. oauth_check = 0
  40. oauth_content = '<hr class=\"main_hr\"><div class="oauth-wrapper"><ul class="oauth-list">'
  41. oauth_supported = load_oauth('_README')['support']
  42. for i in range(len(oauth_supported)):
  43. oauth_data = load_oauth(oauth_supported[i])
  44. if oauth_data['client_id'] != '' and oauth_data['client_secret'] != '':
  45. oauth_content += '''
  46. <li>
  47. <a href="/oauth/{}/init">
  48. <div class="oauth-btn oauth-btn-{}">
  49. <div class="oauth-btn-logo oauth-btn-{}"></div>
  50. {}
  51. </div>
  52. </a>
  53. </li>
  54. '''.format(
  55. oauth_supported[i],
  56. oauth_supported[i],
  57. oauth_supported[i],
  58. load_lang('oauth_signin_' + oauth_supported[i])
  59. )
  60. oauth_check = 1
  61. oauth_content += '</ul></div>'
  62. if oauth_check == 0:
  63. oauth_content = ''
  64. http_warring = '<hr class=\"main_hr\"><span>' + load_lang('http_warring') + '</span>'
  65. return easy_minify(flask.render_template(skin_check(),
  66. imp = [load_lang('login'), wiki_set(), custom(), other2([0, 0])],
  67. data = '''
  68. <form method="post">
  69. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  70. <hr class=\"main_hr\">
  71. <input placeholder="''' + load_lang('password') + '''" name="pw" type="password">
  72. <hr class=\"main_hr\">
  73. ''' + captcha_get() + '''
  74. <button type="submit">''' + load_lang('login') + '''</button>
  75. ''' + oauth_content + '''
  76. ''' + http_warring + '''
  77. </form>
  78. ''',
  79. menu = [['user', load_lang('return')]]
  80. ))