feat: 新增代理分配套餐上架状态(shelf_status)功能
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 6m56s

- 新增数据库迁移:为 shop_package_allocation 表添加 shelf_status 字段
- 更新模型/DTO:ShopPackageAllocation 增加 ShelfStatus 字段及相关枚举
- 更新套餐分配 Service:支持上架/下架状态管理逻辑
- 更新套餐 Store/Service:根据 shelf_status 过滤可售套餐
- 更新购买验证 Service:引入上架状态校验逻辑
- 归档 OpenSpec 变更:2026-03-02-agent-allocation-shelf-status
- 同步更新主规范文档:allocation-shelf-status、package-management、purchase-validation

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-02 15:38:54 +08:00
parent 8efe79526a
commit 61155952a7
22 changed files with 677 additions and 44 deletions

View File

@@ -0,0 +1,58 @@
# Capability: 分配记录独立上下架
## Purpose
本 capability 定义代理对自己分配到的套餐的独立上下架能力。代理可以独立控制自己客户侧的套餐可见性,互不影响。同时约束分配记录 status 修改的所有者校验规则。
## Requirements
### Requirement: 分配记录独立上下架
系统 SHALL 在 `tb_shop_package_allocation` 表维护 `shelf_status` 字段1-上架, 2-下架),允许代理独立控制自己分配到的套餐在客户侧的可见性,不影响其他代理和平台的同一套餐状态。
#### Scenario: 新建分配记录默认上架
- **WHEN** 平台或上级代理为某店铺创建套餐分配记录
- **THEN** `allocation.shelf_status` 默认为 1上架
#### Scenario: 代理下架自己的套餐
- **GIVEN** 代理A拥有套餐P的分配记录shelf_status=1
- **WHEN** 代理A调用 `PATCH /api/admin/packages/:id/shelf`,传入 shelf_status=2
- **THEN** 系统更新代理A的 `allocation.shelf_status=2`套餐P在代理A的客户侧不可见
- **AND** 代理B的同一套餐分配记录 shelf_status 不受影响
- **AND** `tb_package.shelf_status` 不受影响
#### Scenario: 代理上架自己的套餐
- **GIVEN** 代理A的分配记录 shelf_status=2
- **WHEN** 代理A调用 `PATCH /api/admin/packages/:id/shelf`,传入 shelf_status=1
- **THEN** 系统更新代理A的 `allocation.shelf_status=1`
#### Scenario: 代理上架已被全局禁用的套餐
- **GIVEN** `tb_package.status=2`套餐全局禁用代理A的 allocation.shelf_status=2
- **WHEN** 代理A尝试将 shelf_status 设置为1上架
- **THEN** 系统返回错误 "套餐已禁用,无法上架"
#### Scenario: 调用者无分配记录时无法操作
- **GIVEN** 代理A没有套餐P的分配记录
- **WHEN** 代理A调用 `PATCH /api/admin/packages/:id/shelf`套餐ID为P
- **THEN** 系统返回错误 "该套餐未分配给您,无法操作上下架"
---
### Requirement: 分配记录 status 修改需所有者校验
系统 MUST 验证调用者是分配记录的创建者allocator才允许修改该记录的 `status`(启用/禁用)。
#### Scenario: 平台用户修改任意分配记录的 status
- **GIVEN** 平台用户调用 `PUT /api/admin/shop-package-allocations/:id/status`
- **WHEN** 分配记录存在
- **THEN** 允许修改,不限制 allocator
#### Scenario: 代理修改自己创建的分配记录的 status
- **GIVEN** 代理A创建了"代理A→代理B"的分配记录allocator_shop_id = A的shop_id
- **WHEN** 代理A调用修改该记录的 status
- **THEN** 允许修改
#### Scenario: 代理修改别人分配给自己的记录的 status
- **GIVEN** 平台或代理A创建了"→代理B"的分配记录allocator_shop_id != B的shop_id
- **WHEN** 代理B调用修改该记录的 status
- **THEN** 系统返回错误 "无权限操作该资源或资源不存在"