sys_role.go 5.7 KB

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