| 12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- package middleware
- import (
- "github.com/gin-gonic/gin"
- "github.com/lejianwen/rustdesk-api/v2/http/response"
- "github.com/lejianwen/rustdesk-api/v2/service"
- )
- // AdminAuth 后台权限验证中间件
- func AdminAuth() gin.HandlerFunc {
- return func(c *gin.Context) {
- //测试先关闭
- token := c.GetHeader("api-token")
- if token == "" {
- response.Fail(c, 403, "请先登录")
- c.Abort()
- return
- }
- user, ut := service.AllService.UserService.InfoByAccessToken(token)
- if user.Id == 0 {
- response.Fail(c, 403, "请先登录")
- c.Abort()
- return
- }
- if !service.AllService.UserService.CheckUserEnable(user) {
- c.JSON(401, gin.H{
- "error": "Unauthorized",
- })
- c.Abort()
- return
- }
- c.Set("curUser", user)
- c.Set("token", token)
- //如果时间小于1天,token自动续期
- service.AllService.UserService.AutoRefreshAccessToken(ut)
- c.Next()
- }
- }
|