kleinTodo/common/jwt/verify.go

35 lines
825 B
Go
Raw Normal View History

2025-07-26 23:31:00 +02:00
package jwt
import (
_ "context"
"net/http"
"os"
"strings"
2025-08-23 13:28:48 +02:00
"gitea.kleinsense.nl/DariusKlein/kleinTodo/common"
"github.com/golang-jwt/jwt/v5"
2025-07-26 23:31:00 +02:00
)
func GetVerifiedUser(r *http.Request) (string, error) {
2025-07-27 00:02:41 +02:00
verifyJWT, err := VerifyJWT(strings.TrimPrefix(r.Header.Get(common.AuthHeader), "Bearer "))
2025-07-26 23:31:00 +02:00
if err != nil {
return "", err
}
return verifyJWT, nil
}
// VerifyJWT verify JWT token and returns user object
func VerifyJWT(authToken string) (string, error) {
//get jwt secret from environment
secret := os.Getenv("JWT_SECRET")
//parse jwt token
token, err := jwt.ParseWithClaims(authToken, &jwt.RegisteredClaims{}, func(token *jwt.Token) (interface{}, error) {
return []byte(secret), nil
})
if err != nil {
return "", err
}
subject := token.Claims.(*jwt.RegisteredClaims).Subject
return subject, err
}