Spaces:
Paused
Paused
| import os | |
| import sys | |
| import asyncio | |
| import platform | |
| from pathlib import Path | |
| from fastapi import FastAPI, HTTPException | |
| from fastapi.middleware.cors import CORSMiddleware | |
| from fastapi.responses import JSONResponse | |
| from .core.config import settings | |
| from .api.v1.endpoints import auth, menu, orders, payments, reports | |
| from .db.database import init_db | |
| import logging | |
| # Set up Python path | |
| BASE_DIR = Path(__file__).resolve().parent.parent | |
| sys.path.append(str(BASE_DIR)) | |
| # Configure Windows-specific event loop policy | |
| if platform.system() == 'Windows': | |
| asyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy()) | |
| # Configure detailed logging | |
| logging.basicConfig( | |
| level=logging.DEBUG, | |
| format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', | |
| stream=sys.stdout | |
| ) | |
| logger = logging.getLogger(__name__) | |
| def create_app() -> FastAPI: | |
| app = FastAPI( | |
| title=settings.PROJECT_NAME, | |
| openapi_url=f"{settings.API_V1_STR}/openapi.json" | |
| ) | |
| # Configure CORS | |
| app.add_middleware( | |
| CORSMiddleware, | |
| allow_origins=["*"], | |
| allow_credentials=True, | |
| allow_methods=["*"], | |
| allow_headers=["*"] | |
| ) | |
| # Include API routers | |
| app.include_router(auth.router, prefix=f"{settings.API_V1_STR}/auth", tags=["auth"]) | |
| app.include_router(menu.router, prefix=f"{settings.API_V1_STR}/menu", tags=["menu"]) | |
| app.include_router(orders.router, prefix=f"{settings.API_V1_STR}/orders", tags=["orders"]) | |
| app.include_router(payments.router, prefix=f"{settings.API_V1_STR}/payments", tags=["payments"]) | |
| app.include_router(reports.router, prefix=f"{settings.API_V1_STR}/reports", tags=["reports"]) | |
| async def http_exception_handler(request, exc): | |
| return JSONResponse( | |
| status_code=exc.status_code, | |
| content={"detail": exc.detail} | |
| ) | |
| async def root(): | |
| return {"message": "POS Backend API", "version": "1.0.0"} | |
| async def startup_event(): | |
| try: | |
| logger.info("Starting application initialization...") | |
| await init_db() | |
| logger.info("Database initialized successfully") | |
| except Exception as e: | |
| logger.error(f"Failed to initialize database: {str(e)}", exc_info=True) | |
| raise | |
| return app | |
| app = create_app() | |
| if __name__ == "__main__": | |
| import uvicorn | |
| uvicorn.run( | |
| "app.main:app", | |
| host="0.0.0.0", | |
| port=8000, | |
| reload=True, | |
| log_level="info" | |
| ) | |