sys_casbin.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. package system
  2. import (
  3. "errors"
  4. "github.com/casbin/casbin/v2"
  5. "github.com/casbin/casbin/v2/model"
  6. gormadapter "github.com/casbin/gorm-adapter/v3"
  7. _ "github.com/go-sql-driver/mysql"
  8. "go.uber.org/zap"
  9. "log-server/global"
  10. "log-server/model/system/request"
  11. "strconv"
  12. "sync"
  13. )
  14. //@author: [piexlmax](https://github.com/piexlmax)
  15. //@function: UpdateCasbin
  16. //@description: 更新casbin权限
  17. //@param: authorityId string, casbinInfos []request.CasbinInfo
  18. //@return: error
  19. type CasbinService struct{}
  20. var CasbinServiceApp = new(CasbinService)
  21. func (casbinService *CasbinService) UpdateCasbin(AuthorityID uint, casbinInfos []request.CasbinInfo) error {
  22. authorityId := strconv.Itoa(int(AuthorityID))
  23. casbinService.ClearCasbin(0, authorityId)
  24. rules := [][]string{}
  25. for _, v := range casbinInfos {
  26. rules = append(rules, []string{authorityId, v.Path, v.Method})
  27. }
  28. e := casbinService.Casbin()
  29. success, _ := e.AddPolicies(rules)
  30. if !success {
  31. return errors.New("存在相同api,添加失败,请联系管理员")
  32. }
  33. return nil
  34. }
  35. //@author: [piexlmax](https://github.com/piexlmax)
  36. //@function: UpdateCasbinApi
  37. //@description: API更新随动
  38. //@param: oldPath string, newPath string, oldMethod string, newMethod string
  39. //@return: error
  40. func (casbinService *CasbinService) UpdateCasbinApi(oldPath string, newPath string, oldMethod string, newMethod string) error {
  41. err := global.GVA_DB.Model(&gormadapter.CasbinRule{}).Where("v1 = ? AND v2 = ?", oldPath, oldMethod).Updates(map[string]interface{}{
  42. "v1": newPath,
  43. "v2": newMethod,
  44. }).Error
  45. return err
  46. }
  47. //@author: [piexlmax](https://github.com/piexlmax)
  48. //@function: GetPolicyPathByAuthorityId
  49. //@description: 获取权限列表
  50. //@param: authorityId string
  51. //@return: pathMaps []request.CasbinInfo
  52. func (casbinService *CasbinService) GetPolicyPathByAuthorityId(AuthorityID uint) (pathMaps []request.CasbinInfo) {
  53. e := casbinService.Casbin()
  54. authorityId := strconv.Itoa(int(AuthorityID))
  55. list := e.GetFilteredPolicy(0, authorityId)
  56. for _, v := range list {
  57. pathMaps = append(pathMaps, request.CasbinInfo{
  58. Path: v[1],
  59. Method: v[2],
  60. })
  61. }
  62. return pathMaps
  63. }
  64. //@author: [piexlmax](https://github.com/piexlmax)
  65. //@function: ClearCasbin
  66. //@description: 清除匹配的权限
  67. //@param: v int, p ...string
  68. //@return: bool
  69. func (casbinService *CasbinService) ClearCasbin(v int, p ...string) bool {
  70. e := casbinService.Casbin()
  71. success, _ := e.RemoveFilteredPolicy(v, p...)
  72. return success
  73. }
  74. //@author: [piexlmax](https://github.com/piexlmax)
  75. //@function: Casbin
  76. //@description: 持久化到数据库 引入自定义规则
  77. //@return: *casbin.Enforcer
  78. var (
  79. syncedEnforcer *casbin.SyncedEnforcer
  80. once sync.Once
  81. )
  82. func (casbinService *CasbinService) Casbin() *casbin.SyncedEnforcer {
  83. once.Do(func() {
  84. a, _ := gormadapter.NewAdapterByDB(global.GVA_DB)
  85. text := `
  86. [request_definition]
  87. r = sub, obj, act
  88. [policy_definition]
  89. p = sub, obj, act
  90. [role_definition]
  91. g = _, _
  92. [policy_effect]
  93. e = some(where (p.eft == allow))
  94. [matchers]
  95. m = r.sub == p.sub && keyMatch2(r.obj,p.obj) && r.act == p.act
  96. `
  97. m, err := model.NewModelFromString(text)
  98. if err != nil {
  99. zap.L().Error("字符串加载模型失败!", zap.Error(err))
  100. return
  101. }
  102. syncedEnforcer, _ = casbin.NewSyncedEnforcer(m, a)
  103. })
  104. _ = syncedEnforcer.LoadPolicy()
  105. return syncedEnforcer
  106. }