sys_role.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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/database/gdb"
  11. "github.com/gogf/gf/v2/frame/g"
  12. "github.com/gogf/gf/v2/util/gconv"
  13. "github.com/tiger1103/gfast/v3/api/v1/system"
  14. commonService "github.com/tiger1103/gfast/v3/internal/app/common/service"
  15. "github.com/tiger1103/gfast/v3/internal/app/system/consts"
  16. "github.com/tiger1103/gfast/v3/internal/app/system/model/entity"
  17. "github.com/tiger1103/gfast/v3/internal/app/system/service/internal/dao"
  18. "github.com/tiger1103/gfast/v3/internal/app/system/service/internal/do"
  19. "github.com/tiger1103/gfast/v3/library/liberr"
  20. )
  21. type IRole interface {
  22. GetRoleList(ctx context.Context) (list []*entity.SysRole, err error)
  23. GetRoleListSearch(ctx context.Context, req *system.RoleListReq) (res *system.RoleListRes, err error)
  24. AddRole(ctx context.Context, req *system.RoleAddReq) (err error)
  25. Get(ctx context.Context, id uint) (res *entity.SysRole, err error)
  26. GetFilteredNamedPolicy(ctx context.Context, id uint) (gpSlice []int, err error)
  27. EditRole(ctx context.Context, req *system.RoleEditReq) error
  28. }
  29. type roleImpl struct {
  30. }
  31. var role = roleImpl{}
  32. func Role() IRole {
  33. return IRole(&role)
  34. }
  35. func (s *roleImpl) GetRoleListSearch(ctx context.Context, req *system.RoleListReq) (res *system.RoleListRes, err error) {
  36. res = new(system.RoleListRes)
  37. g.Try(func() {
  38. model := dao.SysRole.Ctx(ctx)
  39. if req.RoleName != "" {
  40. model = model.Where("name like ?", "%"+req.RoleName+"%")
  41. }
  42. if req.Status != "" {
  43. model = model.Where("status", gconv.Int(req.Status))
  44. }
  45. res.Total, err = model.Count()
  46. liberr.ErrIsNil(ctx, err, "获取角色数据失败")
  47. if req.PageNum == 0 {
  48. req.PageNum = 1
  49. }
  50. res.CurrentPage = req.PageNum
  51. if req.PageSize == 0 {
  52. req.PageSize = consts.PageSize
  53. }
  54. err = model.Page(res.CurrentPage, req.PageSize).Order("id asc").Scan(&res.List)
  55. liberr.ErrIsNil(ctx, err, "获取数据失败")
  56. })
  57. return
  58. }
  59. // GetRoleList 获取角色列表
  60. func (s *roleImpl) GetRoleList(ctx context.Context) (list []*entity.SysRole, err error) {
  61. cache := commonService.Cache()
  62. //从缓存获取
  63. iList := cache.GetOrSetFuncLock(ctx, consts.CacheSysRole, s.getRoleListFromDb, 0, consts.CacheSysAuthTag)
  64. if iList != nil {
  65. err = gconv.Struct(iList, &list)
  66. }
  67. return
  68. }
  69. // 从数据库获取所有角色
  70. func (s *roleImpl) getRoleListFromDb(ctx context.Context) (value interface{}, err error) {
  71. err = g.Try(func() {
  72. var v []*entity.SysRole
  73. //从数据库获取
  74. err = dao.SysRole.Ctx(ctx).
  75. Order(dao.SysRole.Columns().ListOrder + " asc," + dao.SysRole.Columns().Id + " asc").
  76. Scan(&v)
  77. liberr.ErrIsNil(ctx, err, "获取角色数据失败")
  78. value = v
  79. })
  80. return
  81. }
  82. // AddRoleRule 添加角色权限
  83. func (s *roleImpl) AddRoleRule(ctx context.Context, ruleIds []uint, roleId int64) (err error) {
  84. err = g.Try(func() {
  85. enforcer, e := commonService.CasbinEnforcer(ctx)
  86. liberr.ErrIsNil(ctx, e)
  87. ruleIdsStr := gconv.Strings(ruleIds)
  88. for _, v := range ruleIdsStr {
  89. _, err = enforcer.AddPolicy(gconv.String(roleId), v, "All")
  90. liberr.ErrIsNil(ctx, err)
  91. }
  92. })
  93. return
  94. }
  95. // DelRoleRule 删除角色权限
  96. func (s *roleImpl) DelRoleRule(ctx context.Context, roleId int64) (err error) {
  97. err = g.Try(func() {
  98. enforcer, e := commonService.CasbinEnforcer(ctx)
  99. liberr.ErrIsNil(ctx, e)
  100. _, err = enforcer.RemoveFilteredPolicy(0, gconv.String(roleId))
  101. liberr.ErrIsNil(ctx, e)
  102. })
  103. return
  104. }
  105. func (s *roleImpl) AddRole(ctx context.Context, req *system.RoleAddReq) (err error) {
  106. err = g.DB().Transaction(ctx, func(ctx context.Context, tx *gdb.TX) error {
  107. err = g.Try(func() {
  108. roleId, e := dao.SysRole.Ctx(ctx).TX(tx).InsertAndGetId(req)
  109. liberr.ErrIsNil(ctx, e, "添加角色失败")
  110. //添加角色权限
  111. e = s.AddRoleRule(ctx, req.MenuIds, roleId)
  112. liberr.ErrIsNil(ctx, e)
  113. //清除TAG缓存
  114. commonService.Cache().RemoveByTag(ctx, consts.CacheSysAuthTag)
  115. })
  116. return err
  117. })
  118. return
  119. }
  120. func (s *roleImpl) Get(ctx context.Context, id uint) (res *entity.SysRole, err error) {
  121. err = g.Try(func() {
  122. err = dao.SysRole.Ctx(ctx).WherePri(id).Scan(&res)
  123. liberr.ErrIsNil(ctx, err, "获取角色信息失败")
  124. })
  125. return
  126. }
  127. // GetFilteredNamedPolicy 获取角色关联的菜单规则
  128. func (s *roleImpl) GetFilteredNamedPolicy(ctx context.Context, id uint) (gpSlice []int, err error) {
  129. err = g.Try(func() {
  130. enforcer, e := commonService.CasbinEnforcer(ctx)
  131. liberr.ErrIsNil(ctx, e)
  132. gp := enforcer.GetFilteredNamedPolicy("p", 0, gconv.String(id))
  133. gpSlice = make([]int, len(gp))
  134. for k, v := range gp {
  135. gpSlice[k] = gconv.Int(v[1])
  136. }
  137. })
  138. return
  139. }
  140. // EditRole 修改角色
  141. func (s *roleImpl) EditRole(ctx context.Context, req *system.RoleEditReq) (err error) {
  142. err = g.DB().Transaction(ctx, func(ctx context.Context, tx *gdb.TX) error {
  143. err = g.Try(func() {
  144. _, e := dao.SysRole.Ctx(ctx).TX(tx).WherePri(req.Id).Data(&do.SysRole{
  145. Status: req.Status,
  146. ListOrder: req.ListOrder,
  147. Name: req.Name,
  148. Remark: req.Remark,
  149. }).Update()
  150. liberr.ErrIsNil(ctx, e, "修改角色失败")
  151. //删除角色权限
  152. e = s.DelRoleRule(ctx, req.Id)
  153. liberr.ErrIsNil(ctx, e)
  154. //添加角色权限
  155. e = s.AddRoleRule(ctx, req.MenuIds, req.Id)
  156. liberr.ErrIsNil(ctx, e)
  157. //清除TAG缓存
  158. commonService.Cache().RemoveByTag(ctx, consts.CacheSysAuthTag)
  159. })
  160. return err
  161. })
  162. return
  163. }