refactor: 优化API路由和响应模型 feat(admin): 添加App用户管理接口 feat(sms): 实现阿里云短信服务集成 feat(email): 添加SMTP邮件发送功能 feat(upload): 支持文件上传接口 feat(rate-limiter): 实现手机号限流器 fix: 修复计算步骤入库问题 docs: 更新API文档和测试计划 chore: 更新依赖和配置
73 lines
2.5 KiB
Python
73 lines
2.5 KiB
Python
from fastapi import APIRouter, Query
|
|
from tortoise.expressions import Q
|
|
|
|
from app.controllers.esg import esg_controller
|
|
from app.schemas import Success, SuccessExtra
|
|
from app.schemas.base import BasicResponse, PageResponse, MessageOut
|
|
from app.schemas.esg import ESGResponse
|
|
from app.schemas.esg import ESGCreate, ESGUpdate, ESGResponse
|
|
|
|
router = APIRouter(tags=["ESG管理"])
|
|
|
|
|
|
@router.get("/list", summary="查看ESG列表", response_model=PageResponse[ESGResponse])
|
|
async def list_esg(
|
|
page: int = Query(1, description="页码"),
|
|
page_size: int = Query(10, description="每页数量"),
|
|
code: str = Query(None, description="ESG代码"),
|
|
name: str = Query(None, description="ESG名称"),
|
|
level: str = Query(None, description="ESG级别"),
|
|
):
|
|
q = Q()
|
|
if code:
|
|
q &= Q(code__contains=code)
|
|
if name:
|
|
q &= Q(name__contains=name)
|
|
if level:
|
|
q &= Q(level__contains=level)
|
|
total, esg_objs = await esg_controller.list(page=page, page_size=page_size, search=q, order=["id"])
|
|
data = [await obj.to_dict() for obj in esg_objs]
|
|
return SuccessExtra(data=data, total=total, page=page, page_size=page_size)
|
|
|
|
|
|
@router.get("/get", summary="查看ESG详情", response_model=BasicResponse[ESGResponse])
|
|
async def get_esg(
|
|
id: int = Query(..., description="ESG ID"),
|
|
):
|
|
esg_obj = await esg_controller.get(id=id)
|
|
data = await esg_obj.to_dict()
|
|
return Success(data=data)
|
|
|
|
|
|
@router.post("/create", summary="创建ESG", response_model=BasicResponse[MessageOut])
|
|
async def create_esg(
|
|
esg_in: ESGCreate,
|
|
):
|
|
# 检查代码是否已存在
|
|
if await esg_controller.is_exist(esg_in.code):
|
|
return Success(code=400, msg="ESG代码已存在")
|
|
|
|
await esg_controller.create(obj_in=esg_in)
|
|
return Success(msg="创建成功")
|
|
|
|
|
|
@router.post("/update", summary="更新ESG", response_model=BasicResponse[MessageOut])
|
|
async def update_esg(
|
|
esg_in: ESGUpdate,
|
|
):
|
|
# 检查代码是否已存在(排除当前记录)
|
|
if esg_in.code:
|
|
existing_obj = await esg_controller.model.filter(code=esg_in.code).exclude(id=esg_in.id).first()
|
|
if existing_obj:
|
|
return Success(code=400, msg="ESG代码已存在")
|
|
|
|
await esg_controller.update(id=esg_in.id, obj_in=esg_in)
|
|
return Success(msg="更新成功")
|
|
|
|
|
|
@router.delete("/delete", summary="删除ESG", response_model=BasicResponse[MessageOut])
|
|
async def delete_esg(
|
|
esg_id: int = Query(..., description="ESG ID"),
|
|
):
|
|
await esg_controller.remove(id=esg_id)
|
|
return Success(msg="删除成功") |