mirror of https://github.com/perkeep/perkeep.git
auth: fix advertised password to actually advertise.
Change-Id: I3c5dc19acabb2ddcca4877000bad69f3f9074ef2
This commit is contained in:
parent
7619e6c174
commit
db84536371
|
@ -28,8 +28,7 @@ import (
|
||||||
var kBasicAuthPattern *regexp.Regexp = regexp.MustCompile(`^Basic ([a-zA-Z0-9\+/=]+)`)
|
var kBasicAuthPattern *regexp.Regexp = regexp.MustCompile(`^Basic ([a-zA-Z0-9\+/=]+)`)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
Type string // how to do auth. currently supported: "userpass"
|
mode AuthMode // the auth logic corresponding to Type
|
||||||
mode AuthMode // the auth logic corresponding to Type
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type AuthMode interface {
|
type AuthMode interface {
|
||||||
|
@ -45,22 +44,21 @@ func FromConfig(authConfig string) (AuthMode, os.Error) {
|
||||||
if len(pieces) < 1 {
|
if len(pieces) < 1 {
|
||||||
return nil, fmt.Errorf("Invalid auth string: %q", authConfig)
|
return nil, fmt.Errorf("Invalid auth string: %q", authConfig)
|
||||||
}
|
}
|
||||||
Type = pieces[0]
|
authType := pieces[0]
|
||||||
switch Type {
|
|
||||||
|
if pw := os.Getenv("CAMLI_ADVERTISED_PASSWORD"); pw != "" {
|
||||||
|
mode = &DevAuth{pw}
|
||||||
|
return mode, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
switch authType {
|
||||||
case "userpass":
|
case "userpass":
|
||||||
if len(pieces) != 3 {
|
if len(pieces) != 3 {
|
||||||
return nil, fmt.Errorf("Wrong userpass auth string; needs to be \"userpass:user:password\"")
|
return nil, fmt.Errorf("Wrong userpass auth string; needs to be \"userpass:user:password\"")
|
||||||
}
|
}
|
||||||
mode = &UserPass{pieces[1], pieces[2]}
|
mode = &UserPass{pieces[1], pieces[2]}
|
||||||
case "":
|
|
||||||
password := os.Getenv("CAMLI_ADVERTISED_PASSWORD")
|
|
||||||
if password != "" {
|
|
||||||
mode = &DevAuth{password}
|
|
||||||
} else {
|
|
||||||
return nil, fmt.Errorf("No auth string provided and no \"CAMLI_ADVERTISED_PASSWORD\" defined")
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
return nil, fmt.Errorf("Unknown auth type: %q", Type)
|
return nil, fmt.Errorf("Unknown auth type: %q", authType)
|
||||||
}
|
}
|
||||||
return mode, nil
|
return mode, nil
|
||||||
}
|
}
|
||||||
|
@ -130,8 +128,8 @@ func TriedAuthorization(req *http.Request) bool {
|
||||||
|
|
||||||
func SendUnauthorized(conn http.ResponseWriter) {
|
func SendUnauthorized(conn http.ResponseWriter) {
|
||||||
realm := "camlistored"
|
realm := "camlistored"
|
||||||
if Type == "dev" {
|
if devAuth, ok := mode.(*DevAuth); ok {
|
||||||
realm = "Any username, password is: " + mode.(*DevAuth).Password
|
realm = "Any username, password is: " + devAuth.Password
|
||||||
}
|
}
|
||||||
conn.Header().Set("WWW-Authenticate", fmt.Sprintf("Basic realm=%q", realm))
|
conn.Header().Set("WWW-Authenticate", fmt.Sprintf("Basic realm=%q", realm))
|
||||||
conn.WriteHeader(http.StatusUnauthorized)
|
conn.WriteHeader(http.StatusUnauthorized)
|
||||||
|
|
Loading…
Reference in New Issue