login_register.py 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. from .tool.func import *
  2. def login_register_2():
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. if ban_check(None, 'login') == 1:
  6. return re_error('/ban')
  7. ip = ip_check()
  8. admin = admin_check()
  9. if admin != 1 and ip_or_user(ip) == 0:
  10. return redirect('/user')
  11. if admin != 1:
  12. curs.execute(db_change('select data from other where name = "reg"'))
  13. set_d = curs.fetchall()
  14. if set_d and set_d[0][0] == 'on':
  15. return re_error('/ban')
  16. if flask.request.method == 'POST':
  17. # 리캡차
  18. if captcha_post(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  19. return re_error('/error/13')
  20. else:
  21. captcha_post('', 0)
  22. user_id = flask.request.form.get('id', '')
  23. user_pw = flask.request.form.get('pw', '')
  24. user_repeat = flask.request.form.get('pw2', '')
  25. # PW 검증
  26. if user_id == '' or user_pw == '':
  27. return re_error('/error/27')
  28. if user_pw != user_repeat:
  29. return re_error('/error/20')
  30. # PW 길이 제한
  31. curs.execute(db_change("select data from other where name = 'password_min_length'"))
  32. db_data = curs.fetchall()
  33. if db_data and db_data[0][0] != '':
  34. password_min_length = int(number_check(db_data[0][0]))
  35. if password_min_length > len(user_pw):
  36. return re_error('/error/40')
  37. if do_user_name_check(user_id) == 1:
  38. return re_error('/error/8')
  39. # 중복 확인
  40. curs.execute(db_change("select id from user_set where id = ?"), [user_id])
  41. if curs.fetchall():
  42. return re_error('/error/6')
  43. if admin != 1:
  44. # 이메일 필요시 /register/email로 발송
  45. curs.execute(db_change('select data from other where name = "email_have"'))
  46. sql_data = curs.fetchall()
  47. if sql_data and sql_data[0][0] != '':
  48. # 임시로 세션에 저장
  49. flask.session['reg_id'] = user_id
  50. flask.session['reg_pw'] = user_pw
  51. return redirect('/register/email')
  52. # 가입 승인 필요시 /register/submit으로 발송
  53. curs.execute(db_change('select data from other where name = "requires_approval"'))
  54. sql_data = curs.fetchall()
  55. if sql_data and sql_data[0][0] != '':
  56. flask.session['submit_id'] = user_id
  57. flask.session['submit_pw'] = user_pw
  58. return redirect('/register/submit')
  59. # 전부 아니면 바로 가입 후 /login으로 발송
  60. add_user(user_id, user_pw)
  61. conn.commit()
  62. return redirect('/login')
  63. else:
  64. curs.execute(db_change('select data from other where name = "contract"'))
  65. data = curs.fetchall()
  66. contract = (data[0][0] + '<hr class="main_hr">') if data and data[0][0] != '' else ''
  67. curs.execute(db_change("select data from other where name = 'password_min_length'"))
  68. db_data = curs.fetchall()
  69. if db_data and db_data[0][0] != '':
  70. password_min_length = ' (' + load_lang('password_min_length') + ' : ' + db_data[0][0] + ')'
  71. else:
  72. password_min_length = ''
  73. return easy_minify(flask.render_template(skin_check(),
  74. imp = [load_lang('register'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  75. data = '''
  76. <form method="post">
  77. ''' + contract + '''
  78. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  79. <hr class="main_hr">
  80. <input placeholder="''' + load_lang('password') + password_min_length + '''" name="pw" type="password">
  81. <hr class="main_hr">
  82. <input placeholder="''' + load_lang('password_confirm') + '''" name="pw2" type="password">
  83. <hr class="main_hr">
  84. ''' + captcha_get() + '''
  85. <button type="submit">''' + load_lang('save') + '''</button>
  86. ''' + http_warning() + '''
  87. </form>
  88. ''',
  89. menu = [['user', load_lang('return')]]
  90. ))