roleDetailLogic.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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. func (l *RoleDetailLogic) RoleDetail(req *types.RoleDetailReq) (resp *types.RoleItem, err error) {
  23. role, err := l.svcCtx.SysRoleModel.FindOne(l.ctx, req.Id)
  24. if err != nil {
  25. return nil, response.ErrNotFound("角色不存在")
  26. }
  27. caller := middleware.GetUserDetails(l.ctx)
  28. if caller == nil {
  29. return nil, response.ErrUnauthorized("未登录")
  30. }
  31. if !caller.IsSuperAdmin && caller.ProductCode != role.ProductCode {
  32. return nil, response.ErrForbidden("无权访问该产品的数据")
  33. }
  34. permIds, err := l.svcCtx.SysRolePermModel.FindPermIdsByRoleId(l.ctx, role.Id)
  35. if err != nil {
  36. return nil, err
  37. }
  38. return &types.RoleItem{
  39. Id: role.Id,
  40. ProductCode: role.ProductCode,
  41. Name: role.Name,
  42. Remark: role.Remark,
  43. Status: role.Status,
  44. PermsLevel: role.PermsLevel,
  45. PermIds: permIds,
  46. CreateTime: role.CreateTime,
  47. }, nil
  48. }