All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 4m22s
- 移动 17 个 DTO 文件到 internal/model/dto/ 目录 - 更新所有 DTO 文件的 package 声明从 model 改为 dto - 更新所有引用文件的 import 和类型引用 - Handler 层:admin 和 h5 所有处理器 - Service 层:所有业务服务 - Routes 层:所有路由定义 - Tests 层:单元测试和集成测试 - 清理未使用的 import 语句 - 验证:项目构建成功,测试编译通过,LSP 无错误
91 lines
2.5 KiB
Go
91 lines
2.5 KiB
Go
package routes
|
|
|
|
import (
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"github.com/break/junhong_cmp_fiber/internal/handler/admin"
|
|
"github.com/break/junhong_cmp_fiber/internal/model"
|
|
"github.com/break/junhong_cmp_fiber/internal/model/dto"
|
|
"github.com/break/junhong_cmp_fiber/pkg/openapi"
|
|
)
|
|
|
|
// registerRoleRoutes 注册角色相关路由
|
|
func registerRoleRoutes(api fiber.Router, h *admin.RoleHandler, doc *openapi.Generator, basePath string) {
|
|
roles := api.Group("/roles")
|
|
groupPath := basePath + "/roles"
|
|
|
|
// 角色 CRUD
|
|
Register(roles, doc, groupPath, "POST", "", h.Create, RouteSpec{
|
|
Summary: "创建角色",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.CreateRoleRequest),
|
|
Output: new(dto.RoleResponse),
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "GET", "", h.List, RouteSpec{
|
|
Summary: "角色列表",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.RoleListRequest),
|
|
Output: new(dto.RolePageResult),
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "GET", "/:id", h.Get, RouteSpec{
|
|
Summary: "获取角色详情",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.IDReq),
|
|
Output: new(dto.RoleResponse),
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "PUT", "/:id", h.Update, RouteSpec{
|
|
Summary: "更新角色",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.UpdateRoleParams),
|
|
Output: new(dto.RoleResponse),
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "PUT", "/:id/status", h.UpdateStatus, RouteSpec{
|
|
Summary: "更新角色状态",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.UpdateRoleStatusParams),
|
|
Output: nil,
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "DELETE", "/:id", h.Delete, RouteSpec{
|
|
Summary: "删除角色",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.IDReq),
|
|
Output: nil,
|
|
Auth: true,
|
|
})
|
|
|
|
// 角色-权限关联
|
|
Register(roles, doc, groupPath, "POST", "/:id/permissions", h.AssignPermissions, RouteSpec{
|
|
Summary: "分配权限",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.AssignPermissionsParams),
|
|
Output: nil,
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "GET", "/:id/permissions", h.GetPermissions, RouteSpec{
|
|
Summary: "获取角色权限",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.IDReq),
|
|
Output: new([]model.Permission),
|
|
Auth: true,
|
|
})
|
|
|
|
Register(roles, doc, groupPath, "DELETE", "/:role_id/permissions/:perm_id", h.RemovePermission, RouteSpec{
|
|
Summary: "移除权限",
|
|
Tags: []string{"角色"},
|
|
Input: new(dto.RemovePermissionParams),
|
|
Output: nil,
|
|
Auth: true,
|
|
})
|
|
}
|