You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

133 lines
4.7 KiB

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
from flask_login import LoginManager
import pymysql
import os
from config import Config
db = SQLAlchemy()
migrate = Migrate()
login_manager = LoginManager()
def create_app():
app = Flask(__name__)
app.config.from_object(Config)
# Initialize enhanced logging
setup_enhanced_logging(app)
# Initialize extensions
db.init_app(app)
migrate.init_app(app, db)
login_manager.init_app(app)
login_manager.login_view = 'auth.login'
login_manager.login_message = 'Please log in to access this page.'
# MySQL connection (read-only) - initialized when needed
def get_mysql_connection():
if not hasattr(app, 'mysql_connection') or app.mysql_connection is None:
try:
app.mysql_connection = pymysql.connect(
host=app.config['MYSQL_CONFIG']['host'],
database=app.config['MYSQL_CONFIG']['database'],
user=app.config['MYSQL_CONFIG']['user'],
password=app.config['MYSQL_CONFIG']['password'],
port=app.config['MYSQL_CONFIG']['port'],
autocommit=False # Ensure read-only behavior
)
except Exception as e:
print(f"MySQL connection failed: {e}")
app.mysql_connection = None
return app.mysql_connection
# Make connection function available to app context
app.get_mysql_connection = get_mysql_connection
# Register blueprints
from blueprints.auth import auth_bp
from blueprints.main import main_bp
from blueprints.search import search_bp
from blueprints.analytics import analytics_bp
app.register_blueprint(auth_bp, url_prefix='/auth')
app.register_blueprint(main_bp)
app.register_blueprint(search_bp)
app.register_blueprint(analytics_bp)
# User loader for Flask-Login
from models import Users
@login_manager.user_loader
def load_user(user_id):
return Users.query.get(int(user_id))
# Add permission functions to template context
from permissions import (
can_manage_users, can_manage_payments, can_view_data,
can_process_single_payments, can_manage_batch_payments,
can_manage_payment_plans, can_view_logs, can_export_data,
has_permission, get_user_permission_level
)
@app.context_processor
def inject_permissions():
return {
'can_manage_users': can_manage_users,
'can_manage_payments': can_manage_payments,
'can_view_data': can_view_data,
'can_process_single_payments': can_process_single_payments,
'can_manage_batch_payments': can_manage_batch_payments,
'can_manage_payment_plans': can_manage_payment_plans,
'can_view_logs': can_view_logs,
'can_export_data': can_export_data,
'has_permission': has_permission,
'get_user_permission_level': get_user_permission_level
}
# Note: Database tables will be managed by Flask-Migrate
# Use 'flask db init', 'flask db migrate', 'flask db upgrade' commands
return app
def setup_enhanced_logging(app):
"""Setup enhanced logging system for the application."""
try:
# Create logs directory first
os.makedirs('logs', exist_ok=True)
from logging_config import setup_flask_logging
from middleware import RequestLoggingMiddleware, DatabaseLoggingMiddleware, SecurityMiddleware
# Setup Flask logging
setup_flask_logging(app)
# Initialize middleware with error handling
try:
RequestLoggingMiddleware(app)
app.logger.info("Request logging middleware initialized")
except Exception as e:
app.logger.warning(f"Request logging middleware failed: {e}")
try:
DatabaseLoggingMiddleware(app)
app.logger.info("Database logging middleware initialized")
except Exception as e:
app.logger.warning(f"Database logging middleware failed: {e}")
try:
SecurityMiddleware(app)
app.logger.info("Security middleware initialized")
except Exception as e:
app.logger.warning(f"Security middleware failed: {e}")
except ImportError as e:
print(f"Enhanced logging not available: {e}")
except Exception as e:
print(f"Error setting up enhanced logging: {e}")
# Don't let logging errors prevent the app from starting
pass
if __name__ == '__main__':
app = create_app()
app.run(debug=True)