All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 4m28s
- 修复所有 DTO 文件的 description 标签(10 个文件) - 枚举字段统一使用中文说明(用户类型、角色类型、权限类型等) - 状态字段明确说明 0/1 含义 - validate 标签与 OpenAPI 标签保持一致 - 在 AGENTS.md 和 CLAUDE.md 添加 DTO 规范章节 - AI 助手必须执行的 7 项检查清单 - 常见枚举字段标准值参考 - 确保未来 AI 助手自动遵循规范 - 创建规范文档 - docs/code-review-checklist.md(Code Review 检查清单) - docs/dto-improvement-summary.md(DTO 改进总结) - docs/ai-dto-guidelines-update.md(AI 指引更新说明) - 重新生成 OpenAPI 文档(375 个 description 标签) 影响:所有 API 字段现在都有清晰的中文说明,前端开发更友好
6.1 KiB
6.1 KiB
DTO 规范完善总结
📊 修复概览
修复日期: 2026-01-20
修复范围: 所有 DTO 文件的 description 标签规范化
✅ 已修复的文件清单
1. 账号模块
- ✅
internal/model/account_dto.go- 修复
CreateAccountRequest.UserType- 添加完整中文枚举说明 - 修复
AccountListRequest.UserType- 添加完整中文枚举说明 - 修复
AccountListRequest.Status- 添加 0/1 含义 - 修复
AccountResponse.UserType- 添加完整中文枚举说明 - 修复
AccountResponse.Status- 添加 0/1 含义 - 修复
PlatformAccountListRequest.Status- 添加 0/1 含义
- 修复
2. 认证模块
- ✅
internal/model/auth_dto.go- 为
UserInfo所有字段添加完整的description标签 UserType使用完整中文枚举说明
- 为
3. 角色模块
- ✅
internal/model/role_dto.go- 修复
RoleListRequest.Status- 添加 0/1 含义 - 修复
RoleResponse.RoleType- 添加完整中文枚举说明 - 修复
RoleResponse.Status- 添加 0/1 含义
- 修复
4. 权限模块
- ✅
internal/model/permission_dto.go- 修复
PermissionListRequest.PermType- 添加完整中文枚举说明 - 修复
PermissionListRequest.Platform- 添加完整中文枚举说明 - 修复
PermissionListRequest.Status- 添加 0/1 含义 - 修复
PermissionResponse.PermType- 添加完整中文枚举说明 - 修复
PermissionResponse.Platform- 添加完整中文枚举说明 - 修复
PermissionResponse.Status- 添加 0/1 含义 - 修复
PermissionTreeNode- 所有字段添加完整说明
- 修复
5. 店铺模块
- ✅
internal/model/shop_dto.go- 从无
description标签 → 所有字段添加完整的description标签 - 添加 validate 对应的 OpenAPI 标签(required、minLength、maxLength 等)
Status字段添加 0/1 含义说明Level字段说明店铺层级范围
- 从无
6. 企业模块
- ✅
internal/model/enterprise_dto.go- 从行内注释 → 改为
description标签 Status字段添加 0/1 含义说明- 所有字段添加清晰的中文说明
- 从行内注释 → 改为
7. 个人客户模块
- ✅
internal/model/personal_customer_dto.go- 从行内注释 → 改为
description标签 Status字段添加 0/1 含义说明- 所有字段添加清晰的中文说明
- 从行内注释 → 改为
8. 代理商账号模块
- ✅
internal/model/shop_account_dto.go- 从行内注释 → 改为
description标签 UserType和Status字段添加完整枚举说明
- 从行内注释 → 改为
9. 角色-权限关联模块
- ✅
internal/model/role_permission_dto.go- 从无
description标签 → 所有字段添加完整说明 Status字段添加 0/1 含义说明
- 从无
10. 账号-角色关联模块
- ✅
internal/model/account_role_dto.go- 从无
description标签 → 所有字段添加完整说明 Status字段添加 0/1 含义说明
- 从无
📈 修复前后对比
修复前 ❌
问题 1: 枚举值使用英文
UserType int `json:"user_type" description:"用户类型 (1:SuperAdmin, 2:Platform, 3:Agent, 4:Enterprise)"`
问题 2: 缺少枚举值说明
Status int `json:"status" description:"状态"`
问题 3: 使用行内注释而非 description 标签
EnterpriseName string `json:"enterprise_name"` // 企业名称
问题 4: 完全没有 description 标签
type ShopResponse struct {
ID uint `json:"id"`
ShopName string `json:"shop_name"`
Status int `json:"status"`
}
修复后 ✅
所有枚举值使用完整中文说明
UserType int `json:"user_type" description:"用户类型 (1:超级管理员, 2:平台用户, 3:代理账号, 4:企业账号)"`
状态字段明确说明 0/1 含义
Status int `json:"status" description:"状态 (0:禁用, 1:启用)"`
统一使用 description 标签
EnterpriseName string `json:"enterprise_name" description:"企业名称"`
所有字段都有完整说明
type ShopResponse struct {
ID uint `json:"id" description:"店铺ID"`
ShopName string `json:"shop_name" description:"店铺名称"`
Status int `json:"status" description:"状态 (0:禁用, 1:启用)"`
}
📊 统计数据
生成的 OpenAPI 文档
- 文件路径:
docs/admin-openapi.yaml - Description 字段数量: 375 个
- 覆盖的 DTO 文件: 10 个
- 修复的字段: 100+ 个
枚举字段标准化
| 枚举类型 | 标准 Description | 使用次数 |
|---|---|---|
| 用户类型 | 用户类型 (1:超级管理员, 2:平台用户, 3:代理账号, 4:企业账号) |
6 处 |
| 角色类型 | 角色类型 (1:平台角色, 2:客户角色) |
3 处 |
| 权限类型 | 权限类型 (1:菜单, 2:按钮) |
3 处 |
| 适用端口 | 适用端口 (all:全部, web:Web后台, h5:H5端) |
5 处 |
| 状态 | 状态 (0:禁用, 1:启用) |
15+ 处 |
🎯 达成的效果
1. 前端开发友好
- ✅ 所有 API 字段都有清晰的中文说明
- ✅ 枚举字段明确列出所有可能值
- ✅ 导入 Swagger UI/Apifox 后可直接使用
2. 文档自动生成
- ✅ OpenAPI 文档完全自动生成,无需手动编写
- ✅ 字段说明与代码同步,避免文档过期
3. 代码可维护性
- ✅ 统一的规范,新人容易上手
- ✅ Code Review 有明确的检查标准
📋 后续维护
新增 DTO 时必须遵循
- ✅ 所有字段添加
description标签 - ✅ 枚举字段列出所有可能值(中文)
- ✅ validate 标签与 OpenAPI 标签保持一致
- ✅ 使用
query和path标签标记参数类型
Code Review 检查清单
详见:docs/code-review-checklist.md
验证方法
# 生成文档
go run cmd/gendocs/main.go
# 检查特定字段的说明
grep -A 3 "user_type:" docs/admin-openapi.yaml
grep -A 3 "status:" docs/admin-openapi.yaml
# 统计 description 数量
grep -c "description:" docs/admin-openapi.yaml
🔗 相关文档
👥 贡献者
- 开发团队
最后更新: 2026-01-20