contentmatcher/app.py

166 lines
5.0 KiB
Python
Raw Normal View History

2022-04-25 00:32:17 +02:00
import os
2022-06-12 18:46:07 +02:00
from textwrap import indent
2022-06-05 21:20:23 +02:00
from flask import Flask, redirect, render_template, session, request, url_for
from datetime import date
2022-04-25 00:32:17 +02:00
2022-06-05 21:20:23 +02:00
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
2022-05-22 16:52:01 +02:00
2022-05-20 00:01:56 +02:00
from auth import login_required, bp as auth_bp
from deck import bp as deck_bp
from menu import bp as menu_bp
from upload import bp as upload_bp
2022-05-22 16:52:01 +02:00
from create_db import Card, Deck
2022-06-07 00:28:11 +02:00
from config import CONFIG
2022-05-22 16:52:01 +02:00
engine = create_engine(CONFIG['DB_CONNECTION'])
dbsessionmaker = sessionmaker(bind=engine)
dbsession = dbsessionmaker()
2022-04-25 00:32:17 +02:00
def create_app(test_config=None):
# create and configure the app
app = Flask(__name__, instance_relative_config=True)
app.config.from_mapping(
SECRET_KEY='dev',
DATABASE=os.path.join(app.instance_path, 'flaskr.sqlite'),
2022-05-13 18:23:15 +02:00
) # = kaj naj tu piše?
2022-04-25 00:32:17 +02:00
if test_config is None:
# load the instance config, if it exists, when not testing
app.config.from_pyfile('config.py', silent=True)
else:
# load the test config if passed in
app.config.from_mapping(test_config)
# ensure the instance folder exists
try:
os.makedirs(app.instance_path)
except OSError:
pass
2022-05-20 00:01:56 +02:00
2022-05-17 21:27:51 +02:00
@app.route('/')
2022-05-20 00:01:56 +02:00
@login_required
2022-05-17 21:27:51 +02:00
def index():
2022-05-20 00:01:56 +02:00
return 'redirecting' # meče skoz nazaj na login TODO
2022-06-12 18:46:07 +02:00
@app.route('/deck/beta', methods=["GET", "POST"])
def deck2():
if request.method == 'POST':
pass
return render_template("deck/index.html")
2022-05-20 00:01:56 +02:00
#@login_required
2022-06-08 20:56:11 +02:00
@app.route('/deck/index', methods=["GET", "POST"])
2022-05-20 00:01:56 +02:00
def deck():
2022-06-12 18:46:07 +02:00
if not 'user_id' in session:
return index()
user_id = session['user_id']
username = session['username']
#pokliče na bazo, da dobi str card idjev, ga spremeni v list in srevira karte po idjih
deck_query = dbsession.query(Deck).filter(Deck.owner_id == user_id)
deck_object = deck_query.filter(Deck.completed == False).first()
# @TODO: ce deck, ne obstaja, kaj naj zaj jas?
deck_id = deck_object.id
# Smo oddali obrazec?
if request.method == 'POST':
card_id = request.form.get('card_id', None)
if not card_id:
raise Exception("card_id je nujen!")
submit_card = dbsession.query(Card).get(card_id)
# @TODO preveri, ali je card del trenutnega decka!
2022-06-12 18:46:07 +02:00
# Ali damo share? Potem nastavi na share in ponovi obrazec
share = request.form.get("share", None)
if share:
print(share)
# @TODO logika za share!
# Če ne, gre za rate!
else:
rate = request.form.get('rate', None) #je to nevarno??
print(rate)
2022-06-12 18:46:07 +02:00
if not rate:
raise Exception("manjka rate info!")
if rate == "Yes":
2022-06-12 18:46:07 +02:00
submit_card.interest_rate = 1
2022-06-07 00:28:11 +02:00
elif rate == "Maybe":
k = 0.5
2022-06-12 18:46:07 +02:00
print(submit_card)
submit_card.interest_rate= abs(submit_card.interest_rate*k)
elif rate == "No":
k = 0.1
2022-06-12 18:46:07 +02:00
submit_card.interest_rate = abs(submit_card.interest_rate*k)
# zaporedno število trenutnega carda v decku
next_card = deck_object.current_card + 1
# Ali je deck končan?
if next_card >= deck_object.number_of_cards:
deck_object.completed = True
dbsession.commit()
return redirect(url_for("menu.index"))
deck_object.current_card = next_card
dbsession.commit()
#dbsession.query(Card).filter(Card.id == card.id).update({'last_review': date()})
# Loudamo naslednjo karto v decku
show_card_index = deck_object.current_card
show_card_id = deck_object.cards_by_id.split(",")[show_card_index]
show_card = dbsession.query(Card).get(show_card_id)
if not show_card:
raise Exception("Ne najdem naslednje karte")
# Prikaži obrazec
return render_template("deck/index.html", username=username, card=show_card)
@app.route("/share_button", methods=["GET", "POST"])
def share_button():
userid = session["user_id"]
username = session["username"]
card_number = session["card_number"]
print("share!!!")
return redirect(url_for("deck"))
2022-05-22 16:52:01 +02:00
2022-05-20 00:01:56 +02:00
@app.route('/logout')
def logout():
session.pop("user_id", None)
return index()
2022-06-04 14:21:28 +02:00
@app.route('/match')
def match():
return "match"
2022-06-04 14:21:28 +02:00
2022-05-20 00:01:56 +02:00
#app.register_blueprint(bp) # ??
app.register_blueprint(auth_bp)
app.register_blueprint(deck_bp)
app.register_blueprint(menu_bp)
app.register_blueprint(upload_bp)
2022-05-20 00:01:56 +02:00
app.add_url_rule('/', endpoint='index')
2022-05-13 18:23:15 +02:00
return app
2022-05-15 22:12:18 +02:00
app = create_app()
app.run(debug=True, host="0.0.0.0")