mirror of
https://github.com/lejianwen/rustdesk-api.git
synced 2025-11-29 16:43:17 +00:00
55 lines
1.0 KiB
Go
55 lines
1.0 KiB
Go
package middleware
|
||
|
||
import (
|
||
"Gwen/service"
|
||
"github.com/gin-gonic/gin"
|
||
)
|
||
|
||
func RustAuth() gin.HandlerFunc {
|
||
return func(c *gin.Context) {
|
||
//fmt.Println(c.Request.URL, c.Request.Header)
|
||
//获取HTTP_AUTHORIZATION
|
||
token := c.GetHeader("Authorization")
|
||
if token == "" {
|
||
c.JSON(401, gin.H{
|
||
"error": "Unauthorized",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
if len(token) <= 7 {
|
||
c.JSON(401, gin.H{
|
||
"error": "Unauthorized",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
//提取token,格式是Bearer {token}
|
||
//这里只是简单的提取
|
||
token = token[7:]
|
||
//验证token
|
||
user, ut := service.AllService.UserService.InfoByAccessToken(token)
|
||
if user.Id == 0 {
|
||
c.JSON(401, gin.H{
|
||
"error": "Unauthorized",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
if !service.AllService.UserService.CheckUserEnable(user) {
|
||
c.JSON(401, gin.H{
|
||
"error": "账号已被禁用",
|
||
})
|
||
c.Abort()
|
||
return
|
||
}
|
||
|
||
c.Set("curUser", user)
|
||
c.Set("token", token)
|
||
|
||
service.AllService.UserService.AutoRefreshAccessToken(ut)
|
||
|
||
c.Next()
|
||
}
|
||
}
|