Upload files to "c2s_ipfs_payloads/pkg"
This commit is contained in:
parent
227c8577ca
commit
549841cfac
65
c2s_ipfs_payloads/pkg/auth.go
Normal file
65
c2s_ipfs_payloads/pkg/auth.go
Normal file
|
|
@ -0,0 +1,65 @@
|
|||
// Package auth provides simple HTTP basic authentication middleware for the CID hub.
|
||||
package auth
|
||||
|
||||
import (
|
||||
"crypto/subtle"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
// BasicAuth wraps an HTTP handler with basic auth protection.
|
||||
func BasicAuth(username, password string, next http.HandlerFunc) http.HandlerFunc {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
if username == "" {
|
||||
// No auth configured
|
||||
next(w, r)
|
||||
return
|
||||
}
|
||||
|
||||
user, pass, ok := r.BasicAuth()
|
||||
if !ok {
|
||||
w.Header().Set("WWW-Authenticate", `Basic realm="CID Hub"`)
|
||||
http.Error(w, "Unauthorized", http.StatusUnauthorized)
|
||||
return
|
||||
}
|
||||
|
||||
userMatch := subtle.ConstantTimeCompare([]byte(user), []byte(username)) == 1
|
||||
passMatch := subtle.ConstantTimeCompare([]byte(pass), []byte(password)) == 1
|
||||
|
||||
if !userMatch || !passMatch {
|
||||
http.Error(w, "Forbidden", http.StatusForbidden)
|
||||
return
|
||||
}
|
||||
|
||||
next(w, r)
|
||||
}
|
||||
}
|
||||
|
||||
// JWTAuth wraps an HTTP handler with JWT bearer token auth.
|
||||
// This is a simple token comparison for HMAC-style tokens.
|
||||
func JWTAuth(token string, next http.HandlerFunc) http.HandlerFunc {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
if token == "" {
|
||||
next(w, r)
|
||||
return
|
||||
}
|
||||
|
||||
authHeader := r.Header.Get("Authorization")
|
||||
if authHeader == "" {
|
||||
http.Error(w, "Missing Authorization header", http.StatusUnauthorized)
|
||||
return
|
||||
}
|
||||
|
||||
// Support both "Bearer <token>" and "<token>" directly
|
||||
provided := authHeader
|
||||
if len(authHeader) > 7 && authHeader[:7] == "Bearer " {
|
||||
provided = authHeader[7:]
|
||||
}
|
||||
|
||||
if subtle.ConstantTimeCompare([]byte(provided), []byte(token)) != 1 {
|
||||
http.Error(w, "Forbidden", http.StatusForbidden)
|
||||
return
|
||||
}
|
||||
|
||||
next(w, r)
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user