caddy/middleware/basicauth/basicauth.go

66 lines
1.7 KiB
Go
Raw Normal View History

2015-04-27 18:56:57 +02:00
// Package basicauth implements HTTP Basic Authentication.
2015-04-23 22:57:07 +02:00
package basicauth
import (
"net/http"
"github.com/mholt/caddy/middleware"
)
// BasicAuth is middleware to protect resources with a username and password.
// Note that HTTP Basic Authentication is not secure by itself and should
// not be used to protect important assets without HTTPS. Even then, the
// security of HTTP Basic Auth is disputed. Use discretion when deciding
// what to protect with BasicAuth.
type BasicAuth struct {
Next middleware.Handler
Rules []Rule
2015-04-23 22:57:07 +02:00
}
// ServeHTTP implements the middleware.Handler interface.
func (a BasicAuth) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
2015-05-10 08:20:58 +02:00
var hasAuth bool
var isAuthenticated bool
2015-04-23 22:57:07 +02:00
for _, rule := range a.Rules {
for _, res := range rule.Resources {
if !middleware.Path(r.URL.Path).Matches(res) {
continue
}
// Path matches; parse auth header
username, password, ok := r.BasicAuth()
2015-05-10 08:20:58 +02:00
hasAuth = true
2015-04-23 22:57:07 +02:00
// Check credentials
if !ok || username != rule.Username || password != rule.Password {
2015-05-10 08:20:58 +02:00
continue
2015-04-23 22:57:07 +02:00
}
2015-05-10 08:20:58 +02:00
// flag set only on success authentication
isAuthenticated = true
}
}
2015-05-25 04:52:34 +02:00
2015-05-10 08:20:58 +02:00
if hasAuth {
if !isAuthenticated {
w.Header().Set("WWW-Authenticate", "Basic")
return http.StatusUnauthorized, nil
2015-04-23 22:57:07 +02:00
}
2015-05-25 04:52:34 +02:00
// "It's an older code, sir, but it checks out. I was about to clear them."
return a.Next.ServeHTTP(w, r)
2015-04-23 22:57:07 +02:00
}
// Pass-thru when no paths match
return a.Next.ServeHTTP(w, r)
}
// Rule represents a BasicAuth rule. A username and password
// combination protect the associated resources, which are
// file or directory paths.
type Rule struct {
Username string
Password string
Resources []string
}