Files
hankin 815cbf9d8c v0.2.0: CRM/ERP 系统升级 - 清理 .gitignore 并移除误提交的 venv/env/db 文件
- 更新 .gitignore:全面覆盖环境变量、数据库、日志、缓存、上传文件
- 移除误跟踪的 server/venv/、crm_data.db、.env 文件
- 新增 server/.env.example 模板
- 新增合同管理、利润核算、AI教练等功能模块
- 新增 Playwright e2e 测试套件
- 前后端多项功能升级和 bug 修复
2026-05-11 07:24:19 +00:00

101 lines
3.6 KiB
Python

"""
FastAPI 应用主入口
启动命令: uvicorn app.main:app --reload --host 0.0.0.0 --port 8000
"""
from contextlib import asynccontextmanager
from collections.abc import AsyncIterator
from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware
from app.core.config import settings
from app.core.exceptions import register_exception_handlers
from app.api.auth import router as auth_router
from app.api.customers import router as customers_router
from app.api.products import router as products_router
from app.api.orders import router as orders_router
from app.api.shipping import router as shipping_router
from app.api.finance import router as finance_router
from app.api.sys_settings import router as sys_settings_router
from app.api.chat import router as chat_router
from app.api.dify_tools import router as dify_tools_router
from app.api.sales_logs import router as sales_logs_router
from app.api.import_export import router as import_export_router
from app.api.sales_invoice import router as sales_invoice_router
from app.api.reports import router as reports_router
from app.api.contacts import router as contacts_router
from app.api.dashboard import router as dashboard_router
from app.api.companies import router as companies_router
from app.api.contracts import router as contracts_router
from app.api.profit import router as profit_router
from app.api.ai_coaching import router as ai_coaching_router
@asynccontextmanager
async def lifespan(app: FastAPI) -> AsyncIterator[None]:
"""应用生命周期:启动/关闭时的钩子"""
# ── startup ──
print(f"🚀 {settings.APP_NAME} v{settings.APP_VERSION} 启动中...")
from app.services.ocr_worker import ocr_worker
ocr_worker.start()
yield
# ── shutdown ──
await ocr_worker.stop()
print("👋 服务正在关闭...")
from fastapi.staticfiles import StaticFiles
import os
app = FastAPI(
title=settings.APP_NAME,
version=settings.APP_VERSION,
docs_url="/docs",
redoc_url="/redoc",
lifespan=lifespan,
)
# 挂载上传文件目录
os.makedirs("uploads", exist_ok=True)
app.mount("/uploads", StaticFiles(directory="uploads"), name="uploads")
# ── CORS(仅允许内网生产地址) ──
app.add_middleware(
CORSMiddleware,
allow_origins=["http://192.168.1.100"],
allow_credentials=True,
allow_methods=["*"],
allow_headers=["*"],
)
# ── 注册全局异常处理器 ──
register_exception_handlers(app)
# ── 注册路由 ──
app.include_router(auth_router, prefix="/api")
app.include_router(customers_router, prefix="/api")
app.include_router(products_router, prefix="/api")
app.include_router(orders_router, prefix="/api")
app.include_router(shipping_router, prefix="/api")
app.include_router(finance_router, prefix="/api")
app.include_router(sys_settings_router, prefix="/api")
app.include_router(chat_router, prefix="/api")
app.include_router(dify_tools_router, prefix="/api")
app.include_router(sales_logs_router, prefix="/api")
app.include_router(import_export_router, prefix="/api")
app.include_router(sales_invoice_router, prefix="/api")
app.include_router(reports_router, prefix="/api")
app.include_router(contacts_router, prefix="/api")
app.include_router(dashboard_router, prefix="/api")
app.include_router(companies_router, prefix="/api")
app.include_router(contracts_router, prefix="/api")
app.include_router(profit_router, prefix="/api")
app.include_router(ai_coaching_router, prefix="/api")
# ── 健康检查 ──
@app.get("/health", tags=["系统"])
async def health_check() -> dict:
return {"status": "ok", "version": settings.APP_VERSION}