38 lines
747 B
Go
38 lines
747 B
Go
package jwt
|
|
|
|
import (
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/go-pripro/shop/pkg/e"
|
|
"github.com/go-pripro/shop/pkg/util"
|
|
"net/http"
|
|
"time"
|
|
)
|
|
|
|
func JWT() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
var code int
|
|
var data interface{}
|
|
code = e.SUCCESS
|
|
token := c.Request.Header.Get("Authorization")
|
|
if token == "" {
|
|
code = e.InvalidParams
|
|
} else {
|
|
claims, err := util.ParseToken(token)
|
|
if err != nil {
|
|
code = e.ErrorAuthCheckTokenFail
|
|
} else if time.Now().Unix() > claims.ExpiresAt {
|
|
code = e.ErrorAuthCheckTokenTimeout
|
|
}
|
|
}
|
|
if code != e.SUCCESS {
|
|
c.JSON(http.StatusUnauthorized, gin.H{
|
|
"code" : code,
|
|
"msg" : e.GetMsg(code),
|
|
"data" : data,
|
|
})
|
|
c.Abort()
|
|
return
|
|
}
|
|
c.Next()
|
|
}
|
|
} |