from datetime import datetime from flask import Blueprint, render_template, redirect, url_for, flash, request from flask_login import login_user, logout_user, login_required, current_user from app.extensions import db from app.models.admin_user import AdminUser bp = Blueprint('auth', __name__) @bp.route('/login', methods=['GET', 'POST']) def login(): if current_user.is_authenticated: return redirect(url_for('dashboard.index')) if request.method == 'POST': username = request.form.get('username', '').strip() password = request.form.get('password', '') if not username or not password: flash('Please enter username and password.', 'danger') return render_template('auth/login.html') user = AdminUser.query.filter_by(username=username).first() if user and user.is_active and user.check_password(password): user.last_login = datetime.utcnow() db.session.commit() login_user(user, remember=False) next_page = request.args.get('next') return redirect(next_page or url_for('dashboard.index')) flash('Invalid username or password.', 'danger') return render_template('auth/login.html') @bp.route('/logout') @login_required def logout(): logout_user() flash('You have been logged out.', 'info') return redirect(url_for('auth.login'))