Files
qr-code_manager/app/utils/auth.py
ske087 264a81652a Production deployment fixes and enhancements
- Added environment variable loading with python-dotenv
- Fixed Docker session permissions by using /tmp directory
- Updated .dockerignore to include .env file properly
- Enhanced docker-compose.yml with env_file directive
- Fixed Gunicorn configuration for Docker compatibility
- Updated README.md with comprehensive deployment docs
- Cleaned up debug logging from API routes
- Added DOMAIN_SETUP.md for reverse proxy guidance
- All production issues resolved and tested working
- Application now accessible at qr.moto-adv.com
2025-07-16 17:49:10 -04:00

40 lines
1.4 KiB
Python
Executable File

"""
Authentication utilities for QR Code Manager
"""
import os
import bcrypt
from functools import wraps
from flask import session, redirect, url_for, request, jsonify
# Admin configuration
ADMIN_USERNAME = os.environ.get('ADMIN_USERNAME', 'admin')
ADMIN_PASSWORD_HASH = None
def init_admin():
"""Initialize admin user with password from environment or default"""
global ADMIN_PASSWORD_HASH
admin_password = os.environ.get('ADMIN_PASSWORD', 'admin123')
ADMIN_PASSWORD_HASH = bcrypt.hashpw(admin_password.encode('utf-8'), bcrypt.gensalt())
print(f"Admin user initialized: {ADMIN_USERNAME}")
print(f"Default password: {admin_password if admin_password == 'admin123' else '***'}")
def verify_password(password, hashed):
"""Verify a password against its hash"""
return bcrypt.checkpw(password.encode('utf-8'), hashed)
def login_required(f):
"""Authentication decorator"""
@wraps(f)
def decorated_function(*args, **kwargs):
if 'logged_in' not in session:
if request.endpoint and request.endpoint.startswith('api'):
return jsonify({'error': 'Authentication required'}), 401
return redirect(url_for('auth.login'))
return f(*args, **kwargs)
return decorated_function
def get_admin_credentials():
"""Get admin credentials for authentication"""
return ADMIN_USERNAME, ADMIN_PASSWORD_HASH