fixed no-auth problem (now works as intended)

This commit is contained in:
Bora M. Alper 2018-12-30 19:40:11 +03:00
parent b375658fca
commit f8a780068c
No known key found for this signature in database
GPG Key ID: 8F1A9504E1BD114D

View File

@ -43,8 +43,10 @@ var database persistence.Database
var opts struct { var opts struct {
Addr string Addr string
Database string Database string
// Credentials is nil when no-auth cmd-line flag is supplied.
Credentials map[string][]byte // TODO: encapsulate credentials and mutex for safety Credentials map[string][]byte // TODO: encapsulate credentials and mutex for safety
CredentialsRWMutex sync.RWMutex CredentialsRWMutex sync.RWMutex
// CredentialsPath is nil when no-auth is supplied.
CredentialsPath string CredentialsPath string
Verbosity int Verbosity int
} }
@ -230,7 +232,10 @@ func parseFlags() error {
opts.Database = cmdFlags.Database opts.Database = cmdFlags.Database
} }
if cmdFlags.Cred == "" && !cmdFlags.NoAuth { if !cmdFlags.NoAuth {
// Set opts.CredentialsPath to either the default value (computed by appdirs pkg) or to the one
// supplied by the user.
if cmdFlags.Cred == "" {
opts.CredentialsPath = path.Join( opts.CredentialsPath = path.Join(
appdirs.UserConfigDir("magneticow", "", "", false), appdirs.UserConfigDir("magneticow", "", "", false),
"credentials", "credentials",
@ -239,13 +244,10 @@ func parseFlags() error {
opts.CredentialsPath = cmdFlags.Cred opts.CredentialsPath = cmdFlags.Cred
} }
if opts.CredentialsPath != "" {
opts.Credentials = make(map[string][]byte) opts.Credentials = make(map[string][]byte)
if err := loadCred(opts.CredentialsPath); err != nil { if err := loadCred(opts.CredentialsPath); err != nil {
return err return err
} }
} else {
opts.Credentials = nil
} }
opts.Verbosity = len(cmdFlags.Verbose) opts.Verbosity = len(cmdFlags.Verbose)
@ -309,6 +311,11 @@ func loadCred(cred string) error {
// Source: https://stackoverflow.com/a/39591234/4466589 // Source: https://stackoverflow.com/a/39591234/4466589
func BasicAuth(handler http.HandlerFunc, realm string) http.HandlerFunc { func BasicAuth(handler http.HandlerFunc, realm string) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) { return func(w http.ResponseWriter, r *http.Request) {
if opts.Credentials == nil { // --no-auth is supplied by the user.
handler(w, r)
return
}
username, password, ok := r.BasicAuth() username, password, ok := r.BasicAuth()
if !ok { // No credentials provided if !ok { // No credentials provided
authenticate(w, realm) authenticate(w, realm)