Files
ccdi/docs/design/2026-03-18-project-bank-tag-status-lock-design.md

9.6 KiB
Raw Blame History

项目银行流水打标状态联动设计

背景

当前项目状态仅包含:

  • 0-进行中
  • 1-已完成
  • 2-已归档

银行流水打标已经具备手工触发和自动触发两条链路:

  • 手工触发:用户在项目中发起标签重算
  • 自动触发:上传流水文件或拉取本行信息成功后触发自动重算

但现状里“项目状态”和“银行流水打标任务状态”是分离的:

  • 打标开始时,项目状态不会切到明确的“执行中”
  • 打标期间,上传数据页仍可继续拉取本行信息、上传流水
  • 打标期间,参数模型页仍可修改阈值
  • 项目列表、详情页、状态统计也无法反映项目是否处于打标执行中

这会带来两个问题:

  1. 用户无法判断项目当前是否正在执行银行流水打标
  2. 打标运行过程中仍允许修改输入数据和参数,容易导致执行口径与结果不一致

目标

  • 为项目增加“打标中”这一正式业务状态。
  • 所有银行流水打标入口统一驱动项目状态切换。
  • 打标成功后将项目状态变更为“已完成”。
  • 打标失败后将项目状态回退为“进行中”。
  • 当项目处于“打标中”时:
    • 上传数据页禁止拉取本行信息、上传流水等会改变输入数据的操作
    • 参数模型页禁止修改参数
  • 项目列表、项目详情、项目状态统计统一展示“打标中”。
  • 前端禁用与后端校验保持一致,避免仅靠页面控制被绕过。

范围

In Scope

  • ccdi_project.status 业务状态扩展
  • 银行流水打标任务开始/结束时的项目状态切换
  • 手工触发与自动触发两类打标链路
  • 项目列表、详情页、状态统计的“打标中”展示
  • 上传数据页与参数模型页的前端禁用
  • 文件上传、拉取本行信息、参数保存的后端状态拦截
  • 对应 SQL、测试与实施记录

Out of Scope

  • 打标执行线程模型调整
  • 新增消息推送、WebSocket、实时进度条
  • 已归档项目的业务流程重构
  • 打标结果口径、规则 SQL、本次标签计算逻辑本身的调整

设计原则

  • 项目状态是页面展示、统计、交互控制的唯一业务事实来源。
  • “打标中”不是临时页面标记,而是项目正式状态。
  • 所有打标触发入口必须复用同一套状态切换逻辑,不能分散在多个控制器中各自处理。
  • 前端负责体验层禁用,后端负责最终业务兜底。
  • 失败回退遵循用户确认规则:打标失败回退为 0-进行中

方案选择

本次采用“把打标中做成项目正式状态”的方案,不采用“从任务表动态推导打标中”。

原因:

  • 当前项目列表、详情、统计、按钮显隐都已直接依赖 ccdi_project.status
  • 将“打标中”纳入正式状态,能最小化前后端口径分叉
  • 相比运行时拼装任务态,字典、统计、筛选、禁用逻辑更容易统一维护

状态模型设计

项目状态扩展为:

  • 0-进行中
  • 1-已完成
  • 2-已归档
  • 3-打标中

状态流转

1. 项目创建

  • 新建项目默认状态仍为 0-进行中

2. 打标开始

当任一银行流水打标任务开始执行时,项目状态切换为 3-打标中

覆盖入口包括:

  • 手工重算
  • 批量上传流水完成后触发的自动打标
  • 拉取本行信息完成后触发的自动打标

3. 打标成功

  • 当前轮及补跑轮次全部执行完成后,项目状态切换为 1-已完成

4. 打标失败

  • 当前轮打标执行失败时,项目状态切换回 0-进行中

5. 补跑场景

ProjectBankTagRebuildCoordinator 当前已经支持 needRerun 机制。

设计要求:

  • 当项目已经处于打标流程中且出现补跑标记时,项目状态持续保持 3-打标中
  • 仅当最后一轮实际执行结束后,才根据最终结果落为 1-已完成0-进行中

后端设计

1. 项目状态统一更新能力

建议在项目模块中补充一个明确的项目状态更新能力,供打标服务、文件上传服务、参数服务复用。

职责:

  • 根据 projectId 获取项目并校验存在性
  • 更新 statusupdateByupdateTime
  • 对已归档项目做保护,避免被意外改写状态

不建议把状态切换逻辑散落在多个业务类里直接 projectMapper.updateById(...)

2. 打标状态切换落点

状态切换收口在 CcdiBankTagServiceImpl.rebuildProject(...)

建议流程:

  1. 创建打标任务前或任务创建后、规则执行前,将项目状态更新为 3-打标中
  2. 规则执行全部完成后,将项目状态更新为 1-已完成
  3. 捕获异常时,将项目状态更新为 0-进行中
  4. 若存在补跑循环,则状态保持 3,由最后一轮执行负责写最终态

