| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- from .tool.func import *
- def login_register_2(conn):
- curs = conn.cursor()
- if ban_check(None, 'login') == 1:
- return re_error('/ban')
- ip = ip_check()
- admin = admin_check()
- if admin != 1 and ip_or_user(ip) == 0:
- return redirect('/user')
- if admin != 1:
- curs.execute(db_change('select data from other where name = "reg"'))
- set_d = curs.fetchall()
- if set_d and set_d[0][0] == 'on':
- return re_error('/ban')
- if flask.request.method == 'POST':
- # 리캡차
- if captcha_post(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
- return re_error('/error/13')
- else:
- captcha_post('', 0)
- # 아이디 비밀번호 검증 파트
- user_id = flask.request.form.get('id', '')
- user_pw = flask.request.form.get('pw', '')
- user_repeat = flask.request.form.get('pw2', '')
- if user_id == '' or user_pw == '':
- return re_error('/error/27')
- if user_pw != user_repeat:
- return re_error('/error/20')
- if re.search(r'(?:[^A-Za-zㄱ-힣0-9])', user_id):
- return re_error('/error/8')
- curs.execute(db_change('select html from html_filter where kind = "name"'))
- set_d = curs.fetchall()
- for i in set_d:
- check_r = re.compile(i[0], re.I)
- if check_r.search(user_id):
- return re_error('/error/8')
- if len(user_id) > 32:
- return re_error('/error/7')
- curs.execute(db_change("select id from user_set where id = ?"), [user_id])
- if curs.fetchall():
- return re_error('/error/6')
-
- if admin != 1:
- # 이메일 필요시 /register/email로 발송
- curs.execute(db_change('select data from other where name = "email_have"'))
- sql_data = curs.fetchall()
- if sql_data and sql_data[0][0] != '':
- # 임시로 세션에 저장
- flask.session['reg_id'] = user_id
- flask.session['reg_pw'] = user_pw
- return redirect('/register/email')
-
- # 가입 승인 필요시 /register/submit으로 발송
- curs.execute(db_change('select data from other where name = "requires_approval"'))
- sql_data = curs.fetchall()
- if sql_data and sql_data[0][0] != '':
- flask.session['submit_id'] = user_id
- flask.session['submit_pw'] = user_pw
-
- return redirect('/register/submit')
-
- # 전부 아니면 바로 가입 후 /login으로 발송
- add_user(user_id, user_pw)
-
- return redirect('/login')
- else:
- curs.execute(db_change('select data from other where name = "contract"'))
- data = curs.fetchall()
- contract = (data[0][0] + '<hr class="main_hr">') if data and data[0][0] != '' else ''
-
- return easy_minify(flask.render_template(skin_check(),
- imp = [load_lang('register'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
- data = '''
- <form method="post">
- ''' + contract + '''
-
- <input placeholder="''' + load_lang('id') + '''" name="id" type="text">
- <hr class="main_hr">
-
- <input placeholder="''' + load_lang('password') + '''" name="pw" type="password">
- <hr class="main_hr">
-
- <input placeholder="''' + load_lang('password_confirm') + '''" name="pw2" type="password">
- <hr class="main_hr">
-
- ''' + approval_question + '''
- ''' + captcha_get() + '''
-
- <!--
- <a href="" id="oauth_google">(Google)</a>
- <hr class="main_hr">
- -->
-
- <button type="submit">''' + load_lang('save') + '''</button>
-
- ''' + http_warning() + '''
- </form>
- <script>
- document.getElementById('oauth_google').href = '' +
- 'https://accounts.google.com/o/oauth2/auth' +
- '?client_id=ID' +
- '&redirect_uri=' + window.location.origin +
- '&response_type=code' +
- '&scope=https://www.googleapis.com/auth/userinfo.email' +
- '&approval_prompt=force' +
- '&access_type=offline' +
- '';
- </script>
- ''',
- menu = [['user', load_lang('return')]]
- ))
|