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>
2.3 KiB
2.3 KiB
Why
套餐分配给代理后,代理无法独立控制自己的客户侧上下架状态:代理调用上下架接口会直接修改平台级字段 tb_package.shelf_status,导致整个平台的该套餐都被下架。需要在分配记录层引入独立的上下架字段,并确立角色上下文决定操作目标的设计原则,为未来 SaaS 化奠定基础。
What Changes
- 新增
tb_shop_package_allocation.shelf_status字段(1-上架, 2-下架),分配时默认上架 - 修改
PATCH /api/admin/packages/:id/shelf接口行为:平台/超管修改tb_package.shelf_status,代理修改自己的tb_shop_package_allocation.shelf_status - 修改 代理查询套餐列表/详情时,
shelf_status字段返回各自分配记录的值(而非平台级值) - 修改 购买校验逻辑:代理场景下检查卖家代理的
allocation.shelf_status,不再检查package.shelf_status - 修复
PUT /api/admin/shop-package-allocations/:id/status接口:加入所有者校验(只有分配者才能修改该条记录的 status)
Capabilities
New Capabilities
allocation-shelf-status:代理分配记录的独立上下架能力,包括字段定义、API 行为分流(按角色路由到不同数据层)、读取时的展示逻辑
Modified Capabilities
package-management:shelf_status上下架操作的角色分流行为变更(平台→改套餐本身,代理→改分配记录)agent-available-packages:代理查询套餐时shelf_status字段语义变更(返回各自分配记录的值)package-purchase-validation:购买校验逻辑变更(代理场景改为检查allocation.shelf_status,平台场景保持检查package.shelf_status)
Impact
- 数据库迁移:
tb_shop_package_allocation新增shelf_status字段 - API 行为变更:
PATCH /packages/:id/shelf同一接口因角色不同操作不同数据层 - 购买链路:
purchase_validation服务逻辑调整,需结合购买场景判断检查哪一层的 shelf_status - 列表查询:
PackageStore.List()和响应构建逻辑需感知代理角色并返回正确的 shelf_status - 权限修复:
ShopPackageAllocationService.UpdateStatus()需加 allocator 归属校验