# 实现任务清单 **Change ID**: `add-commission-withdrawal-settings` --- ## 阶段 1: DTO 定义 (15 分钟) ### Task 1.1: 创建 DTO 文件 **文件**: `internal/model/commission_withdrawal_setting_dto.go` **实现内容**: - [x] 1.1.1 `CreateWithdrawalSettingReq` 请求结构 - [x] 1.1.2 `WithdrawalSettingListReq` 分页请求 - [x] 1.1.3 `WithdrawalSettingItem` 响应结构 **验证**: - [x] 验证标签正确(必填项) - [x] JSON 标签正确 --- ## 阶段 2: Store 层 (30 分钟) ### Task 2.1: 扩展 CommissionWithdrawalSetting Store **文件**: `internal/store/postgres/commission_withdrawal_setting_store.go` **实现内容**: - [x] 2.1.1 `Create(setting)` - 创建配置 - [x] 2.1.2 `List(req)` - 分页查询(按创建时间倒序) - [x] 2.1.3 `GetCurrent()` - 获取当前生效配置(is_active=true) - [x] 2.1.4 `DeactivateCurrent()` - 将当前配置设为失效 **验证**: - [x] 查询逻辑正确 - [x] 关联创建人信息 --- ## 阶段 3: Service 层 (45 分钟) ### Task 3.1: 创建 Service **文件**: `internal/service/commission_withdrawal_setting/service.go` **实现内容**: - [x] 3.1.1 `Create(ctx, req)` - 新增配置 - [x] 3.1.2 `List(ctx, req)` - 查询配置列表 - [x] 3.1.3 `GetCurrent(ctx)` - 获取当前生效配置 **业务逻辑**: - [x] 3.1.4 新增时先失效旧配置,再创建新配置(事务) **验证**: - [x] 配置切换逻辑正确 - [x] 权限检查(仅平台用户) --- ## 阶段 4: Handler 层 (30 分钟) ### Task 4.1: 创建 Handler **文件**: `internal/handler/admin/commission_withdrawal_setting.go` **实现内容**: - [x] 4.1.1 `CreateWithdrawalSetting` - POST /api/admin/commission/withdrawal-settings - [x] 4.1.2 `ListWithdrawalSettings` - GET /api/admin/commission/withdrawal-settings - [x] 4.1.3 `GetCurrentWithdrawalSetting` - GET /api/admin/commission/withdrawal-settings/current **验证**: - [x] 参数校验正确 - [x] 响应格式正确 --- ### Task 4.2: 路由注册 **实现内容**: - [x] 4.2.1 注册三个 API 路由 - [x] 4.2.2 配置权限(仅平台用户可新增) --- ## 阶段 5: 测试 (30 分钟) ### Task 5.1: 功能测试 **实现内容**: - [x] 5.1.1 新增配置测试 - [x] 5.1.2 配置切换测试(旧配置自动失效) - [x] 5.1.3 获取当前配置测试 --- ## 完成标准 - [x] 所有 DTO 定义完成 - [x] Store 层方法实现完成 - [x] Service 层业务逻辑完成 - [x] Handler 层 API 实现完成 - [x] 配置切换逻辑正确 - [x] 编译通过 - [x] 功能测试通过