Spaces:
Sleeping
Sleeping
| ## bookmyservice-ums/app/app.py | |
| from fastapi import FastAPI | |
| from fastapi.middleware.cors import CORSMiddleware | |
| from app.routers import user_router, profile_router, account_router, wallet_router, address_router, pet_router, guest_router, favorite_router, review_router | |
| from app.middleware.rate_limiter import RateLimitMiddleware | |
| from app.middleware.security_middleware import SecurityMiddleware | |
| import logging | |
| from app.utils.logger import setup_logger | |
| # Configure logging | |
| logging.basicConfig( | |
| level=logging.INFO, | |
| format="%(asctime)s - %(levelname)s - %(message)s" | |
| ) | |
| logger = setup_logger(__name__) | |
| # Set specific logger levels | |
| logging.getLogger("user_router").setLevel(logging.DEBUG) | |
| logging.getLogger("user_service").setLevel(logging.DEBUG) | |
| logging.getLogger("otp_model").setLevel(logging.DEBUG) | |
| logging.getLogger("user_model").setLevel(logging.DEBUG) | |
| logging.getLogger("profile_service").setLevel(logging.DEBUG) | |
| # Reduce noise from other libraries | |
| logging.getLogger("uvicorn").setLevel(logging.INFO) | |
| logging.getLogger("fastapi").setLevel(logging.INFO) | |
| app = FastAPI(title="BookMyService User Management Service") | |
| # Add security middleware (should be added first for proper request logging) | |
| app.add_middleware(SecurityMiddleware) | |
| # Add rate limiting middleware | |
| app.add_middleware(RateLimitMiddleware, calls=100, period=60) | |
| app.add_middleware( | |
| CORSMiddleware, | |
| allow_origins=["*"], | |
| allow_credentials=True, | |
| allow_methods=["*"], | |
| allow_headers=["*"], | |
| ) | |
| app.include_router(user_router.router, prefix="/auth", tags=["user_auth"]) | |
| app.include_router(profile_router.router, prefix="/profile", tags=["profile"]) | |
| app.include_router(account_router.router, prefix="/account", tags=["account_management"]) | |
| app.include_router(wallet_router.router, prefix="/wallet", tags=["wallet_management"]) | |
| app.include_router(address_router.router, prefix="/addresses", tags=["address_management"]) | |
| app.include_router(pet_router.router, prefix="/api/v1/users", tags=["pet_management"]) | |
| app.include_router(guest_router.router, prefix="/api/v1/users", tags=["guest_management"]) | |
| app.include_router(favorite_router.router, prefix="/api/v1/users", tags=["favorites"]) | |
| app.include_router(review_router.router,prefix="/review",tags=["reviews"]) | |
| def root(): | |
| return {"message": "BookMyService UMS is running"} | |