文档
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 6m2s

This commit is contained in:
2026-01-31 13:06:30 +08:00
parent b8dda7e62a
commit 62708892ec
29 changed files with 6568 additions and 31 deletions

View File

@@ -0,0 +1,82 @@
## Why
当前系统缺少完整的强充(强制充值)机制和代购订单支持,导致以下问题:(1) 个人客户无法直接给钱包充值,必须通过购买套餐间接充值;(2) 平台和代理无法为其他代理代购套餐(线下已收款场景);(3) 一次性佣金触发机制不完善,代购订单错误触发佣金且累加充值金额;(4) 缺少强充预检接口,前端无法提前告知用户充值限制。这些限制影响了业务灵活性和用户体验,需要立即完善。
## What Changes
- **新增钱包充值系统**实现个人客户直接充值钱包功能包含充值订单RechargeRecord的创建、支付、回调处理充值成功触发佣金计算
- **新增强充预检接口**:提供钱包充值预检和套餐购买预检接口,返回强充要求、金额限制、实际支付金额等信息
- **新增代购订单功能**:支持平台/代理给其他代理代购套餐,使用线下支付方式,订单标记为代购类型
- **扩展强充配置**ShopSeriesAllocation 模型新增 `enable_force_recharge``force_recharge_amount` 字段,支持累计充值强充配置(可选)
- **修复佣金计算逻辑**:代购订单不触发一次性佣金,不累加 `AccumulatedRecharge`,确保佣金计算准确性
- **扩展订单模型**Order 模型新增 `is_purchase_on_behalf` 字段和 `offline` 支付方式,区分代购订单和普通订单
- **完善充值验证**:创建充值订单和购买订单时强制验证强充要求,防止前端绕过限制
## Capabilities
### New Capabilities
- `wallet-recharge`: 钱包充值系统,包含充值订单创建、支付集成(微信/支付宝)、回调处理、充值成功后触发佣金计算
- `force-recharge-check`: 强充预检接口,包含钱包充值预检、套餐购买预检,返回强充要求和金额限制
- `purchase-on-behalf`: 代购订单功能,支持平台/代理为其他代理代购套餐,使用线下支付,区分代购和普通订单
### Modified Capabilities
- `commission-calculation`: 修改佣金计算逻辑,代购订单不触发一次性佣金,不累加 AccumulatedRecharge
- `order-management`: 订单模型增加 `is_purchase_on_behalf` 字段,支持代购订单类型
- `order-payment`: 支付方式增加 `offline` 线下支付,代购订单创建后直接标记为已支付
- `shop-series-allocation`: 增加强充配置字段(`enable_force_recharge``force_recharge_amount`),支持累计充值强充设置
## Impact
### 数据库变更
- **tb_order 表**:新增 `is_purchase_on_behalf` 字段BOOLEAN`payment_method` 增加 `offline` 枚举值
- **tb_shop_series_allocation 表**:新增 `enable_force_recharge` 字段BOOLEAN`force_recharge_amount` 字段BIGINT
- **tb_recharge_record 表**:已存在但未使用,需要创建对应的 Store/Service/Handler
- **数据库迁移**:需要创建迁移文件添加新字段
### 新增代码模块
- **Store 层**`RechargeStore`(充值订单数据访问)
- **Service 层**`RechargeService`(充值业务逻辑)、强充预检逻辑(在现有 Service 中)
- **Handler 层**`RechargeHandler`(充值 HTTP 接口)、充值预检接口(在现有 Handler 中)
- **Task 层**:充值支付回调处理(在现有 callback handler 中扩展)
### 修改现有代码
- **CommissionCalculationService**:增加代购订单判断逻辑
- **OrderService**:增加代购订单创建逻辑、强充验证逻辑
- **OrderHandler**admin增加平台创建代购订单接口
- **ShopSeriesAllocationService**:支持强充配置的创建和更新
### API 变更
- **新增接口**
- `GET /api/h5/wallets/recharge-check` - 钱包充值预检
- `POST /api/h5/recharge-records` - 创建充值订单
- `GET /api/h5/recharge-records` - 查询充值订单列表
- `GET /api/h5/recharge-records/:id` - 查询充值订单详情
- `POST /api/h5/orders/purchase-check` - 套餐购买预检
- `POST /api/admin/orders` - 修改以支持代购订单创建
- **修改接口**
- `POST /api/admin/shop-series-allocations` - 支持强充配置参数
- `PUT /api/admin/shop-series-allocations/:id` - 支持强充配置更新
### 支付回调处理
- **微信支付回调**:扩展支持充值订单的回调处理
- **支付宝回调**:扩展支持充值订单的回调处理
### 业务逻辑影响
- **佣金计算**:代购订单不触发一次性佣金,但仍计算差价佣金
- **累计充值**:只有真实充值(个人客户充值或购买套餐)才累加 AccumulatedRecharge
- **强充触发**
- 首次充值必须充值阈值金额OneTimeCommissionThreshold
- 累计充值如果启用强充必须充值固定金额ForceRechargeAmount
- **订单支付**:代购订单创建后直接标记为已支付,跳过钱包扣款
### 测试影响
- **单元测试**:需要为所有新增 Service 方法编写测试
- **集成测试**:需要测试完整的充值流程、强充预检、代购订单流程
- **测试覆盖率**:核心业务逻辑测试覆盖率需保持 ≥ 90%
### 性能考虑
- 预检接口响应时间 < 100ms涉及数据库查询
- 充值订单创建响应时间 < 200ms
- 支付回调处理时间 < 500ms异步处理佣金计算