| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- package system
- import (
- "errors"
- "strconv"
- "gorm.io/gorm"
- gormadapter "github.com/casbin/gorm-adapter/v3"
- "github.com/flipped-aurora/gin-vue-admin/server/global"
- "github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
- "github.com/flipped-aurora/gin-vue-admin/server/utils"
- _ "github.com/go-sql-driver/mysql"
- )
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: UpdateCasbin
- //@description: 更新casbin权限
- //@param: authorityId string, casbinInfos []request.CasbinInfo
- //@return: error
- type CasbinService struct{}
- var CasbinServiceApp = new(CasbinService)
- func (casbinService *CasbinService) UpdateCasbin(adminAuthorityID, AuthorityID uint, casbinInfos []request.CasbinInfo) error {
- err := AuthorityServiceApp.CheckAuthorityIDAuth(adminAuthorityID, AuthorityID)
- if err != nil {
- return err
- }
- if global.GVA_CONFIG.System.UseStrictAuth {
- apis, e := ApiServiceApp.GetAllApis(adminAuthorityID)
- if e != nil {
- return e
- }
- for i := range casbinInfos {
- hasApi := false
- for j := range apis {
- if apis[j].Path == casbinInfos[i].Path && apis[j].Method == casbinInfos[i].Method {
- hasApi = true
- break
- }
- }
- if !hasApi {
- return errors.New("存在api不在权限列表中")
- }
- }
- }
- authorityId := strconv.Itoa(int(AuthorityID))
- casbinService.ClearCasbin(0, authorityId)
- rules := [][]string{}
- //做权限去重处理
- deduplicateMap := make(map[string]bool)
- for _, v := range casbinInfos {
- key := authorityId + v.Path + v.Method
- if _, ok := deduplicateMap[key]; !ok {
- deduplicateMap[key] = true
- rules = append(rules, []string{authorityId, v.Path, v.Method})
- }
- }
- if len(rules) == 0 {
- return nil
- } // 设置空权限无需调用 AddPolicies 方法
- e := utils.GetCasbin()
- success, _ := e.AddPolicies(rules)
- if !success {
- return errors.New("存在相同api,添加失败,请联系管理员")
- }
- return nil
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: UpdateCasbinApi
- //@description: API更新随动
- //@param: oldPath string, newPath string, oldMethod string, newMethod string
- //@return: error
- func (casbinService *CasbinService) UpdateCasbinApi(oldPath string, newPath string, oldMethod string, newMethod string) error {
- err := global.GVA_DB.Model(&gormadapter.CasbinRule{}).Where("v1 = ? AND v2 = ?", oldPath, oldMethod).Updates(map[string]interface{}{
- "v1": newPath,
- "v2": newMethod,
- }).Error
- if err != nil {
- return err
- }
- e := utils.GetCasbin()
- return e.LoadPolicy()
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: GetPolicyPathByAuthorityId
- //@description: 获取权限列表
- //@param: authorityId string
- //@return: pathMaps []request.CasbinInfo
- func (casbinService *CasbinService) GetPolicyPathByAuthorityId(AuthorityID uint) (pathMaps []request.CasbinInfo) {
- e := utils.GetCasbin()
- authorityId := strconv.Itoa(int(AuthorityID))
- list, _ := e.GetFilteredPolicy(0, authorityId)
- for _, v := range list {
- pathMaps = append(pathMaps, request.CasbinInfo{
- Path: v[1],
- Method: v[2],
- })
- }
- return pathMaps
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: ClearCasbin
- //@description: 清除匹配的权限
- //@param: v int, p ...string
- //@return: bool
- func (casbinService *CasbinService) ClearCasbin(v int, p ...string) bool {
- e := utils.GetCasbin()
- success, _ := e.RemoveFilteredPolicy(v, p...)
- return success
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: RemoveFilteredPolicy
- //@description: 使用数据库方法清理筛选的politicy 此方法需要调用FreshCasbin方法才可以在系统中即刻生效
- //@param: db *gorm.DB, authorityId string
- //@return: error
- func (casbinService *CasbinService) RemoveFilteredPolicy(db *gorm.DB, authorityId string) error {
- return db.Delete(&gormadapter.CasbinRule{}, "v0 = ?", authorityId).Error
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: SyncPolicy
- //@description: 同步目前数据库的policy 此方法需要调用FreshCasbin方法才可以在系统中即刻生效
- //@param: db *gorm.DB, authorityId string, rules [][]string
- //@return: error
- func (casbinService *CasbinService) SyncPolicy(db *gorm.DB, authorityId string, rules [][]string) error {
- err := casbinService.RemoveFilteredPolicy(db, authorityId)
- if err != nil {
- return err
- }
- return casbinService.AddPolicies(db, rules)
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: AddPolicies
- //@description: 添加匹配的权限
- //@param: v int, p ...string
- //@return: bool
- func (casbinService *CasbinService) AddPolicies(db *gorm.DB, rules [][]string) error {
- var casbinRules []gormadapter.CasbinRule
- for i := range rules {
- casbinRules = append(casbinRules, gormadapter.CasbinRule{
- Ptype: "p",
- V0: rules[i][0],
- V1: rules[i][1],
- V2: rules[i][2],
- })
- }
- return db.Create(&casbinRules).Error
- }
- func (casbinService *CasbinService) FreshCasbin() (err error) {
- e := utils.GetCasbin()
- err = e.LoadPolicy()
- return err
- }
|