Files
junhong_cmp_fiber/internal/routes/role.go
huang 46e4e5f4f1
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 4m22s
refactor: 将 DTO 文件从 internal/model 移动到 internal/model/dto 目录
- 移动 17 个 DTO 文件到 internal/model/dto/ 目录
- 更新所有 DTO 文件的 package 声明从 model 改为 dto
- 更新所有引用文件的 import 和类型引用
  - Handler 层:admin 和 h5 所有处理器
  - Service 层:所有业务服务
  - Routes 层:所有路由定义
  - Tests 层:单元测试和集成测试
- 清理未使用的 import 语句
- 验证:项目构建成功,测试编译通过,LSP 无错误
2026-01-22 10:15:04 +08:00

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,
})
}