Files
huang 91c9bbfeb8
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 4m35s
feat: 实现账号与佣金管理模块
新增功能:
- 店铺佣金查询:店铺佣金统计、店铺佣金记录列表、店铺提现记录
- 佣金提现审批:提现申请列表、审批通过、审批拒绝
- 提现配置管理:配置列表、新增配置、获取当前生效配置
- 企业管理:企业列表、创建、更新、删除、获取详情
- 企业卡授权:授权列表、批量授权、批量取消授权、统计
- 客户账号管理:账号列表、创建、更新状态、重置密码
- 我的佣金:佣金统计、佣金记录、提现申请、提现记录

数据库变更:
- 扩展 tb_commission_withdrawal_request 新增提现单号等字段
- 扩展 tb_account 新增 is_primary 字段
- 扩展 tb_commission_record 新增 shop_id、balance_after
- 扩展 tb_commission_withdrawal_setting 新增每日提现次数限制
- 扩展 tb_iot_card、tb_device 新增 shop_id 冗余字段
- 新建 tb_enterprise_card_authorization 企业卡授权表
- 新建 tb_asset_allocation_record 资产分配记录表
- 数据迁移:owner_type 枚举值 agent 统一为 shop

测试:
- 新增 7 个单元测试文件覆盖各服务
- 修复集成测试 Redis 依赖问题
2026-01-21 18:20:44 +08:00

1.9 KiB
Raw Permalink Blame History

Change: 佣金提现设置模块

Why

平台需要配置全局的佣金提现规则:

  1. 每日提现次数限制
  2. 最低提现金额
  3. 提现手续费比率

配置采用"新建生效"模式,新配置生效后旧配置自动失效,保留历史记录。

What Changes

新增 API 接口

方法 路径 说明
POST /api/admin/commission/withdrawal-settings 新增配置
GET /api/admin/commission/withdrawal-settings 配置列表(历史记录)
GET /api/admin/commission/withdrawal-settings/current 获取当前生效配置

技术实现

  • 新增 Handlerinternal/handler/admin/commission_withdrawal_setting.go
  • 新增 Serviceinternal/service/commission_withdrawal_setting/service.go
  • 新增 DTOinternal/model/dto/commission_withdrawal_setting_dto.go
  • 扩展 Storeinternal/store/postgres/commission_withdrawal_setting_store.go

业务逻辑

新增配置

  1. 验证参数有效性
  2. 将当前生效配置的 is_active 设为 false
  3. 创建新配置,is_active 设为 true
  4. 记录创建人

配置字段

  • daily_withdrawal_limit:每日提现次数限制
  • min_withdrawal_amount:最低提现金额(分)
  • fee_rate手续费比率基点100=1%

Impact

影响的规范

  • 新增 Capabilitycommission-withdrawal-settings

影响的代码

新增文件(约 200 行):

  • internal/handler/admin/commission_withdrawal_setting.go~60 行)
  • internal/service/commission_withdrawal_setting/service.go~100 行)
  • internal/model/dto/commission_withdrawal_setting_dto.go~40 行)

兼容性

  • 向后兼容:新增 API不影响现有功能

Dependencies

  • 依赖提案:add-commission-model-changes
  • 依赖现有模型:CommissionWithdrawalSetting

Testing Strategy

  1. 单元测试:配置切换逻辑
  2. 集成测试:新建配置→查询生效配置