File size: 2,338 Bytes
b407a42
 
 
 
aedd440
d846c9a
 
fe2f3e5
05dc4f5
 
fe2f3e5
05dc4f5
 
fe2f3e5
df8187a
05dc4f5
fe2f3e5
05dc4f5
 
 
fe2f3e5
 
 
 
 
 
 
 
 
 
 
b407a42
 
 
d846c9a
 
 
 
 
 
b407a42
 
 
 
 
 
 
 
 
 
d846c9a
82a6cc5
 
 
 
f36ca66
aedd440
b407a42
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
## 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"])

@app.get("/")
def root():
    return {"message": "BookMyService UMS is running"}