| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- from .tool.func import *
- async def login_login():
- with get_db_connect() as conn:
- curs = conn.cursor()
- ip = ip_check()
- if ip_or_user(ip) == 0:
- return redirect(conn, '/user')
- if (await ban_check(None, 'login'))[0] == 1:
- return await re_error(conn, 0)
-
- return_url = flask.request.args.get('return', '')
- if not return_url.startswith('/') or return_url.startswith('//') or '\\' in return_url:
- return_url = ''
- if flask.request.method == 'POST':
- if await captcha_post(conn, flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
- return await re_error(conn, 13)
- user_agent = flask.request.headers.get('User-Agent', '')
- user_id = flask.request.form.get('id', '')
- user_pw = flask.request.form.get('pw', '')
- curs.execute(db_change("select data from user_set where id = ? and name = 'pw'"), [user_id])
- db_data = curs.fetchall()
- if not db_data:
- return await re_error(conn, 2)
- else:
- db_user_pw = db_data[0][0]
-
- curs.execute(db_change("select data from user_set where id = ? and name = 'encode'"), [user_id])
- db_data = curs.fetchall()
- if not db_data:
- return await re_error(conn, 2)
- else:
- db_user_encode = db_data[0][0]
- if pw_check(conn, user_pw, db_user_pw, db_user_encode, user_id) != 1:
- return await re_error(conn, 10)
- curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [user_id])
- fa_data = curs.fetchall()
- if fa_data and fa_data[0][0] != '':
- flask.session['login_id'] = user_id
- return redirect(conn, '/login/2fa')
- else:
- flask.session['id'] = user_id
- ua_plus(conn, user_id, ip, user_agent, get_time())
- if return_url != '':
- return redirect(conn, return_url)
- else:
- return redirect(conn, '/user')
- else:
- return await render_template(
- await get_lang('login'),
- '''
- <form method="post">
- <input class="__ON_INPUT__" placeholder="''' + await get_lang('id') + '''" name="id" type="text">
- <hr class="main_hr">
- <input class="__ON_INPUT__" placeholder="''' + await get_lang('password') + '''" name="pw" type="password">
- <hr class="main_hr">
- <!-- <label class="__ON_CHECKLABEL__"><input class="__ON_CHECKBOX__" type="checkbox" name="auto_login"> ''' + await get_lang('auto_login') + ''' (''' + await get_lang('not_working') + ''')</label>
- <hr class="main_hr"> -->
- ''' + await captcha_get(conn) + '''
- <button class="__ON_BUTTON__" type="submit">''' + await get_lang('login') + '''</button>
- ''' + await http_warning() + '''
- </form>
- ''',
- 0,
- [['user', await get_lang('return')]]
- )
|