from app import app, db from flask import render_template, redirect, request, url_for, flash from flask_login import current_user, login_user, login_required, logout_user from forms import LoginForm, RegisterForm from tables import User @app.route("/login", methods=["GET", "POST"]) def login(): form = LoginForm() username = form.username.data password = form.password.data if form.validate_on_submit(): # Valid submission user = User.query.filter_by(username=username).first() # TODO: show user if login succeeded if user and user.verify_password(password): login_user(user) return redirect(url_for("home")) else: flash("Invalid username or password", "danger") return render_template("user/login.html", form=form) @app.route("/logout", methods=["GET", "POST"]) @login_required def logout(): logout_user() return redirect("/") @app.route("/register", methods=["GET", "POST"]) def register(): form = RegisterForm() # Load data from form username = form.username.data password = form.password.data email = form.email.data if form.validate_on_submit(): # Valid submission user = User.query.filter_by(username=username).first() if not user: # No user with this username user = User(username, password, email) db.session.add(user) db.session.commit() return redirect(url_for("login")) else: flash("User already exists", "danger") return render_template("user/register.html", form=form)