feat: wire native leaudit upload flow

This commit is contained in:
wren
2026-04-28 16:53:16 +08:00
parent c776af598a
commit e738398eb6
26 changed files with 7364 additions and 5778 deletions
@@ -4,18 +4,36 @@ from __future__ import annotations
from contextlib import asynccontextmanager
from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine
from sqlalchemy.ext.asyncio import AsyncEngine, AsyncSession, async_sessionmaker, create_async_engine
from sqlalchemy.pool import NullPool
from fastapi_admin.config import ASYNCPG_DATABASE_URL
_engine = create_async_engine(ASYNCPG_DATABASE_URL, echo=False, pool_size=20, max_overflow=10)
_engine: AsyncEngine | None = None
_AsyncSessionFactory: async_sessionmaker[AsyncSession] | None = None
_AsyncSessionFactory = async_sessionmaker(_engine, class_=AsyncSession, expire_on_commit=False)
def _get_session_factory() -> async_sessionmaker[AsyncSession]:
"""按需创建 session factory,避免 reload/多事件循环复用旧连接池。"""
global _engine, _AsyncSessionFactory
if _AsyncSessionFactory is None:
_engine = create_async_engine(
ASYNCPG_DATABASE_URL,
echo=False,
poolclass=NullPool,
)
_AsyncSessionFactory = async_sessionmaker(
_engine,
class_=AsyncSession,
expire_on_commit=False,
)
return _AsyncSessionFactory
@asynccontextmanager
async def GetAsyncSession():
"""获取异步数据库 session(上下文管理器)。"""
async with _AsyncSessionFactory() as session:
SessionFactory = _get_session_factory()
async with SessionFactory() as session:
yield session
await session.commit()
@@ -1,9 +1,9 @@
"""BaseModel —— 所有业务模型的抽象基类。
自动提供三个公共时间字段:
- create_timeINSERT 时由数据库写入当前时间
- update_timeINSERT 和 UPDATE 时自动更新
- delete_time:默认 NULL,非 NULL 表示已软删除
- created_atINSERT 时由数据库写入当前时间
- updated_atINSERT 和 UPDATE 时自动更新
- deleted_at:默认 NULL,非 NULL 表示已软删除
"""
from __future__ import annotations
@@ -21,12 +21,12 @@ class BaseModel(Base):
__abstract__ = True
create_time: Mapped[datetime] = mapped_column(
DateTime(timezone=True), server_default=func.now(), comment="创建时间"
created_at: Mapped[datetime] = mapped_column(
"created_at", DateTime(timezone=True), server_default=func.now(), comment="创建时间"
)
update_time: Mapped[datetime] = mapped_column(
DateTime(timezone=True), server_default=func.now(), onupdate=func.now(), comment="更新时间"
updated_at: Mapped[datetime] = mapped_column(
"updated_at", DateTime(timezone=True), server_default=func.now(), onupdate=func.now(), comment="更新时间"
)
delete_time: Mapped[datetime | None] = mapped_column(
DateTime(timezone=True), default=None, comment="软删除时间"
deleted_at: Mapped[datetime | None] = mapped_column(
"deleted_at", DateTime(timezone=True), default=None, comment="软删除时间"
)