#1 add basic authorization

This commit is contained in:
Tim
2024-07-26 09:28:25 +02:00
parent d80ceb42da
commit ffd8b413a9
9 changed files with 1367 additions and 529 deletions

28
api/middleware/auth.go Normal file
View File

@@ -0,0 +1,28 @@
package middleware
import (
"api/utils"
"context"
"net/http"
)
type ContextKey string
const TOKEN_KEY ContextKey = "token"
func EnsureAuth(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
tokenStr := r.Header.Get("Authorization")
tokenStr = tokenStr[len("Bearer "):]
token, err := utils.VerifyToken(tokenStr)
if err != nil {
http.Error(w, "Unauthorized", http.StatusUnauthorized)
return
}
var newContext = context.WithValue(r.Context(), TOKEN_KEY, token)
next.ServeHTTP(w, r.WithContext(newContext))
})
}