sys_role.go 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * @desc:角色处理
  3. * @company:云南奇讯科技有限公司
  4. * @Author: yixiaohu
  5. * @Date: 2022/3/9 10:31
  6. */
  7. package service
  8. import (
  9. "context"
  10. "github.com/gogf/gf/v2/frame/g"
  11. "github.com/gogf/gf/v2/util/gconv"
  12. "github.com/tiger1103/gfast/v3/api/v1/system"
  13. commonService "github.com/tiger1103/gfast/v3/internal/app/common/service"
  14. "github.com/tiger1103/gfast/v3/internal/app/system/consts"
  15. "github.com/tiger1103/gfast/v3/internal/app/system/model/entity"
  16. "github.com/tiger1103/gfast/v3/internal/app/system/service/internal/dao"
  17. "github.com/tiger1103/gfast/v3/library/liberr"
  18. )
  19. type IRole interface {
  20. GetRoleList(ctx context.Context) (list []*entity.SysRole, err error)
  21. GetRoleListSearch(ctx context.Context, req *system.RoleListReq) (res *system.RoleListRes, err error)
  22. }
  23. type roleImpl struct {
  24. }
  25. var role = roleImpl{}
  26. func Role() IRole {
  27. return IRole(&role)
  28. }
  29. func (s *roleImpl) GetRoleListSearch(ctx context.Context, req *system.RoleListReq) (res *system.RoleListRes, err error) {
  30. res = new(system.RoleListRes)
  31. g.Try(func() {
  32. model := dao.SysRole.Ctx(ctx)
  33. if req.RoleName != "" {
  34. model = model.Where("name like ?", "%"+req.RoleName+"%")
  35. }
  36. if req.Status != "" {
  37. model = model.Where("status", gconv.Int(req.Status))
  38. }
  39. res.Total, err = model.Count()
  40. liberr.ErrIsNil(ctx, err, "获取角色数据失败")
  41. if req.PageNum == 0 {
  42. req.PageNum = 1
  43. }
  44. res.CurrentPage = req.PageNum
  45. if req.PageSize == 0 {
  46. req.PageSize = consts.PageSize
  47. }
  48. err = model.Page(res.CurrentPage, req.PageSize).Order("id asc").Scan(&res.List)
  49. liberr.ErrIsNil(ctx, err, "获取数据失败")
  50. })
  51. return
  52. }
  53. // GetRoleList 获取角色列表
  54. func (s *roleImpl) GetRoleList(ctx context.Context) (list []*entity.SysRole, err error) {
  55. cache := commonService.Cache(ctx)
  56. //从缓存获取
  57. iList := cache.GetOrSetFuncLock(ctx, consts.CacheSysRole, s.getRoleListFromDb, 0, consts.CacheSysAuthTag)
  58. if iList != nil {
  59. err = gconv.Struct(iList, &list)
  60. }
  61. return
  62. }
  63. // 从数据库获取所有角色
  64. func (s *roleImpl) getRoleListFromDb(ctx context.Context) (value interface{}, err error) {
  65. err = g.Try(func() {
  66. var v []*entity.SysRole
  67. //从数据库获取
  68. err = dao.SysRole.Ctx(ctx).
  69. Order(dao.SysRole.Columns().ListOrder + " asc," + dao.SysRole.Columns().Id + " asc").
  70. Scan(&v)
  71. liberr.ErrIsNil(ctx, err, "获取角色数据失败")
  72. value = v
  73. })
  74. return
  75. }
  76. // AddRoleRule 添加角色权限
  77. func (s *roleImpl) AddRoleRule(ctx context.Context, iRule interface{}, roleId int64) (err error) {
  78. err = g.Try(func() {
  79. enforcer, e := commonService.CasbinEnforcer(ctx)
  80. liberr.ErrIsNil(ctx, e)
  81. ruleIds := gconv.Strings(iRule)
  82. for _, v := range ruleIds {
  83. _, err = enforcer.AddPolicy(gconv.String(roleId), gconv.String(v), "All")
  84. liberr.ErrIsNil(ctx, err)
  85. }
  86. })
  87. return
  88. }