101 lines
3.8 KiB
Python
101 lines
3.8 KiB
Python
from flask import Blueprint, render_template, request, jsonify, redirect
|
|
unsecure = Blueprint('unsecure', __name__, url_prefix='/unsecure')
|
|
from modules.persistence import load_dict, save_dict
|
|
from modules.persistence import esp_conn_infos
|
|
from datetime import datetime
|
|
from modules.socketio import resend_static_data
|
|
from modules.db import get_coffee_count, get_coffees
|
|
from obj import user
|
|
import random
|
|
|
|
|
|
@unsecure.route('/')
|
|
def index():
|
|
username = request.args.get('username')
|
|
userid = request.args.get('userid')
|
|
|
|
if not username or not userid:
|
|
return redirect('/unsecure/login')
|
|
|
|
valid_user = user.User.validate_user(username=username, userid=userid)
|
|
print(valid_user)
|
|
if not valid_user:
|
|
return redirect('/unsecure/login')
|
|
|
|
|
|
water = load_dict("water")
|
|
beans = load_dict("beans")
|
|
machine = load_dict("machine")
|
|
coffee_count = get_coffee_count()
|
|
# print(f"[DEBUG] Water: {water}, Beans: {beans}, Machine: {machine}")
|
|
return render_template('index.html', title='gimmiCoffee', water=water, beans=beans, machine=machine, esp_conn_infos=esp_conn_infos, coffee_count=coffee_count, username = username)
|
|
|
|
@unsecure.route('/verify', methods=['POST'])
|
|
def verify():
|
|
username = request.args.get('username')
|
|
password = request.args.get('pass')
|
|
|
|
if not username or not password:
|
|
return jsonify({'route': '/unsecure/login'}), 400
|
|
|
|
is_existent = user.User.authenticate_user(username, password)
|
|
if is_existent:
|
|
# Erfolgreich eingeloggt → weiterleiten
|
|
return jsonify({'route': f"/unsecure/?username={is_existent.get_name()}&userid={is_existent.get_id()}"})
|
|
else:
|
|
# Fehler → zurück zur Login-Seite
|
|
return jsonify({'route': '/unsecure/login', 'error': 'Invalid credentials'}), 401
|
|
|
|
@unsecure.route('/register', methods=['POST'])
|
|
def register():
|
|
username = request.args.get('username')
|
|
password = request.args.get('pass')
|
|
userid = random.randint(10000, 99999)
|
|
print(username, password, userid)
|
|
if not username or not password:
|
|
return jsonify({'err': 'invalidData'}), 400
|
|
|
|
new_user = user.User(user_id=userid, name=username, email = "", password=password)
|
|
new_user.save_to_db()
|
|
return redirect('/unsecure/login')
|
|
|
|
@unsecure.route('/login')
|
|
def login():
|
|
return render_template('login.html')
|
|
|
|
@unsecure.route('/refill-water', methods=['POST'])
|
|
def update_water():
|
|
water = load_dict("water")
|
|
water["lastFilled"] = datetime.now()
|
|
water["fill"] = 100
|
|
water["coffeesOnFill"] = 0
|
|
water["refilled"] = water["refilled"] + 1
|
|
save_dict("water", water)
|
|
resend_static_data()
|
|
return jsonify({"status": "ok", "task": "refill-water-executed"})
|
|
|
|
@unsecure.route('/refill-beans', methods=['POST'])
|
|
def update_beans():
|
|
beans = load_dict("beans")
|
|
beans["lastFilled"] = datetime.now()
|
|
beans["fill"] = 100
|
|
beans["coffeesOnFill"] = 0
|
|
beans["refilled"] = beans["refilled"] + 1
|
|
save_dict("beans", beans)
|
|
resend_static_data()
|
|
return jsonify({"status": "ok", "task": "refill-beans-executed"})
|
|
|
|
@unsecure.route('/coffees-made')
|
|
def coffees_made():
|
|
coffees = get_coffees()
|
|
return render_template('coffees.html', title='gimmiCoffee', coffees=coffees)
|
|
|
|
@unsecure.route('/water')
|
|
def water():
|
|
water = load_dict("water")
|
|
return render_template('water.html', title='gimmiCoffee', last_filled=datetime.strptime(water["lastFilled"], "%Y-%m-%d %H:%M:%S.%f"), current_level=water["fill"], total_refills=water["refilled"], coffees_made=water["coffeesOnFill"])
|
|
@unsecure.route('/beans')
|
|
def beans():
|
|
beans = load_dict("beans")
|
|
return render_template('beans.html', title='gimmiCoffee', last_filled=datetime.strptime(beans["lastFilled"], "%Y-%m-%d %H:%M:%S.%f"), current_level=beans["fill"], total_refills=beans["refilled"], coffees_made=beans["coffeesOnFill"])
|