tyt-api-nest/docs/uploads.md
EL 0b5640a977 调压任务流程从“发布即指派”改为“发布待接收(PENDING) -> 工程师接收(ACCEPTED) -> 完成(COMPLETED)”。
新增工程师“取消接收”能力,任务可从 ACCEPTED 回退到 PENDING。
发布任务不再要求 engineerId,并增加同设备存在未结束任务时的重复发布拦截。
完成任务新增 completionMaterials 必填校验,仅允许图片/视频凭证,并在完成时落库。
植入物目录新增 isValve,区分阀门与管子;非阀门不维护压力挡位,阀门至少 1 个挡位。
患者设备与任务查询返回新增字段,前端任务页支持接收/取消接收/上传凭证后完成。
增补 Prisma 迁移、接口文档、E2E 用例与夹具修复逻辑。
2026-03-20 06:03:09 +08:00

2.7 KiB
Raw Blame History

上传资产模块说明(src/uploads

1. 目标

  • 提供图片、视频、文件的统一上传入口。
  • 为 B 端“影像库/视频库/文件库”页面提供分页查询。
  • 为患者手术表单中的术前资料、植入物标签上传提供复用能力。

2. 数据模型

新增 UploadAsset 表,保存上传文件元数据:

  • hospitalId:医院归属
  • creatorId:上传人
  • typeIMAGE / VIDEO / FILE
  • originalName:原始文件名
  • fileName:服务端生成文件名
  • storagePath:相对存储路径
  • url:公开访问地址,前端直接用于预览
  • mimeType:文件 MIME 类型
  • fileSize:文件大小(字节)

文件本体默认落盘到:

  • 公开目录:storage/uploads
  • 临时目录:storage/tmp-uploads
  • 最终目录规则:storage/uploads/YYYY/MM/DD
  • 最终文件名规则:YYYYMMDDHHmmss-原文件名
    • 图片压缩后扩展名统一为 .webp
    • 视频压缩后扩展名统一为 .mp4
    • 如同一秒内出现同名文件,会自动追加 -1-2 防止覆盖

3. 接口

  • POST /b/uploads
    • 角色:SYSTEM_ADMIN / HOSPITAL_ADMIN / DIRECTOR / LEADER / DOCTOR / ENGINEER
    • 表单字段:
      • file:二进制文件
      • hospitalId:仅 SYSTEM_ADMIN 上传时必填
  • GET /b/uploads
    • 角色:SYSTEM_ADMIN / HOSPITAL_ADMIN
    • 查询参数:
      • keyword
      • type
      • hospitalId:仅 SYSTEM_ADMIN 可选
      • page
      • pageSize

4. 使用说明

  • 患者手术表单中的“术前 CT 影像/资料”支持直接上传,上传成功后自动回填 type/name/url
  • 设备表单中的“植入物标签”支持直接上传图片,上传成功后自动回填 labelImageUrl
  • 工程师完成调压任务时,可直接上传图片或视频作为完成凭证。
  • 患者详情页会直接预览术前图片、视频和设备标签。
  • 单独新增“影像库”页面,按图片/视频/文件分页查看所有上传资产。
    • 页面访问权限仅 SYSTEM_ADMIN / HOSPITAL_ADMIN

5. 压缩策略

  • 图片上传后会自动压缩并统一转成 webp
    • 自动纠正旋转方向
    • 最大边限制为 2560
    • 返回的 mimeTypeimage/webp
  • 视频上传后会自动压缩并统一转成 mp4
    • 最大边限制为 1280
    • 视频编码为 H.264
    • 音频编码为 AAC
    • 返回的 mimeTypevideo/mp4
  • 普通文件类型不做转码,按原文件保存。
  • 如果本地 pnpm install 屏蔽了依赖安装脚本,ffmpeg-static 二进制不会自动落盘,视频压缩会失败。
    • 这种情况下手动执行:
      • node node_modules/.pnpm/ffmpeg-static@5.3.0/node_modules/ffmpeg-static/install.js