login_register.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. from .tool.func import *
  2. def login_register_2(conn):
  3. curs = conn.cursor()
  4. if ban_check() == 1:
  5. return re_error('/ban')
  6. ip = ip_check()
  7. if ip_or_user(ip) == 0:
  8. return redirect('/user')
  9. if not admin_check() == 1:
  10. curs.execute(db_change('select data from other where name = "reg"'))
  11. set_d = curs.fetchall()
  12. if set_d and set_d[0][0] == 'on':
  13. return re_error('/ban')
  14. if flask.request.method == 'POST':
  15. if captcha_post(flask.request.form.get('g-recaptcha-response', '')) == 1:
  16. return re_error('/error/13')
  17. else:
  18. captcha_post('', 0)
  19. if flask.request.form.get('id', None) == '' or flask.request.form.get('pw', None) == '':
  20. return redirect('/register')
  21. if flask.request.form.get('pw', None) != flask.request.form.get('pw2', None):
  22. return re_error('/error/20')
  23. if re.search('(?:[^A-Za-zㄱ-힣0-9 ])', flask.request.form.get('id', None)):
  24. return re_error('/error/8')
  25. curs.execute(db_change('select html from html_filter where kind = "name"'))
  26. set_d = curs.fetchall()
  27. for i in set_d:
  28. check_r = re.compile(i[0], re.I)
  29. if check_r.search(flask.request.form.get('id', None)):
  30. return re_error('/error/8')
  31. if len(flask.request.form.get('id', None)) > 32:
  32. return re_error('/error/7')
  33. curs.execute(db_change("select id from user where id = ?"), [flask.request.form.get('id', None)])
  34. if curs.fetchall():
  35. return re_error('/error/6')
  36. hashed = pw_encode(flask.request.form.get('pw', None))
  37. curs.execute(db_change('select data from other where name = "email_have"'))
  38. sql_data = curs.fetchall()
  39. if sql_data and sql_data[0][0] != '':
  40. flask.session['c_id'] = flask.request.form.get('id', None)
  41. flask.session['c_pw'] = hashed
  42. flask.session['c_key'] = ''.join(random.choice("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ") for i in range(16))
  43. return redirect('/need_email')
  44. else:
  45. curs.execute(db_change('select data from other where name = "encode"'))
  46. db_data = curs.fetchall()
  47. curs.execute(db_change("select id from user limit 1"))
  48. if not curs.fetchall():
  49. curs.execute(db_change("insert into user (id, pw, acl, date, encode) values (?, ?, 'owner', ?, ?)"), [flask.request.form.get('id', None), hashed, get_time(), db_data[0][0]])
  50. first = 1
  51. else:
  52. curs.execute(db_change("insert into user (id, pw, acl, date, encode) values (?, ?, 'user', ?, ?)"), [flask.request.form.get('id', None), hashed, get_time(), db_data[0][0]])
  53. first = 0
  54. ip = ip_check()
  55. agent = flask.request.headers.get('User-Agent')
  56. curs.execute(db_change("insert into ua_d (name, ip, ua, today, sub) values (?, ?, ?, ?, '')"), [flask.request.form.get('id', None), ip, agent, get_time()])
  57. flask.session['state'] = 1
  58. flask.session['id'] = flask.request.form.get('id', None)
  59. flask.session['head'] = ''
  60. conn.commit()
  61. if first == 0:
  62. return redirect('/change')
  63. else:
  64. return redirect('/setting')
  65. else:
  66. contract = ''
  67. curs.execute(db_change('select data from other where name = "contract"'))
  68. data = curs.fetchall()
  69. if data and data[0][0] != '':
  70. contract = data[0][0] + '<hr class=\"main_hr\">'
  71. http_warring = '<hr class=\"main_hr\"><span>' + load_lang('http_warring') + '</span>'
  72. return easy_minify(flask.render_template(skin_check(),
  73. imp = [load_lang('register'), wiki_set(), custom(), other2([0, 0])],
  74. data = '''
  75. <form method="post">
  76. ''' + contract + '''
  77. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  78. <hr class=\"main_hr\">
  79. <input placeholder="''' + load_lang('password') + '''" name="pw" type="password">
  80. <hr class=\"main_hr\">
  81. <input placeholder="''' + load_lang('password_confirm') + '''" name="pw2" type="password">
  82. <hr class=\"main_hr\">
  83. ''' + captcha_get() + '''
  84. <button type="submit">''' + load_lang('save') + '''</button>
  85. ''' + http_warring + '''
  86. </form>
  87. ''',
  88. menu = [['user', load_lang('return')]]
  89. ))