2020-01-06 07:21:52 -05:00

49 lines
1.5 KiB
Python
Executable File

from flask import render_template, url_for, redirect, Blueprint
from flask_login import login_user, logout_user, current_user
from dashmachine.user_system.forms import LoginForm
from dashmachine.user_system.models import User
from dashmachine import bcrypt
from dashmachine.main.utils import public_route
user_system = Blueprint("user_system", __name__)
# *****REMINDER*****
# user accounts for this platform can only be created/edited with the
# functions in user_system.utils
# ------------------------------------------------------------------------------
# User system routes
# ------------------------------------------------------------------------------
# login page
@public_route
@user_system.route("/login", methods=["GET", "POST"])
def login():
user = User.query.first()
if current_user.is_authenticated:
return redirect(url_for("main.home"))
form = LoginForm()
if form.validate_on_submit():
user = User.query.filter_by(email=form.email.data.lower()).first()
if user and bcrypt.check_password_hash(user.password, form.password.data):
login_user(user, remember=form.remember.data)
return redirect(url_for("main.home"))
else:
print("password was wrong")
return redirect(url_for("user_system.login"))
return render_template("user/login.html", title="Login", form=form)
# this logs the user out and redirects to the login page
@user_system.route("/logout")
def logout():
logout_user()
return redirect(url_for("user_system.login"))