一人多车
This commit is contained in:
242
docs/DriverVehicleBindingApi.md
Normal file
242
docs/DriverVehicleBindingApi.md
Normal file
@@ -0,0 +1,242 @@
|
||||
# 驾驶员车辆绑定改动说明
|
||||
|
||||
## 1. 本次改动概览
|
||||
|
||||
本次后端围绕驾驶员与车辆绑定,调整并新增以下能力:
|
||||
|
||||
1. 三检流程未完成时,禁止进行车辆换绑操作。
|
||||
2. 三检流程未完成时,禁止新增出车检查。
|
||||
3. 新增查询接口:返回指定驾驶员已绑定车辆列表,以及所在公司仍可绑定的车辆列表。
|
||||
4. 新增查询接口:仅返回指定驾驶员已绑定车辆列表。
|
||||
5. 新增覆盖式批量绑定接口:前端传驾驶员ID和车辆ID串,后端先清空该驾驶员原有绑定,再绑定最新车辆列表。
|
||||
6. 新增追加式批量绑定接口:前端传驾驶员ID和车辆ID串,后端保留该驾驶员已有绑定,仅追加绑定新车辆。
|
||||
7. 驾驶员表保留单值字段 `vehicleId` 作为默认车辆ID。
|
||||
8. 驾驶员表新增字段 `vehicleIds`,用于存储已绑定车辆ID集合,多个以英文逗号分隔。
|
||||
|
||||
## 2. 三检限制规则
|
||||
|
||||
### 2.1 换绑限制
|
||||
|
||||
- 生效范围:
|
||||
- 驾驶员编辑接口触发换绑时
|
||||
- 车辆编辑接口修改当前绑定驾驶员时
|
||||
- 限制规则:
|
||||
- 若车辆当前存在未完成三检流程,则禁止换绑
|
||||
- 提示文案:
|
||||
- `当前车辆三检流程未完成,不可进行换绑操作`
|
||||
|
||||
### 2.2 新增出车检查限制
|
||||
|
||||
- 生效范围:
|
||||
- 新增车辆进出场检查接口
|
||||
- 限制规则:
|
||||
- 若车辆当前存在未完成三检流程,则不能新增出车检查
|
||||
- 提示文案:
|
||||
- `当前车辆三检流程未完成,不能新增出车检查`
|
||||
|
||||
### 2.3 未完成三检流程判定
|
||||
|
||||
- 判定口径:
|
||||
- 查询车辆最新一条三检记录
|
||||
- 仅当最新记录满足以下两个条件时,才视为已完成:
|
||||
- `inspectPhase = 3`
|
||||
- `flowStatus` 为 `APPROVED` 或 `REJECTED`
|
||||
- 其他情况均视为三检流程未完成
|
||||
|
||||
## 3. 查询驾驶员绑定车辆选项接口
|
||||
|
||||
### 3.1 接口信息
|
||||
|
||||
- 路径:`GET /driverManagement/driver/bindingVehicleOptions`
|
||||
- 入参:
|
||||
- `companyId`:公司ID
|
||||
- `driverId`:驾驶员ID
|
||||
|
||||
### 3.2 返回结构
|
||||
|
||||
返回 `data` 包含两个列表:
|
||||
|
||||
- `boundVehicleList`:该驾驶员已绑定车辆列表
|
||||
- `bindableVehicleList`:该公司还可以绑定的车辆列表
|
||||
|
||||
列表项字段如下:
|
||||
|
||||
- `vehicleId`:车辆ID
|
||||
- `plateNumber`:车牌号
|
||||
- `currentDriverId`:当前绑定驾驶员ID
|
||||
- `currentDriverName`:当前绑定驾驶员姓名
|
||||
- `vehicleType`:车辆类型
|
||||
|
||||
### 3.3 查询规则
|
||||
|
||||
- 已绑定车辆:
|
||||
- 查询当前公司全部未删除车辆
|
||||
- 取 `currentDriver` 中包含当前 `driverId` 的车辆
|
||||
- 可绑定车辆:
|
||||
- 当前公司
|
||||
- 未删除
|
||||
- `vehicleStatus = 1`
|
||||
- `operationStatus = 1`
|
||||
- `currentDriver` 为空
|
||||
|
||||
## 4. 驾驶员批量绑定车辆接口
|
||||
|
||||
### 4.1 接口信息
|
||||
|
||||
- 路径:`POST /driverManagement/driver/batchBindVehicles`
|
||||
- 请求体:
|
||||
|
||||
```json
|
||||
{
|
||||
"driverId": "abc123",
|
||||
"vehicleIds": "1001,1002,1003"
|
||||
}
|
||||
```
|
||||
|
||||
### 4.2 参数说明
|
||||
|
||||
- `driverId`:必填,驾驶员ID
|
||||
- `vehicleIds`:
|
||||
- 可为空
|
||||
- 多个车辆ID使用英文逗号分隔
|
||||
- 若为空,表示清空该驾驶员当前绑定车辆
|
||||
|
||||
### 4.3 业务规则
|
||||
|
||||
接口执行过程如下:
|
||||
|
||||
1. 校验驾驶员是否存在。
|
||||
2. 根据驾驶员所属公司校验目标车辆是否存在且归属当前公司。
|
||||
3. 若原绑定车辆或目标绑定车辆存在未完成三检流程,则禁止批量绑定。
|
||||
4. 先将该驾驶员从原已绑定车辆中解绑。
|
||||
5. 再将目标车辆批量绑定到当前驾驶员。
|
||||
6. 同步回写驾驶员表中的:
|
||||
- `vehicleId`:默认车辆ID,取当前绑定车辆中的主车辆
|
||||
- `vehicleIds`:全部绑定车辆ID集合
|
||||
- `plateNumber`:默认车辆对应车牌号
|
||||
7. 同步处理受影响的其他驾驶员车辆关系。
|
||||
|
||||
### 4.4 返回结果
|
||||
|
||||
- 成功:返回通用成功响应
|
||||
- 失败:抛出业务异常并返回对应提示
|
||||
|
||||
## 5. 查询驾驶员已绑定车辆列表接口
|
||||
|
||||
### 5.1 接口信息
|
||||
|
||||
- 路径:`GET /driverManagement/driver/boundVehicles`
|
||||
- 入参:
|
||||
- `companyId`:公司ID
|
||||
- `driverId`:驾驶员ID
|
||||
|
||||
### 5.2 返回字段
|
||||
|
||||
返回列表项字段如下:
|
||||
|
||||
- `vehicleId`:车辆ID
|
||||
- `plateNumber`:车牌号
|
||||
- `currentDriverId`:当前绑定驾驶员ID
|
||||
- `currentDriverName`:当前绑定驾驶员姓名
|
||||
- `vehicleType`:车辆类型
|
||||
|
||||
## 6. 驾驶员追加批量绑定车辆接口
|
||||
|
||||
### 6.1 接口信息
|
||||
|
||||
- 路径:`POST /driverManagement/driver/appendBindVehicles`
|
||||
- 请求体:
|
||||
|
||||
```json
|
||||
{
|
||||
"driverId": "abc123",
|
||||
"vehicleIds": "1001,1002,1003"
|
||||
}
|
||||
```
|
||||
|
||||
### 6.2 业务规则
|
||||
|
||||
接口执行过程如下:
|
||||
|
||||
1. 校验驾驶员是否存在。
|
||||
2. 根据驾驶员所属公司校验目标车辆是否存在且归属当前公司。
|
||||
3. 不取消该驾驶员现有绑定车辆。
|
||||
4. 仅将本次新增传入的车辆追加绑定给当前驾驶员。
|
||||
5. 若新增车辆当前已绑定其他驾驶员,则转绑到当前驾驶员,并同步受影响驾驶员关系。
|
||||
6. 若本次新增车辆存在未完成三检流程,则禁止绑定。
|
||||
7. 同步回写驾驶员表中的:
|
||||
- `vehicleId`
|
||||
- `vehicleIds`
|
||||
- `plateNumber`
|
||||
|
||||
## 7. 驾驶员解除绑定接口
|
||||
|
||||
### 7.1 接口信息
|
||||
|
||||
- 路径:`POST /driverManagement/driver/unbindVehicles`
|
||||
- 请求体:
|
||||
|
||||
```json
|
||||
{
|
||||
"driverId": "abc123",
|
||||
"vehicleIds": "1001,1002"
|
||||
}
|
||||
```
|
||||
|
||||
### 7.2 参数说明
|
||||
|
||||
- `driverId`:必填,驾驶员ID
|
||||
- `vehicleIds`:
|
||||
- 可为空
|
||||
- 多个车辆ID使用英文逗号分隔
|
||||
- 为空时表示清空该驾驶员当前全部绑定车辆
|
||||
- 有值时表示仅解绑指定车辆
|
||||
|
||||
### 7.3 业务规则
|
||||
|
||||
接口执行过程如下:
|
||||
|
||||
1. 校验驾驶员是否存在。
|
||||
2. 根据驾驶员所属公司校验目标车辆是否存在且归属当前公司。
|
||||
3. 校验传入车辆当前确实绑定在该驾驶员名下,否则禁止解绑。
|
||||
4. 校验待解绑车辆当前不存在未完成三检流程,否则禁止解绑。
|
||||
5. 仅执行解绑,不触发换绑逻辑。
|
||||
6. 从该驾驶员当前绑定关系中移除指定车辆,或清空全部绑定。
|
||||
7. 同步回写驾驶员表中的:
|
||||
- `vehicleId`
|
||||
- `vehicleIds`
|
||||
- `plateNumber`
|
||||
|
||||
## 8. 绑定模型说明
|
||||
|
||||
- 当前车辆表实际是一车单人绑定,`currentDriver` 仅保留单个驾驶员ID。
|
||||
- 驾驶员表支持一个驾驶员绑定多辆车:
|
||||
- `vehicleId`:默认车辆ID,单值
|
||||
- `vehicleIds`:全部绑定车辆ID集合,多值CSV
|
||||
- `plateNumber`:默认车辆对应车牌号,单值
|
||||
- 因此批量绑定的核心逻辑是:
|
||||
- 车辆侧单车只绑定一个驾驶员
|
||||
- 驾驶员侧允许关联多辆车
|
||||
- 移动端与司机端默认取 `vehicleId` 作为当前车辆
|
||||
|
||||
## 9. 数据库脚本
|
||||
|
||||
- 脚本文件:`sql/alter_hot_driver_vehicle_ids_20260522.sql`
|
||||
- 脚本内容:
|
||||
|
||||
```sql
|
||||
ALTER TABLE hot_driver
|
||||
ADD COLUMN vehicle_ids VARCHAR(1000) NULL COMMENT '已绑定车辆ID集合,多个以逗号分隔' AFTER vehicle_id;
|
||||
|
||||
UPDATE hot_driver
|
||||
SET vehicle_ids = NULLIF(TRIM(vehicle_id), '')
|
||||
WHERE vehicle_ids IS NULL
|
||||
AND vehicle_id IS NOT NULL;
|
||||
|
||||
UPDATE hot_driver
|
||||
SET vehicle_id = NULLIF(SUBSTRING_INDEX(vehicle_ids, ',', 1), ''),
|
||||
plate_number = NULLIF(SUBSTRING_INDEX(plate_number, ',', 1), '');
|
||||
|
||||
ALTER TABLE hot_driver
|
||||
DROP COLUMN current_page_vehicle_id;
|
||||
```
|
||||
113
docs/VehicleThreeInspectApi.md
Normal file
113
docs/VehicleThreeInspectApi.md
Normal file
@@ -0,0 +1,113 @@
|
||||
# 车辆三检模块改动说明
|
||||
|
||||
## 1. 本次改动
|
||||
|
||||
本次对车辆三检模块新增了以下能力:
|
||||
|
||||
1. 新增字段 `rejectReason`,表示审核不通过原因。
|
||||
2. 新增批量审核接口,管理员可以一键审核多条不同的车辆三检内容。
|
||||
|
||||
## 2. 字段变更
|
||||
|
||||
### 2.1 新增字段
|
||||
|
||||
- 字段名:`rejectReason`
|
||||
- 含义:审核不通过原因
|
||||
- 生效场景:仅在审核不通过时有值
|
||||
|
||||
### 2.2 使用规则
|
||||
|
||||
- 当审核通过时:
|
||||
- 后端自动将 `rejectReason` 置空
|
||||
- 当审核不通过时:
|
||||
- 前端需要传入 `rejectReason`
|
||||
- 若未传,后端会返回业务异常:
|
||||
- `审核不通过时,不通过原因不能为空`
|
||||
|
||||
### 2.3 数据库说明
|
||||
|
||||
车辆三检表需要新增字段:
|
||||
|
||||
```sql
|
||||
ALTER TABLE hot_vehicle_three_inspect
|
||||
ADD COLUMN reject_reason varchar(500) NULL COMMENT '审核不通过原因';
|
||||
```
|
||||
|
||||
## 3. 单条审核接口调整
|
||||
|
||||
### 3.1 接口信息
|
||||
|
||||
- 路径:`POST /securityManagement/vehicleThreeInspect/audit`
|
||||
|
||||
### 3.2 新增请求字段
|
||||
|
||||
- `rejectReason`:审核不通过原因
|
||||
|
||||
### 3.3 审核规则
|
||||
|
||||
- 当前仍以 `hasHiddenDanger` 作为是否通过的判断依据:
|
||||
- `hasHiddenDanger = 0`:审核通过
|
||||
- `hasHiddenDanger = 1`:审核不通过
|
||||
- 审核不通过时必须传 `rejectReason`
|
||||
- 审核通过时 `rejectReason` 不入库
|
||||
|
||||
## 4. 批量审核接口
|
||||
|
||||
### 4.1 接口信息
|
||||
|
||||
- 路径:`POST /securityManagement/vehicleThreeInspect/batchAudit`
|
||||
- 说明:管理员可一次性审核多条不同三检记录
|
||||
|
||||
### 4.2 请求体
|
||||
|
||||
```json
|
||||
{
|
||||
"auditItems": [
|
||||
{
|
||||
"id": 101,
|
||||
"taskId": "task_001",
|
||||
"auditTime": "2026-05-22 10:00:00",
|
||||
"hasHiddenDanger": 0,
|
||||
"auditResult": "审核通过",
|
||||
"auditorSignImgUrl": "12345"
|
||||
},
|
||||
{
|
||||
"id": 102,
|
||||
"taskId": "task_002",
|
||||
"auditTime": "2026-05-22 10:05:00",
|
||||
"hasHiddenDanger": 1,
|
||||
"auditResult": "发现问题需整改",
|
||||
"rejectReason": "轮胎磨损超标",
|
||||
"auditorSignImgUrl": "12345"
|
||||
}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
### 4.3 请求字段说明
|
||||
|
||||
批量项沿用单条审核字段,核心包括:
|
||||
|
||||
- `id`:三检记录ID
|
||||
- `taskId`:流程任务ID
|
||||
- `auditTime`:审核时间
|
||||
- `hasHiddenDanger`:是否存在隐患
|
||||
- `auditResult`:审核结论
|
||||
- `rejectReason`:审核不通过原因
|
||||
- `auditorSignImgUrl`:审核人签名
|
||||
|
||||
### 4.4 处理规则
|
||||
|
||||
接口会逐条执行以下逻辑:
|
||||
|
||||
1. 校验三检记录ID和流程任务ID。
|
||||
2. 校验审核时间不能早于检查时间。
|
||||
3. 若传了审核签名,则校验签名归属。
|
||||
4. 根据 `hasHiddenDanger` 处理通过/不通过逻辑。
|
||||
5. 审核不通过时校验 `rejectReason` 必填。
|
||||
6. 更新三检记录并推进对应流程任务。
|
||||
|
||||
## 5. 影响范围
|
||||
|
||||
- 详情接口、列表接口、导出接口会返回 `rejectReason` 字段。
|
||||
- 审核驳回通知优先展示 `rejectReason`,没有时才回退展示 `auditResult`。
|
||||
Reference in New Issue
Block a user