login_register.py 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. from .tool.func import *
  2. def login_register_2(conn):
  3. curs = conn.cursor()
  4. if ban_check(None, 'login') == 1:
  5. return re_error('/ban')
  6. ip = ip_check()
  7. admin = admin_check()
  8. if admin != 1 and ip_or_user(ip) == 0:
  9. return redirect('/user')
  10. if admin != 1:
  11. curs.execute(db_change('select data from other where name = "reg"'))
  12. set_d = curs.fetchall()
  13. if set_d and set_d[0][0] == 'on':
  14. return re_error('/ban')
  15. if flask.request.method == 'POST':
  16. # 리캡차
  17. if captcha_post(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  18. return re_error('/error/13')
  19. else:
  20. captcha_post('', 0)
  21. user_id = flask.request.form.get('id', '')
  22. user_pw = flask.request.form.get('pw', '')
  23. user_repeat = flask.request.form.get('pw2', '')
  24. # PW 검증
  25. if user_id == '' or user_pw == '':
  26. return re_error('/error/27')
  27. if user_pw != user_repeat:
  28. return re_error('/error/20')
  29. # PW 길이 제한
  30. curs.execute(db_change("select data from other where name = 'password_min_length'"))
  31. db_data = curs.fetchall()
  32. if db_data and db_data[0][0] != '':
  33. password_min_length = int(number_check(db_data[0][0]))
  34. if password_min_length > len(user_pw):
  35. return re_error('/error/40')
  36. # ID 글자 확인
  37. if re.search(r'(?:[^A-Za-zㄱ-힣0-9])', user_id):
  38. return re_error('/error/8')
  39. # ID 필터
  40. curs.execute(db_change('select html from html_filter where kind = "name"'))
  41. set_d = curs.fetchall()
  42. for i in set_d:
  43. check_r = re.compile(i[0], re.I)
  44. if check_r.search(user_id):
  45. return re_error('/error/8')
  46. # ID 길이 제한 (32글자)
  47. if len(user_id) > 32:
  48. return re_error('/error/7')
  49. # 중복 확인
  50. curs.execute(db_change("select id from user_set where id = ?"), [user_id])
  51. if curs.fetchall():
  52. return re_error('/error/6')
  53. if admin != 1:
  54. # 이메일 필요시 /register/email로 발송
  55. curs.execute(db_change('select data from other where name = "email_have"'))
  56. sql_data = curs.fetchall()
  57. if sql_data and sql_data[0][0] != '':
  58. # 임시로 세션에 저장
  59. flask.session['reg_id'] = user_id
  60. flask.session['reg_pw'] = user_pw
  61. return redirect('/register/email')
  62. # 가입 승인 필요시 /register/submit으로 발송
  63. curs.execute(db_change('select data from other where name = "requires_approval"'))
  64. sql_data = curs.fetchall()
  65. if sql_data and sql_data[0][0] != '':
  66. flask.session['submit_id'] = user_id
  67. flask.session['submit_pw'] = user_pw
  68. return redirect('/register/submit')
  69. # 전부 아니면 바로 가입 후 /login으로 발송
  70. add_user(user_id, user_pw)
  71. conn.commit()
  72. return redirect('/login')
  73. else:
  74. curs.execute(db_change('select data from other where name = "contract"'))
  75. data = curs.fetchall()
  76. contract = (data[0][0] + '<hr class="main_hr">') if data and data[0][0] != '' else ''
  77. curs.execute(db_change("select data from other where name = 'password_min_length'"))
  78. db_data = curs.fetchall()
  79. if db_data and db_data[0][0] != '':
  80. password_min_length = ' (' + load_lang('password_min_length') + ' : ' + db_data[0][0] + ')'
  81. else:
  82. password_min_length = ''
  83. return easy_minify(flask.render_template(skin_check(),
  84. imp = [load_lang('register'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  85. data = '''
  86. <form method="post">
  87. ''' + contract + '''
  88. <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
  89. <hr class="main_hr">
  90. <input placeholder="''' + load_lang('password') + password_min_length + '''" name="pw" type="password">
  91. <hr class="main_hr">
  92. <input placeholder="''' + load_lang('password_confirm') + '''" name="pw2" type="password">
  93. <hr class="main_hr">
  94. ''' + captcha_get() + '''
  95. <!--
  96. <a href="" id="oauth_google">(Google)</a>
  97. <hr class="main_hr">
  98. -->
  99. <button type="submit">''' + load_lang('save') + '''</button>
  100. ''' + http_warning() + '''
  101. </form>
  102. <script>
  103. document.getElementById('oauth_google').href = '' +
  104. 'https://accounts.google.com/o/oauth2/auth' +
  105. '?client_id=ID' +
  106. '&redirect_uri=' + window.location.origin +
  107. '&response_type=code' +
  108. '&scope=https://www.googleapis.com/auth/userinfo.email' +
  109. '&approval_prompt=force' +
  110. '&access_type=offline' +
  111. '';
  112. </script>
  113. ''',
  114. menu = [['user', load_lang('return')]]
  115. ))