refactor: 优化API路由和响应模型 feat(admin): 添加App用户管理接口 feat(sms): 实现阿里云短信服务集成 feat(email): 添加SMTP邮件发送功能 feat(upload): 支持文件上传接口 feat(rate-limiter): 实现手机号限流器 fix: 修复计算步骤入库问题 docs: 更新API文档和测试计划 chore: 更新依赖和配置
203 lines
8.5 KiB
Python
203 lines
8.5 KiB
Python
from fastapi import APIRouter, HTTPException, Query, Depends
|
|
from typing import Optional, List
|
|
|
|
from app.controllers.valuation import valuation_controller
|
|
from app.schemas.valuation import (
|
|
ValuationAssessmentCreate,
|
|
ValuationAssessmentUpdate,
|
|
ValuationAssessmentOut,
|
|
ValuationAssessmentList,
|
|
ValuationAssessmentQuery,
|
|
ValuationApprovalRequest,
|
|
ValuationAdminNotesUpdate,
|
|
ValuationCalculationStepOut
|
|
)
|
|
from app.schemas.base import Success, SuccessExtra, BasicResponse, PageResponse
|
|
from app.core.ctx import CTX_USER_ID
|
|
|
|
valuations_router = APIRouter(tags=["估值评估"])
|
|
|
|
|
|
@valuations_router.post("/", summary="创建估值评估", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def create_valuation(data: ValuationAssessmentCreate):
|
|
"""创建新的估值评估记录"""
|
|
try:
|
|
# 获取当前用户ID
|
|
user_id = CTX_USER_ID.get()
|
|
print(user_id)
|
|
result = await valuation_controller.create(data, user_id)
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="创建成功")
|
|
except Exception as e:
|
|
raise HTTPException(status_code=400, detail=f"创建失败: {str(e)}")
|
|
|
|
|
|
@valuations_router.get("/statistics/overview", summary="获取统计信息", response_model=BasicResponse[dict])
|
|
async def get_statistics():
|
|
"""获取估值评估统计信息"""
|
|
result = await valuation_controller.get_statistics()
|
|
return Success(data=result, msg="获取统计信息成功")
|
|
|
|
|
|
@valuations_router.get("/{valuation_id}", summary="获取估值评估详情", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def get_valuation(valuation_id: int):
|
|
"""根据ID获取估值评估详情"""
|
|
result = await valuation_controller.get_by_id(valuation_id)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="获取成功")
|
|
|
|
|
|
@valuations_router.get("/{valuation_id}/steps", summary="获取估值计算步骤", response_model=BasicResponse[List[ValuationCalculationStepOut]])
|
|
async def get_valuation_steps(valuation_id: int):
|
|
"""根据估值ID获取所有计算步骤"""
|
|
steps = await valuation_controller.get_calculation_steps(valuation_id)
|
|
if not steps:
|
|
raise HTTPException(status_code=404, detail="未找到该估值的计算步骤")
|
|
import json
|
|
steps_out = [json.loads(step.model_dump_json()) for step in steps]
|
|
return Success(data=steps_out, msg="获取计算步骤成功")
|
|
|
|
|
|
@valuations_router.put("/{valuation_id}", summary="更新估值评估", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def update_valuation(valuation_id: int, data: ValuationAssessmentUpdate):
|
|
"""更新估值评估记录"""
|
|
result = await valuation_controller.update(valuation_id, data)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="更新成功")
|
|
|
|
|
|
@valuations_router.delete("/{valuation_id}", summary="删除估值评估", response_model=BasicResponse[dict])
|
|
async def delete_valuation(valuation_id: int):
|
|
"""软删除估值评估记录"""
|
|
result = await valuation_controller.delete(valuation_id)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
return Success(data={"deleted": True}, msg="删除成功")
|
|
|
|
|
|
@valuations_router.get("/", summary="获取估值评估列表", response_model=PageResponse[ValuationAssessmentOut])
|
|
async def get_valuations(
|
|
asset_name: Optional[str] = Query(None, description="资产名称"),
|
|
institution: Optional[str] = Query(None, description="所属机构"),
|
|
industry: Optional[str] = Query(None, description="所属行业"),
|
|
heritage_level: Optional[str] = Query(None, description="非遗等级"),
|
|
status: Optional[str] = Query(None, description="评估状态"),
|
|
is_active: Optional[bool] = Query(None, description="是否激活"),
|
|
page: int = Query(1, ge=1, description="页码"),
|
|
size: int = Query(10, ge=1, le=100, description="每页数量")
|
|
):
|
|
"""获取估值评估列表,支持筛选和分页"""
|
|
query = ValuationAssessmentQuery(
|
|
asset_name=asset_name,
|
|
institution=institution,
|
|
industry=industry,
|
|
heritage_level=heritage_level,
|
|
status=status,
|
|
is_active=is_active,
|
|
page=page,
|
|
size=size
|
|
)
|
|
result = await valuation_controller.get_list(query)
|
|
import json
|
|
items = [json.loads(item.model_dump_json()) for item in result.items]
|
|
return SuccessExtra(
|
|
data=items,
|
|
total=result.total,
|
|
page=result.page,
|
|
page_size=result.size,
|
|
pages=result.pages,
|
|
msg="获取估值评估列表成功"
|
|
)
|
|
|
|
|
|
@valuations_router.get("/search/keyword", summary="搜索估值评估", response_model=PageResponse[ValuationAssessmentOut])
|
|
async def search_valuations(
|
|
keyword: str = Query(..., description="搜索关键词"),
|
|
page: int = Query(1, ge=1, description="页码"),
|
|
size: int = Query(10, ge=1, le=100, description="每页数量")
|
|
):
|
|
"""根据关键词搜索估值评估记录"""
|
|
result = await valuation_controller.search(keyword, page, size)
|
|
import json
|
|
items = [json.loads(item.model_dump_json()) for item in result.items]
|
|
return SuccessExtra(
|
|
data=items,
|
|
total=result.total,
|
|
page=result.page,
|
|
page_size=result.size,
|
|
pages=result.pages,
|
|
msg="搜索成功"
|
|
)
|
|
|
|
|
|
# 批量操作接口
|
|
@valuations_router.post("/batch/delete", summary="批量删除估值评估", response_model=BasicResponse[dict])
|
|
async def batch_delete_valuations(valuation_ids: list[int]):
|
|
"""批量软删除估值评估记录"""
|
|
success_count = 0
|
|
failed_ids = []
|
|
|
|
for valuation_id in valuation_ids:
|
|
result = await valuation_controller.delete(valuation_id)
|
|
if result:
|
|
success_count += 1
|
|
else:
|
|
failed_ids.append(valuation_id)
|
|
|
|
return Success(
|
|
data={
|
|
"success_count": success_count,
|
|
"failed_ids": failed_ids,
|
|
"total_count": len(valuation_ids)
|
|
},
|
|
msg=f"批量删除完成,成功删除 {success_count} 条记录"
|
|
)
|
|
|
|
|
|
# 导出接口
|
|
@valuations_router.get("/export/excel", summary="导出估值评估数据", response_model=BasicResponse[dict])
|
|
async def export_valuations(
|
|
asset_name: Optional[str] = Query(None, description="资产名称"),
|
|
institution: Optional[str] = Query(None, description="所属机构"),
|
|
industry: Optional[str] = Query(None, description="所属行业"),
|
|
heritage_level: Optional[str] = Query(None, description="非遗等级")
|
|
):
|
|
"""导出估值评估数据为Excel文件"""
|
|
# 这里可以实现Excel导出逻辑
|
|
# 暂时返回提示信息
|
|
return Success(data={"message": "导出功能待实现"}, msg="导出请求已接收")
|
|
|
|
|
|
# 审核管理接口
|
|
@valuations_router.post("/{valuation_id}/approve", summary="审核通过估值评估", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def approve_valuation(valuation_id: int, data: ValuationApprovalRequest):
|
|
"""审核通过估值评估"""
|
|
result = await valuation_controller.approve_valuation(valuation_id, data.admin_notes)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="审核通过成功")
|
|
|
|
|
|
@valuations_router.post("/{valuation_id}/reject", summary="审核拒绝估值评估", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def reject_valuation(valuation_id: int, data: ValuationApprovalRequest):
|
|
"""审核拒绝估值评估"""
|
|
result = await valuation_controller.reject_valuation(valuation_id, data.admin_notes)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="审核拒绝成功")
|
|
|
|
|
|
@valuations_router.put("/{valuation_id}/admin-notes", summary="更新管理员备注", response_model=BasicResponse[ValuationAssessmentOut])
|
|
async def update_admin_notes(valuation_id: int, data: ValuationAdminNotesUpdate):
|
|
"""更新管理员备注"""
|
|
result = await valuation_controller.update_admin_notes(valuation_id, data.admin_notes)
|
|
if not result:
|
|
raise HTTPException(status_code=404, detail="估值评估记录不存在")
|
|
import json
|
|
return Success(data=json.loads(result.model_dump_json()), msg="管理员备注更新成功") |