1234567891011121314151617181920212223242526272829303132333435363738 |
- package middleware
- import (
- "strconv"
- "strings"
- "github.com/gin-gonic/gin"
- "lcfns/global"
- "lcfns/model/common/response"
- "lcfns/service"
- "lcfns/utils"
- )
- var casbinService = service.ServiceGroupApp.SystemServiceGroup.CasbinService
- // CasbinHandler 拦截器
- func CasbinHandler() gin.HandlerFunc {
- return func(c *gin.Context) {
- if global.Config.System.Env != "develop" {
- waitUse, _ := utils.GetClaims(c)
- //获取请求的PATH
- path := c.Request.URL.Path
- obj := strings.TrimPrefix(path, global.Config.System.RouterPrefix)
- // 获取请求方法
- act := c.Request.Method
- // 获取用户的角色
- sub := strconv.Itoa(int(waitUse.AuthorityId))
- e := casbinService.Casbin() // 判断策略中是否存在
- success, _ := e.Enforce(sub, obj, act)
- if !success {
- response.FailWithDetailed(gin.H{}, "权限不足", c)
- c.Abort()
- return
- }
- }
- c.Next()
- }
- }
|