38 lines
751 B
Go
38 lines
751 B
Go
package jwt
|
|
|
|
import (
|
|
"github.com/EDDYCJY/go-gin-example/pkg/e"
|
|
"github.com/EDDYCJY/go-gin-example/pkg/util"
|
|
"github.com/gin-gonic/gin"
|
|
"net/http"
|
|
"time"
|
|
)
|
|
|
|
func JWT() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
var code int
|
|
var data interface{}
|
|
code = e.SUCCESS
|
|
token := c.Query("token")
|
|
if token == "" {
|
|
code = e.INVALID_PARAMS
|
|
} else {
|
|
claims, err := util.ParseToken(token)
|
|
if err != nil {
|
|
code = e.ERROR_AUTH_CHECK_TOKEN_FAIL
|
|
} else if time.Now().Unix() > claims.ExpiresAt {
|
|
code = e.ERROR_AUTH_CHECK_TOKEN_TIMEOUT
|
|
}
|
|
}
|
|
if code != e.SUCCESS {
|
|
c.JSON(http.StatusUnauthorized, gin.H{
|
|
"code" : code,
|
|
"msg" : e.GetMsg(code),
|
|
"data" : data,
|
|
})
|
|
c.Abort()
|
|
return
|
|
}
|
|
c.Next()
|
|
}
|
|
} |