86 lines
3.1 KiB
Python
86 lines
3.1 KiB
Python
from flask import render_template, flash, redirect, url_for, request
|
|
from flask_login import login_user, logout_user, current_user, login_required
|
|
from werkzeug.urls import url_parse
|
|
from app import app, db
|
|
from app.forms import LoginForm, RegistrationForm, UpdateAccountForm
|
|
from app.models.users import Member
|
|
|
|
# Ce truc c'est la vie !
|
|
def _render_template(*args, **kwargs):
|
|
# TODO: debugguer cette merde : au logout, ça foire
|
|
# if current_user.is_authenticated:
|
|
# login_form = LoginForm()
|
|
# return render_template(*args, **kwargs, login_form=login_form)
|
|
# return render_template(*args, **kwargs)
|
|
login_form = LoginForm()
|
|
return render_template(*args, **kwargs, login_form=login_form)
|
|
|
|
|
|
@app.route('/')
|
|
def index():
|
|
login_form = LoginForm()
|
|
return _render_template('index.html')
|
|
|
|
@app.route('/login', methods=['GET', 'POST'])
|
|
def login():
|
|
if request.method == 'GET':
|
|
return redirect(url_for('index'))
|
|
login_form = LoginForm()
|
|
if login_form.validate_on_submit():
|
|
member = Member.query.filter_by(name=login_form.username.data).first()
|
|
if member is None or not member.check_password(login_form.password.data):
|
|
flash('Pseudo ou mot de passe invalide', 'error')
|
|
return redirect(request.referrer)
|
|
login_user(member, remember=login_form.remember_me.data)
|
|
flash('Connexion réussie', 'info')
|
|
return redirect(request.referrer)
|
|
|
|
@app.route('/logout')
|
|
def logout():
|
|
logout_user()
|
|
flash('Déconnexion réussie', 'info')
|
|
return redirect(url_for('index'))
|
|
|
|
|
|
@app.route('/account', methods=['GET', 'POST'])
|
|
def account():
|
|
if not current_user.is_authenticated:
|
|
flash('Veuillez vous authentifier', 'warning')
|
|
return redirect(url_for('index'))
|
|
form = UpdateAccountForm()
|
|
if request.method == "POST":
|
|
if form.validate_on_submit():
|
|
current_user.update({
|
|
"email": form.email.data,
|
|
"password": form.password.data,
|
|
"signature": form.signature.data,
|
|
"bio": form.biography.data,
|
|
"birthday": form.birthday.data,
|
|
"newsletter": form.newsletter.data
|
|
})
|
|
db.session.add(current_user)
|
|
db.session.commit()
|
|
flash('Modifications effectuées', 'ok')
|
|
else:
|
|
flash('Erreur lors de la modification', 'error')
|
|
return _render_template('account.html', form=form)
|
|
|
|
@app.route('/register', methods=['GET', 'POST'])
|
|
def register():
|
|
if current_user.is_authenticated:
|
|
return redirect(url_for('index'))
|
|
form = RegistrationForm()
|
|
if form.validate_on_submit():
|
|
member = Member(form.username.data, form.email.data, form.password.data)
|
|
db.session.add(member)
|
|
db.session.commit()
|
|
flash('Inscription réussie', 'ok')
|
|
return redirect(url_for('validation'))
|
|
return _render_template('register.html', title='Register', form=form)
|
|
|
|
@app.route('/register/validation/')
|
|
def validation():
|
|
if current_user.is_authenticated :
|
|
return redirect(url_for('index'))
|
|
return _render_template('validation.html')
|