Files
junhong_cmp_fiber/openspec/changes/client-api-data-model-fixes/specs/agent-retail-price/spec.md
huang ec86dbf463 feat: 客户端接口数据模型基础准备
- 新增资产状态、订单来源、操作人类型、实名链接类型常量
- 8个模型新增字段(asset_status/generation/source/retail_price等)
- 数据库迁移000082:7张表15+字段,含存量retail_price回填
- BUG-1修复:代理零售价渠道隔离,cost_price分配锁定
- BUG-2修复:一次性佣金仅客户端订单触发
- BUG-4修复:充值回调Store操作纳入事务
- 新增资产手动停用接口(PATCH /iot-cards/:id/deactivate、/devices/:id/deactivate)
- Carrier管理新增实名链接配置
- 后台订单generation写时快照
- BatchUpdatePricing支持retail_price调价目标
- 清理全部H5旧接口和个人客户旧登录方法
2026-03-19 10:56:50 +08:00

2.1 KiB

ADDED Requirements

Requirement: 分配零售价字段定义

系统 MUST 在 ShopPackageAllocation 新增 retail_price bigint NOT NULL DEFAULT 0 字段。

Scenario: 新字段存在且非空

  • WHEN 执行分配记录建表或迁移
  • THEN retail_price MUST 为非空整型字段,默认值为 0

Requirement: 分配创建默认零售价规则

系统 MUST 在创建分配记录时将 retail_price 自动设置为对应 Package.SuggestedRetailPrice

Scenario: 创建分配自动带出建议零售价

  • WHEN 平台给代理创建套餐分配记录
  • THEN 新记录的 retail_price MUST 等于该套餐的 suggested_retail_price

Requirement: 零售价约束规则

系统 MUST 强制校验:retail_price >= cost_priceretail_price <= suggested_retail_price * 2

Scenario: 零售价低于成本价

  • WHEN 代理设置 retail_price < cost_price
  • THEN 系统 MUST 拒绝保存并返回价格约束错误

Scenario: 零售价超过建议价两倍

  • WHEN 代理设置 retail_price > suggested_retail_price * 2
  • THEN 系统 MUST 拒绝保存并返回价格约束错误

Requirement: 成本价分配锁定规则

当某分配存在下级分配记录时,系统 MUST 禁止修改该分配的 cost_price

Scenario: 存在下级分配时修改成本价

  • WHEN 上级分配记录已被继续分配到下级店铺
  • THEN 系统 MUST 拒绝对该记录的 cost_price 修改

Requirement: 代理零售价可调与存量迁移

系统 MUST 允许代理修改自己分配记录的 retail_price(在约束范围内);系统 MUST 对存量数据执行迁移:将 retail_price 批量更新为对应套餐的 SuggestedRetailPrice

Scenario: 代理调整自己的零售价

  • WHEN 代理修改自己分配记录的 retail_price 且满足价格约束
  • THEN 系统 MUST 允许更新

Scenario: 存量数据回填零售价

  • WHEN 执行本次数据迁移
  • THEN 系统 MUST 将历史 ShopPackageAllocation.retail_price 批量更新为对应套餐的 SuggestedRetailPrice