- 完善管家意图识别、模型计划构建与规划器调度 - 重构差旅报销提交编排器与管家计划流程前端交互 - 优化报销消息项样式与文档中心视图 - 新增小财管家与附件上传风险前置复核设计文档 - 补充管家规划器与文档中心测试覆盖
4.0 KiB
4.0 KiB
附件上传风险前置复核
功能一句话
报销附件上传并完成 OCR 识别后立即执行完整风险复核,提交审批时只做轻量最终校验、预算占用和流程流转。
背景与问题
当前报销单提交阶段会同步执行较重的风险检查,包括附件风险汇总、差旅规则、场景规则、规则中心风险、历史行为统计和风险观测写入。用户在点击提交后会等待较长时间,容易误认为页面卡住。
风险的主要依据来自已上传票据、OCR 识别结果、费用明细、关联申请单和员工历史行为。这些数据在附件上传完成后已经基本具备,因此完整风险复核应前移到上传完成阶段。
目标与非目标
目标:
- 附件上传成功后自动刷新费用明细、附件风险、差旅/场景/规则中心风险和 AI 预审标识。
- 风险复核结果写回
claim.risk_flags_json,并持久化规则中心风险观测。 - 提交阶段不再重复跑完整
_run_ai_submission_review()。 - 提交阶段只保留草稿完整性校验、预算占用、未处理阻断风险判断、状态流转、审计日志和助手会话清理。
非目标:
- 不新增业务字段。
- 不改变现有风险规则语义。
- 不把提交改成真正的后端异步任务队列。
用户与场景
- 报销申请人:上传票据后立即看到风险建议和需补充说明,不必等到提交时才发现问题。
- 直属领导和财务人员:收到单据时可看到提交前已生成的风险提示和用户处理结果。
- 系统管理员:风险观测仍可进入后台统计。
功能能力
上传完成后:
- 根据 OCR 结果回填费用明细类型、日期、金额、事由等已有字段。
- 刷新附件级
attachment_analysis风险。 - 执行报销级风险复核,并生成
ai_pre_review状态。 - 对规则中心命中的风险写入
risk_observations。
提交审批时:
- 如果存在高风险且用户未处理,继续阻止提交或要求说明/按职级测算。
- 如果风险已处理,只做预算和流程流转。
- 不再重复生成一套提交阶段风险。
方案设计
后端:
- 在
ExpenseClaimService.upload_claim_item_attachment()中,OCR、附件分析和_sync_claim_from_items()完成后,调用上传后风险复核 helper。 - 新增 helper 复用现有
_run_ai_submission_review()与_replace_ai_pre_review_flag(),但保持单据状态为草稿。 - 提交阶段读取既有风险结果,只做最终阻断风险判断,不重复调用
_run_ai_submission_review()。
前端:
- 继续使用当前附件识别中的状态条。
- 上传完成后通过接口返回的
claim_risk_flags更新 AI 建议区和风险标识。 - 提交时只显示轻量后台提交流程提示。
算法与公式
当前功能不涉及新的显式数学公式。风险评分和风险等级沿用现有规则中心、附件分析、差旅政策和风险观测逻辑。
测试方案
- 后端单元测试:附件上传后写入
ai_pre_review和submission_review风险。 - 后端单元测试:提交阶段不再调用完整
_run_ai_submission_review()。 - 后端单元测试:上传后规则中心风险可写入
risk_observations。 - 前端静态回归:提交确认仍为后台提交,不恢复阻塞弹窗。
- 构建验证:
npm.cmd --prefix web run build。
指标与验收
- 上传附件后,接口响应的
claim_risk_flags包含最新复核结果。 - 提交接口耗时不再包含完整风险复核耗时。
- 提交后审批人仍能看到已前置生成的风险提示。
- 后端和前端相关回归测试通过。
风险与开放问题
- 如果用户上传后又修改费用明细,现有
update_claim_item()需要继续刷新附件风险和报销级风险。 - 如果用户没有上传附件直接提交,提交阶段仍需要保留兜底风险复核或阻断提示。
- 未来可进一步把上传后复核做成真正后台任务,但本次先保持同步接口返回最新风险结果。