Some checks failed
Backend Tests / Static Checks (push) Has been cancelled
Backend Tests / Tests (other) (push) Has been cancelled
Backend Tests / Tests (plugin) (push) Has been cancelled
Backend Tests / Tests (server) (push) Has been cancelled
Backend Tests / Tests (store) (push) Has been cancelled
Build Canary Image / build-frontend (push) Has been cancelled
Build Canary Image / build-push (linux/amd64) (push) Has been cancelled
Build Canary Image / build-push (linux/arm64) (push) Has been cancelled
Build Canary Image / merge (push) Has been cancelled
Frontend Tests / Lint (push) Has been cancelled
Frontend Tests / Build (push) Has been cancelled
Proto Linter / Lint Protos (push) Has been cancelled
34 lines
820 B
Go
34 lines
820 B
Go
package auth
|
|
|
|
import (
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
// ExtractBearerToken extracts the JWT token from an Authorization header value.
|
|
// Expected format: "Bearer {token}"
|
|
// Returns empty string if no valid bearer token is found.
|
|
func ExtractBearerToken(authHeader string) string {
|
|
if authHeader == "" {
|
|
return ""
|
|
}
|
|
parts := strings.Fields(authHeader)
|
|
if len(parts) != 2 || !strings.EqualFold(parts[0], "bearer") {
|
|
return ""
|
|
}
|
|
return parts[1]
|
|
}
|
|
|
|
// ExtractRefreshTokenFromCookie extracts the refresh token from cookie header.
|
|
func ExtractRefreshTokenFromCookie(cookieHeader string) string {
|
|
if cookieHeader == "" {
|
|
return ""
|
|
}
|
|
req := &http.Request{Header: http.Header{"Cookie": []string{cookieHeader}}}
|
|
cookie, err := req.Cookie(RefreshTokenCookieName)
|
|
if err != nil {
|
|
return ""
|
|
}
|
|
return cookie.Value
|
|
}
|