Ross Mountjoy 62191b21b8 ##### Updated to version 0.6!
> Version 0.6 brings DashMachine one big step forward to being a finished product by adding a gui to edit the various settings in the config.ini.

**Changelog**
- improvements to /home including 'pinned' cards, multi-select tag filtering, 'action providers' allowing you to do web searches from the searchbar
- rebuilt sidenav with list view, mirroring filter/search/collapse state of the homepage
- /settings and /home now on same route
- dynamic reloading of settings (no more page reloads)
- dedicated config.ini editor slide-out
- settings editor slide-out
- card editor slide-out
- better access group control
- dedicated documentation pages
- improved documentation
- new system for automatically generating documentation for platforms
- ability to load custom platforms
- added an 'on_starup' method for platforms allowing for registering api routes. (example coming soon)
2020-05-07 09:27:18 -04:00

52 lines
1.6 KiB
Python
Executable File

from flask import render_template, url_for, redirect, Blueprint, jsonify
from flask_login import login_user, logout_user
from dashmachine.user_system.forms import LoginForm
from dashmachine.user_system.models import User
from dashmachine import bcrypt
from dashmachine.version import version, revision_number
from dashmachine.main.utils import public_route
user_system = Blueprint("user_system", __name__)
# ------------------------------------------------------------------------------
# User system routes
# ------------------------------------------------------------------------------
# login page
@public_route
@user_system.route("/login", methods=["GET"])
def login():
dm_version = f"{version}-{revision_number}"
form = LoginForm()
return render_template(
"user/login.html", title="Login", form=form, dm_version=dm_version
)
@public_route
@user_system.route("/check_login", methods=["POST"])
def check_login():
form = LoginForm()
if form.validate_on_submit():
user = User.query.filter_by(username=form.username.data.lower()).first()
if not user:
response = {"err": "User not found"}
elif bcrypt.check_password_hash(user.password, form.password.data):
login_user(user, remember=form.remember.data)
response = {"url": url_for("main.home")}
else:
response = {"err": "Password is wrong"}
else:
response = {"err": str(form.errors)}
return jsonify(data=response)
# 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"))