All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 5m24s
- 新增套餐系列管理 (CRUD + 状态切换) - 新增套餐管理 (CRUD + 启用/禁用 + 上架/下架双状态) - 清理 8 个废弃分佣模型及对应数据库表 - Package 模型新增建议成本价、建议售价、上架状态字段 - 完整的 Store/Service/Handler 三层实现 - 包含单元测试和集成测试 - 归档 add-package-module change - 新增多个 OpenSpec changes (订单支付、店铺套餐分配、一次性分佣、卡设备系列绑定)
6.2 KiB
6.2 KiB
1. 模型清理
- 1.1 删除
internal/model/commission.go中的废弃模型(AgentHierarchy, CommissionRule, CommissionLadder, CommissionCombinedCondition, CommissionApproval, CommissionTemplate, CarrierSettlement) - 1.2 删除
internal/model/package.go中的AgentPackageAllocation模型 - 1.3 执行
go build ./...确认无编译错误,如有引用则同步清理
2. Package 模型调整
- 2.1 在
internal/model/package.go的 Package 结构体中新增suggested_cost_price字段(bigint, 默认 0, 注释:建议成本价) - 2.2 在 Package 结构体中新增
suggested_retail_price字段(bigint, 默认 0, 注释:建议售价) - 2.3 在 Package 结构体中新增
shelf_status字段(int, 默认 2, 注释:上架状态 1-上架 2-下架)
3. 数据库迁移
- 3.1 创建迁移文件,UP 脚本删除 8 个废弃表:tb_agent_hierarchy, tb_commission_rule, tb_commission_ladder, tb_commission_combined_condition, tb_commission_approval, tb_commission_template, tb_carrier_settlement, tb_agent_package_allocation
- 3.2 在迁移 UP 脚本中添加 tb_package 表的 3 个新字段
- 3.3 编写迁移 DOWN 脚本(重建表结构、删除新字段)
- 3.4 本地执行迁移验证
4. 套餐系列 DTO
- 4.1 创建
internal/model/dto/package_series.go,定义 CreatePackageSeriesRequest(series_code 必填, series_name 必填, description 可选) - 4.2 定义 UpdatePackageSeriesRequest(series_name, description)
- 4.3 定义 PackageSeriesListRequest(page, page_size, series_name 模糊, status 筛选)
- 4.4 定义 UpdatePackageSeriesStatusRequest(status 必填)
- 4.5 定义 PackageSeriesResponse 响应结构
5. 套餐系列 Store
- 5.1 创建
internal/store/postgres/package_series_store.go,实现 Create 方法 - 5.2 实现 GetByID 方法
- 5.3 实现 GetByCode 方法(用于编码唯一性检查)
- 5.4 实现 Update 方法
- 5.5 实现 Delete 方法(软删除)
- 5.6 实现 List 方法(支持分页、名称模糊搜索、状态筛选)
- 5.7 实现 UpdateStatus 方法
6. 套餐系列 Service
- 6.1 创建
internal/service/package_series/service.go,实现 Create 方法(检查编码唯一性) - 6.2 实现 Get 方法
- 6.3 实现 Update 方法(忽略编码修改)
- 6.4 实现 Delete 方法
- 6.5 实现 List 方法
- 6.6 实现 UpdateStatus 方法
7. 套餐系列 Handler
- 7.1 创建
internal/handler/admin/package_series.go,实现 Create 接口 - 7.2 实现 Get 接口
- 7.3 实现 Update 接口
- 7.4 实现 Delete 接口
- 7.5 实现 List 接口
- 7.6 实现 UpdateStatus 接口
8. 套餐 DTO
- 8.1 创建
internal/model/dto/package.go,定义 CreatePackageRequest(package_code 必填, package_name 必填, series_id, package_type 必填, duration_months 必填, data_type, real_data_mb, virtual_data_mb, data_amount_mb, price 必填, suggested_cost_price, suggested_retail_price) - 8.2 定义 UpdatePackageRequest(除 package_code 外的字段)
- 8.3 定义 PackageListRequest(page, page_size, package_name 模糊, series_id, status, shelf_status, package_type)
- 8.4 定义 UpdatePackageStatusRequest(status 必填)
- 8.5 定义 UpdatePackageShelfStatusRequest(shelf_status 必填)
- 8.6 定义 PackageResponse 响应结构(包含新增的 3 个字段)
9. 套餐 Store
- 9.1 创建
internal/store/postgres/package_store.go,实现 Create 方法 - 9.2 实现 GetByID 方法
- 9.3 实现 GetByCode 方法
- 9.4 实现 Update 方法
- 9.5 实现 Delete 方法
- 9.6 实现 List 方法(支持分页、名称模糊、系列筛选、状态筛选、上架状态筛选、类型筛选)
- 9.7 实现 UpdateStatus 方法
- 9.8 实现 UpdateShelfStatus 方法
10. 套餐 Service
- 10.1 创建
internal/service/package/service.go,实现 Create 方法(检查编码唯一性、验证系列存在) - 10.2 实现 Get 方法
- 10.3 实现 Update 方法(忽略编码修改、验证系列存在)
- 10.4 实现 Delete 方法
- 10.5 实现 List 方法
- 10.6 实现 UpdateStatus 方法(禁用时强制下架)
- 10.7 实现 UpdateShelfStatus 方法(检查启用状态才能上架)
11. 套餐 Handler
- 11.1 创建
internal/handler/admin/package.go,实现 Create 接口 - 11.2 实现 Get 接口
- 11.3 实现 Update 接口
- 11.4 实现 Delete 接口
- 11.5 实现 List 接口
- 11.6 实现 UpdateStatus 接口
- 11.7 实现 UpdateShelfStatus 接口
12. Bootstrap 注册
- 12.1 在
internal/bootstrap/stores.go中注册 PackageSeriesStore 和 PackageStore - 12.2 在
internal/bootstrap/services.go中注册 PackageSeriesService 和 PackageService - 12.3 在
internal/bootstrap/handlers.go中注册 PackageSeriesHandler 和 PackageHandler
13. 路由注册
- 13.1 在
internal/router/中注册套餐系列路由组/api/admin/package-series(POST, GET, GET/:id, PUT/:id, DELETE/:id, PATCH/:id/status) - 13.2 注册套餐路由组
/api/admin/packages(POST, GET, GET/:id, PUT/:id, DELETE/:id, PATCH/:id/status, PATCH/:id/shelf)
14. 文档生成器更新
- 14.1 在
cmd/api/docs.go中添加 PackageSeriesHandler 和 PackageHandler - 14.2 在
cmd/gendocs/main.go中添加 PackageSeriesHandler 和 PackageHandler - 14.3 执行
go run cmd/gendocs/main.go生成 OpenAPI 文档
15. 测试
- 15.1 为 PackageSeriesStore 编写单元测试
- 15.2 为 PackageStore 编写单元测试
- 15.3 为 PackageSeriesService 编写单元测试(覆盖编码唯一性检查)
- 15.4 为 PackageService 编写单元测试(覆盖双状态逻辑)
- 15.5 编写套餐系列 API 集成测试
- 15.6 编写套餐 API 集成测试(覆盖禁用强制下架、禁用不能上架场景)
- 15.7 执行
go test ./...确认所有测试通过
16. 最终验证
- 16.1 执行
go build ./...确认编译通过 - 16.2 执行
go vet ./...检查代码质量 - 16.3 启动服务,手动测试 API 接口
- 16.4 确认 OpenAPI 文档正确生成