PCv5/app/routes/account/login.py

77 lines
2.6 KiB
Python
Raw Normal View History

2019-02-03 16:20:05 +01:00
from flask import redirect, url_for, request, flash
from flask_login import login_user, logout_user, login_required, current_user
from urllib.parse import urlparse, urljoin
2019-02-03 16:20:05 +01:00
from app import app
2019-02-03 16:52:42 +01:00
from app.forms.login import LoginForm
2020-08-25 22:57:45 +02:00
from app.models.user import Member
from app.models.priv import Group
2019-02-03 16:20:05 +01:00
from app.utils.render import render
2020-07-21 21:06:00 +02:00
from app.utils.send_mail import send_validation_mail
import datetime
2019-02-03 16:20:05 +01:00
2019-12-16 23:57:50 +01:00
@app.route('/connexion', methods=['GET', 'POST'])
2019-02-03 16:20:05 +01:00
def login():
2020-07-21 21:06:00 +02:00
# If something failed, return abort("Message")
def _abort(msg):
flash(msg, 'error')
if request.referrer:
return redirect(request.referrer)
return redirect(url_for('index'))
if current_user.is_authenticated:
return redirect(url_for('index'))
2019-02-03 16:20:05 +01:00
form = LoginForm()
lateral = LoginForm(prefix="menu_")
if lateral.validate_on_submit():
form = lateral
2019-02-03 16:20:05 +01:00
if form.validate_on_submit():
member = Member.query.filter_by(name=form.username.data).first()
# Check if member can login
if member is not None and "No login" in [g.name for g in member.groups]:
2020-07-21 21:06:00 +02:00
return _abort('Cet utilisateur ne peut pas se connecter')
# Check if password is ok
2019-02-03 16:20:05 +01:00
if member is None or not member.check_password(form.password.data):
2020-07-21 21:06:00 +02:00
return _abort('Pseudo ou mot de passe invalide')
# Check if user is activated
if member.email_confirmed == False:
# Send another mail
send_validation_mail(member.name, member.email)
return _abort(f"Email non confirmé. Un mail de confirmation a de nouveau été envoyé à l'adresse {member.email}")
# Login & update time-based trophies
login_user(member, remember=form.remember_me.data,
duration=datetime.timedelta(days=7))
member.update_trophies("on-login")
# Redirect safely (https://huit.re/open-redirect)
def is_safe_url(target):
ref_url = urlparse(request.host_url)
test_url = urlparse(urljoin(request.host_url, target))
return test_url.scheme in ('http', 'https') and \
ref_url.netloc == test_url.netloc
next = request.args.get('next')
if next and is_safe_url(next):
return redirect(next)
if request.referrer:
return redirect(request.referrer)
2019-02-03 16:20:05 +01:00
return redirect(url_for('index'))
return render('account/login.html', form=form)
2019-02-03 16:20:05 +01:00
2019-12-16 23:57:50 +01:00
@app.route('/deconnexion')
2019-02-03 16:20:05 +01:00
@login_required
def logout():
logout_user()
flash('Déconnexion réussie', 'info')
if request.referrer:
return redirect(request.referrer)
return redirect(url_for('index'))