2026-05-06 17:43:47 +08:00
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
|
|
from fastapi import FastAPI
|
|
|
|
|
from fastapi.middleware.cors import CORSMiddleware
|
|
|
|
|
|
|
|
|
|
from app.api.router import api_router
|
|
|
|
|
from app.core.config import get_settings
|
2026-05-06 22:23:42 +08:00
|
|
|
from app.core.logging import get_logger, setup_logging
|
|
|
|
|
from app.middleware.logging import AccessLogMiddleware
|
2026-05-07 11:50:10 +08:00
|
|
|
from app.services.employee import prepare_employee_directory
|
2026-05-06 17:43:47 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def create_app() -> FastAPI:
|
|
|
|
|
settings = get_settings()
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
setup_logging(
|
|
|
|
|
level=settings.log_level,
|
|
|
|
|
log_dir=settings.log_dir,
|
|
|
|
|
enable_file=settings.log_file_enabled,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
logger = get_logger("app.main")
|
|
|
|
|
logger.info(
|
|
|
|
|
"Starting %s (env=%s, debug=%s)", settings.app_name, settings.app_env, settings.app_debug
|
|
|
|
|
)
|
|
|
|
|
|
2026-05-06 17:43:47 +08:00
|
|
|
app = FastAPI(
|
|
|
|
|
title=settings.app_name,
|
|
|
|
|
debug=settings.app_debug,
|
|
|
|
|
version="0.1.0",
|
|
|
|
|
)
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
app.add_middleware(AccessLogMiddleware)
|
|
|
|
|
|
2026-05-06 17:43:47 +08:00
|
|
|
if settings.cors_origins:
|
|
|
|
|
app.add_middleware(
|
|
|
|
|
CORSMiddleware,
|
|
|
|
|
allow_origins=settings.cors_origins,
|
|
|
|
|
allow_credentials=True,
|
|
|
|
|
allow_methods=["*"],
|
|
|
|
|
allow_headers=["*"],
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
app.include_router(api_router, prefix=settings.api_v1_prefix)
|
|
|
|
|
|
|
|
|
|
@app.get("/", tags=["root"])
|
|
|
|
|
def root() -> dict[str, str]:
|
|
|
|
|
return {"message": f"{settings.app_name} is running"}
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
@app.on_event("startup")
|
|
|
|
|
def _on_startup() -> None:
|
2026-05-07 11:50:10 +08:00
|
|
|
prepare_employee_directory()
|
2026-05-06 22:23:42 +08:00
|
|
|
logger.info(
|
2026-05-07 11:50:10 +08:00
|
|
|
"Server ready - host=%s port=%s prefix=%s",
|
2026-05-06 22:23:42 +08:00
|
|
|
settings.app_host,
|
|
|
|
|
settings.app_port,
|
|
|
|
|
settings.api_v1_prefix,
|
|
|
|
|
)
|
|
|
|
|
|
2026-05-06 17:43:47 +08:00
|
|
|
return app
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
app = create_app()
|