jwt_helper.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. package jwt
  2. import (
  3. "fmt"
  4. "net/http"
  5. "github.com/IceWhaleTech/CasaOS/model"
  6. loger2 "github.com/IceWhaleTech/CasaOS/pkg/utils/loger"
  7. oasis_err2 "github.com/IceWhaleTech/CasaOS/pkg/utils/oasis_err"
  8. "github.com/gin-gonic/gin"
  9. )
  10. func JWT(swagHandler gin.HandlerFunc) gin.HandlerFunc {
  11. return func(c *gin.Context) {
  12. var code int
  13. code = oasis_err2.SUCCESS
  14. token := c.GetHeader("Authorization")
  15. if len(token) == 0 {
  16. token = c.Query("token")
  17. }
  18. if token == "" {
  19. code = oasis_err2.INVALID_PARAMS
  20. }
  21. if swagHandler == nil {
  22. //claims, err := ParseToken(token)
  23. _, err := ParseToken(token)
  24. if err != nil {
  25. code = oasis_err2.ERROR_AUTH_TOKEN
  26. }
  27. //else if time.Now().Unix() > claims.ExpiresAt {
  28. // code = oasis_err2.ERROR_AUTH_TOKEN
  29. //}
  30. }
  31. if code != oasis_err2.SUCCESS {
  32. c.JSON(http.StatusOK, model.Result{Success: code, Message: oasis_err2.GetMsg(code)})
  33. c.Abort()
  34. return
  35. }
  36. c.Next()
  37. }
  38. }
  39. //获取token
  40. func GetToken(username, pwd string) string {
  41. token, err := GenerateToken(username, pwd)
  42. if err == nil {
  43. return token
  44. } else {
  45. loger2.NewOLoger().Fatal(fmt.Sprintf("Get Token Fail: %V", err))
  46. return ""
  47. }
  48. }