igdb/code/app/routes.py

91 lines
2.6 KiB
Python

from app import app
from app.forms import AnnualForm, LoginForm, PlotForm
from database.queries import query_annual_data, query_plot_data, query_user
from flask import flash, redirect, render_template, request, url_for, send_file
from flask_login import current_user, login_required, login_user, logout_user
from processing.dataframe import create_table, create_plot
from werkzeug.urls import url_parse
@app.route("/")
@app.route("/index")
def index():
return render_template("index.html", title="Home Page")
@app.route("/login", methods=["GET", "POST"])
def login():
if current_user.is_authenticated:
return redirect(url_for("admin"))
form = LoginForm()
if form.validate_on_submit():
user = query_user(form)
if user is None or not user.check_password(form.password.data):
flash("Invalid username or password")
return redirect(url_for("login"))
login_user(user, remember=form.remember_me.data)
next_page = request.args.get("next")
if not next_page or url_parse(next_page).netloc != "":
next_page = url_for("admin")
return redirect(next_page)
return render_template("login.html", title="Sign In", form=form)
@app.route("/logout")
def logout():
logout_user()
return redirect(url_for("index"))
@app.route("/admin")
@login_required
def admin():
return render_template("admin.html", title="Admin Page")
@app.route("/nuke")
@login_required
def nuke():
return render_template("nuked.html", title="NUKE THE SYSTEM!")
@app.route("/data")
def data():
return render_template("data.html", title="Data")
@app.route("/table_selection", methods=["GET", "POST"])
def table_selection():
form = AnnualForm()
if form.validate_on_submit():
query = query_annual_data(form)
table = create_table(query.statement)
return render_template("table.html", table=table, title="Table")
return render_template("table_selection.html", title="Data", form=form)
@app.route("/table")
def table():
return render_template("table.html", table=table, title="Table")
@app.route("/plot_selection", methods=["GET", "POST"])
def plot_selection():
form = PlotForm()
if form.validate_on_submit():
query = query_plot_data(form)
plot = create_plot(query.statement)
return render_template("plot.html", title="Plot", plot=plot)
return render_template("plot_selection.html", title="Data", form=form)
@app.route("/plot")
def plot():
return render_template("plot.html", title="Plot", plot=plot)
@app.route("/figure")
def figure(query):
fig = create_plot(query)
return send_file(fig, mimetype="image/png")