2
0

login.py 3.6 KB

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