这样可以保证手工和自动触发都复用同一套状态流转。

3. 前置拦截能力

后端需要对“打标中不可改输入”的规则做服务端校验,避免前端禁用被绕过。

文件上传相关

CcdiFileUploadServiceImpl 中,对以下入口增加项目状态校验:

  • 批量上传流水
  • 拉取本行信息

当项目状态为 3-打标中 时,直接抛出业务异常,例如:

  • 当前项目正在进行银行流水打标,暂不允许上传或拉取数据

参数保存相关

CcdiModelParamServiceImpl 中,对以下入口增加项目状态校验:

  • saveParams
  • saveAllParams

当项目状态为 3-打标中 时,直接抛出业务异常,例如:

  • 当前项目正在进行银行流水打标,暂不允许修改参数

4. 已归档项目保护

若已归档项目被误触发打标,不应继续推进状态切换。

建议策略:

  • 已归档项目不允许进入新的打标流程
  • 若入口层未提前拦住,状态更新能力也应拒绝把 2-已归档 改写为 3

这样能避免“已归档”与“打标中”之间出现非法流转。

前端设计

1. 项目详情页状态展示

ruoyi-ui/src/views/ccdiProject/detail.vue 需要新增 3-打标中 的状态展示:

  • 状态文字:打标中
  • 状态样式:与现有“进行中/已完成/已归档”区分

详情页向子组件透传的 projectInfo.projectStatus 保持为统一禁用依据。

2. 上传数据页禁用

UploadData.vue 在项目状态为 3 时进入受限态。

禁用范围

  • 拉取本行信息
  • 上传流水
  • 所有会触发上传、拉取、重新提交输入数据的入口按钮

交互要求

  • 按钮使用 disabled
  • 禁用状态有明确提示文案,而不是仅变灰
  • 已存在的文件列表、统计、查看类操作仍允许使用

目标是“禁止改变输入”,而不是“整个页面不可看”。

3. 参数模型页只读

ParamConfig.vue 在项目状态为 3 时进入只读态。

控制项

  • 参数输入框禁用
  • “保存所有修改”按钮禁用
  • 页面顶部或按钮区展示提示文案:
    • 项目正在进行银行流水打标,参数暂不可修改

4. 项目列表与状态统计

项目列表

项目列表页需要新增 3-打标中 的显示与操作策略:

  • 状态列可正常显示“打标中”
  • “打标中”项目允许进入详情页查看
  • 不显示仅适用于完成态的“查看结果/归档”
  • 不把“打标中”误判为“进行中”或“已完成”

状态统计

项目首页状态统计扩展为:

  • 全部
  • 进行中
  • 已完成
  • 已归档
  • 打标中

对应后端统计 VO 与前端 tabCounts 都要同步扩展。

SQL 与字典设计

需要新增一条增量 SQL补齐状态字典与注释口径

  • ccdi_project.status 注释补充 3-打标中
  • sys_dict_dataccdi_project_status 新增:
    • dict_label = 打标中
    • dict_value = 3

不直接依赖历史初始化脚本作为唯一变更承载,避免新环境与增量环境口径不一致。

错误处理

  • 打标失败时,项目状态必须回退为 0-进行中
  • 若状态更新失败,不应静默吞掉,需要保留日志,便于排查“任务完成但状态未切回”的问题
  • 服务端拦截返回的错误文案要能让用户理解是“项目正在打标,所以暂时不可操作”
  • 前端收到业务错误后直接展示后端文案,不再自行拼装另一套口径

测试设计

至少覆盖以下测试:

1. 打标状态流转测试

  • 手工打标开始时置为 3
  • 手工打标成功后置为 1
  • 手工打标失败后回退为 0
  • 自动打标开始时也会置为 3
  • 存在补跑时,期间持续保持 3

2. 服务端拦截测试

  • 项目状态为 3 时,批量上传流水被拒绝
  • 项目状态为 3 时,拉取本行信息被拒绝
  • 项目状态为 3 时,参数保存被拒绝

3. 前端页面测试/联调验证

  • 项目详情页正确显示“打标中”
  • 上传数据页相关按钮禁用
  • 参数模型页输入框和保存按钮禁用
  • 项目列表与状态统计正确显示“打标中”

风险与兼容性

  • 新增状态 3 后,所有基于项目状态写死 0/1/2 的前后端逻辑都要排查,避免出现未知状态回退到默认分支
  • 字典数据、状态统计 VO、前端颜色映射、按钮显隐条件需同步改造否则会出现展示不一致
  • 若存在历史完成项目再次触发自动打标,按本设计会先进入 3-打标中,完成后重新回到 1-已完成,这是符合本次需求的

实施拆分建议

后续实施计划建议拆成两份:

  • 后端实施计划:状态枚举/SQL/服务端状态切换/拦截/测试
  • 前端实施计划:详情页禁用/列表与统计展示/交互提示/联调验证

这样能符合仓库“前后端分别产出实施计划”的协作约定。