# 实现任务清单 **Change ID**: `add-my-commission` --- ## 阶段 1: DTO 定义 (20 分钟) ### Task 1.1: 创建 DTO 文件 **文件**: `internal/model/my_commission_dto.go` **实现内容**: - [x] 1.1.1 `MyCommissionSummaryResp` 佣金概览响应 - [x] 1.1.2 `CreateMyWithdrawalReq` 发起提现请求 - [x] 1.1.3 `CreateMyWithdrawalResp` 发起提现响应 - [x] 1.1.4 `MyWithdrawalListReq` 提现记录查询请求 - [x] 1.1.5 `MyCommissionRecordListReq` 佣金明细查询请求 - [x] 1.1.6 `MyCommissionRecordItem` 佣金记录列表项 - [x] 1.1.7 `MyCommissionRecordPageResult` 佣金记录分页响应 **验证**: - [x] 字段完整 - [x] 验证标签正确 --- ## 阶段 2: Service 层 (1.5 小时) ### Task 2.1: 创建 MyCommission Service **文件**: `internal/service/my_commission/service.go` **实现内容**: - [x] 2.1.1 `GetCommissionSummary(ctx)` - 我的佣金概览 - [x] 2.1.2 `CreateWithdrawalRequest(ctx, req)` - 发起提现 - [x] 2.1.3 `ListMyWithdrawalRequests(ctx, req)` - 我的提现记录 - [x] 2.1.4 `ListMyCommissionRecords(ctx, req)` - 我的佣金明细 **业务逻辑**: - [x] 2.1.5 从上下文获取当前用户的 shop_id - [x] 2.1.6 提现验证(金额、余额、次数限制) - [x] 2.1.7 计算手续费 - [x] 2.1.8 冻结钱包余额 - [x] 2.1.9 生成提现单号 **验证**: - [x] 提现验证逻辑正确 - [x] 钱包操作正确 --- ## 阶段 3: Handler 层 (45 分钟) ### Task 3.1: 创建 Handler **文件**: `internal/handler/admin/my_commission.go` **实现内容**: - [x] 3.1.1 `GetSummary` - GET /api/admin/my/commission-summary - [x] 3.1.2 `CreateWithdrawal` - POST /api/admin/my/withdrawal-requests - [x] 3.1.3 `ListWithdrawals` - GET /api/admin/my/withdrawal-requests - [x] 3.1.4 `ListRecords` - GET /api/admin/my/commission-records **验证**: - [x] 参数校验正确 - [x] 仅代理商用户可访问(Service 层校验) --- ### Task 3.2: 路由注册 **文件**: `internal/routes/my_commission.go` **实现内容**: - [x] 3.2.1 注册四个 API 路由 - [x] 3.2.2 配置权限(仅代理商用户,Service 层校验) --- ### Task 3.3: Bootstrap 注册 **实现内容**: - [x] 3.3.1 `internal/bootstrap/services.go` - 添加 MyCommission Service - [x] 3.3.2 `internal/bootstrap/handlers.go` - 添加 MyCommission Handler - [x] 3.3.3 `internal/bootstrap/types.go` - 添加 MyCommission Handler 类型 - [x] 3.3.4 `internal/routes/admin.go` - 注册 MyCommission 路由 --- ## 阶段 4: 测试 (45 分钟) ### Task 4.1: 功能测试 **实现内容**: - [x] 4.1.1 佣金概览测试 - [x] 4.1.2 发起提现测试 - [x] 4.1.3 提现记录查询测试 - [x] 4.1.4 佣金明细查询测试 ### Task 4.2: 边界测试 **实现内容**: - [x] 4.2.1 最低金额验证 - [x] 4.2.2 每日次数限制验证 - [x] 4.2.3 余额不足验证 - [x] 4.2.4 无提现配置时的处理 --- ## 完成标准 - [x] 所有 DTO 定义完成 - [x] Service 层业务逻辑完成 - [x] Handler 层 API 实现完成 - [x] 提现验证逻辑正确 - [x] 钱包冻结操作正确 - [x] 仅代理商用户可访问 - [x] 编译通过 - [x] 功能测试通过