roleDetailLogic.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package role
  2. import (
  3. "context"
  4. "perms-system-server/internal/middleware"
  5. "perms-system-server/internal/response"
  6. "perms-system-server/internal/svc"
  7. "perms-system-server/internal/types"
  8. "github.com/zeromicro/go-zero/core/logx"
  9. )
  10. type RoleDetailLogic struct {
  11. logx.Logger
  12. ctx context.Context
  13. svcCtx *svc.ServiceContext
  14. }
  15. func NewRoleDetailLogic(ctx context.Context, svcCtx *svc.ServiceContext) *RoleDetailLogic {
  16. return &RoleDetailLogic{
  17. Logger: logx.WithContext(ctx),
  18. ctx: ctx,
  19. svcCtx: svcCtx,
  20. }
  21. }
  22. // RoleDetail 角色详情。根据角色 ID 查询角色完整信息及其已绑定的权限 ID 列表。
  23. func (l *RoleDetailLogic) RoleDetail(req *types.RoleDetailReq) (resp *types.RoleItem, err error) {
  24. role, err := l.svcCtx.SysRoleModel.FindOne(l.ctx, req.Id)
  25. if err != nil {
  26. return nil, response.ErrNotFound("角色不存在")
  27. }
  28. caller := middleware.GetUserDetails(l.ctx)
  29. if caller == nil {
  30. return nil, response.ErrUnauthorized("未登录")
  31. }
  32. if !caller.IsSuperAdmin && caller.ProductCode != role.ProductCode {
  33. return nil, response.ErrForbidden("无权访问该产品的数据")
  34. }
  35. permIds, err := l.svcCtx.SysRolePermModel.FindPermIdsByRoleId(l.ctx, role.Id)
  36. if err != nil {
  37. return nil, err
  38. }
  39. return &types.RoleItem{
  40. Id: role.Id,
  41. ProductCode: role.ProductCode,
  42. Name: role.Name,
  43. Remark: role.Remark,
  44. Status: role.Status,
  45. PermsLevel: role.PermsLevel,
  46. PermIds: permIds,
  47. CreateTime: role.CreateTime,
  48. }, nil
  49. }