75 lines
2.4 KiB
Python
75 lines
2.4 KiB
Python
import os
|
|
from datetime import datetime
|
|
from flask import Flask
|
|
from config import config
|
|
from app.extensions import db, migrate, login_manager
|
|
|
|
|
|
def create_app(config_name='production'):
|
|
app = Flask(__name__)
|
|
app.config.from_object(config.get(config_name, config['default']))
|
|
|
|
data_dir = os.environ.get('DATA_DIR', '/app/data')
|
|
os.makedirs(data_dir, exist_ok=True)
|
|
|
|
db.init_app(app)
|
|
migrate.init_app(app, db)
|
|
login_manager.init_app(app)
|
|
|
|
from app.models import user, app_access, api_key, module_config # noqa: F401
|
|
|
|
from app.routes.auth import bp as auth_bp
|
|
from app.routes.dashboard import bp as dashboard_bp
|
|
from app.routes.settings import bp as settings_bp
|
|
from app.routes.api import bp as api_bp
|
|
|
|
app.register_blueprint(auth_bp)
|
|
app.register_blueprint(dashboard_bp)
|
|
app.register_blueprint(settings_bp)
|
|
app.register_blueprint(api_bp)
|
|
|
|
with app.app_context():
|
|
db.create_all()
|
|
_seed_admin(app)
|
|
_seed_modules(app)
|
|
|
|
@app.context_processor
|
|
def inject_globals():
|
|
return {'now': datetime.utcnow(), 'registered_apps': app.config['REGISTERED_APPS']}
|
|
|
|
return app
|
|
|
|
|
|
def _seed_admin(app):
|
|
from app.models.user import PortalUser
|
|
from app.extensions import db
|
|
from werkzeug.security import generate_password_hash
|
|
|
|
if PortalUser.query.count() == 0:
|
|
admin = PortalUser(
|
|
username=app.config['ADMIN_USERNAME'],
|
|
email=app.config['ADMIN_EMAIL'],
|
|
password_hash=generate_password_hash(app.config['ADMIN_PASSWORD']),
|
|
is_admin=True,
|
|
is_active=True,
|
|
)
|
|
db.session.add(admin)
|
|
db.session.flush()
|
|
|
|
# Grant admin access to all apps with explicit admin role
|
|
from app.models.app_access import AppAccess
|
|
for reg_app in app.config['REGISTERED_APPS']:
|
|
db.session.add(AppAccess(user_id=admin.id, app_name=reg_app['id'],
|
|
is_active=True, app_role='admin'))
|
|
|
|
db.session.commit()
|
|
|
|
|
|
def _seed_modules(app):
|
|
"""Ensure every registered app has a ModuleConfig row (default: enabled)."""
|
|
from app.models.module_config import ModuleConfig
|
|
for reg_app in app.config['REGISTERED_APPS']:
|
|
if not ModuleConfig.query.filter_by(app_id=reg_app['id']).first():
|
|
db.session.add(ModuleConfig(app_id=reg_app['id'], enabled=True))
|
|
db.session.commit()
|