From b07e7f61b31b27c182c3e55ad16caf5af5be1bbd Mon Sep 17 00:00:00 2001 From: Julien Danjou Date: Wed, 15 Jun 2011 11:44:38 +0200 Subject: [PATCH] auth: add SendUnauthorized Change-Id: I6bf97fee5097af56dfa4b1d1cd1157f5e15d08e5 Signed-off-by: Julien Danjou --- lib/go/camli/auth/auth.go | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/lib/go/camli/auth/auth.go b/lib/go/camli/auth/auth.go index 295fd8492..fef5395a8 100644 --- a/lib/go/camli/auth/auth.go +++ b/lib/go/camli/auth/auth.go @@ -35,6 +35,16 @@ func TriedAuthorization(req *http.Request) bool { return req.Header.Get("Authorization") != "" } +func SendUnauthorized(conn http.ResponseWriter) { + realm := "camlistored" + if pw := os.Getenv("CAMLI_ADVERTISED_PASSWORD"); pw != "" { + realm = "Any username, password is: " + pw + } + conn.Header().Set("WWW-Authenticate", fmt.Sprintf("Basic realm=%q", realm)) + conn.WriteHeader(http.StatusUnauthorized) + fmt.Fprintf(conn, "

Unauthorized

") +} + func IsAuthorized(req *http.Request) bool { auth := req.Header.Get("Authorization") if auth == "" { @@ -64,17 +74,11 @@ func IsAuthorized(req *http.Request) bool { // HTTP Basic Auth. func RequireAuth(handler func(conn http.ResponseWriter, req *http.Request)) func (conn http.ResponseWriter, req *http.Request) { return func (conn http.ResponseWriter, req *http.Request) { - if !IsAuthorized(req) { - realm := "camlistored" - if pw := os.Getenv("CAMLI_ADVERTISED_PASSWORD"); pw != "" { - realm = "Any username, password is: " + pw - } - conn.Header().Set("WWW-Authenticate", fmt.Sprintf("Basic realm=%q", realm)) - conn.WriteHeader(http.StatusUnauthorized) - fmt.Fprintf(conn, "Authentication required.\n") - return + if IsAuthorized(req) { + handler(conn, req) + } else { + SendUnauthorized(conn) } - handler(conn, req) } }