35 lines
1.1 KiB
Go
35 lines
1.1 KiB
Go
|
package middleware
|
||
|
|
||
|
import (
|
||
|
"crypto/subtle"
|
||
|
"net/http"
|
||
|
|
||
|
"github.com/gabek/owncast/config"
|
||
|
log "github.com/sirupsen/logrus"
|
||
|
)
|
||
|
|
||
|
// RequireAdminAuth wraps a handler requiring HTTP basic auth for it using the given
|
||
|
// the stream key as the password and and a hardcoded "admin" for username.
|
||
|
func RequireAdminAuth(handler http.HandlerFunc) http.HandlerFunc {
|
||
|
username := "admin"
|
||
|
password := config.Config.VideoSettings.StreamingKey
|
||
|
|
||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||
|
|
||
|
user, pass, ok := r.BasicAuth()
|
||
|
realm := "Owncast Authenticated Request"
|
||
|
|
||
|
// Failed
|
||
|
if !ok || subtle.ConstantTimeCompare([]byte(user), []byte(username)) != 1 || subtle.ConstantTimeCompare([]byte(pass), []byte(password)) != 1 {
|
||
|
w.Header().Set("WWW-Authenticate", `Basic realm="`+realm+`"`)
|
||
|
http.Error(w, "Unauthorized", http.StatusUnauthorized)
|
||
|
log.Warnln("Failed authentication for", r.URL.Path, "from", r.RemoteAddr, r.UserAgent())
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Success
|
||
|
log.Traceln("Authenticated request OK for", r.URL.Path, "from", r.RemoteAddr, r.UserAgent())
|
||
|
handler(w, r)
|
||
|
}
|
||
|
}
|