cc-backend/internal/auth/local.go

36 lines
920 B
Go
Raw Normal View History

2022-07-07 14:08:37 +02:00
package auth
2022-07-07 12:11:49 +02:00
import (
"fmt"
"net/http"
"golang.org/x/crypto/bcrypt"
)
type LocalAuthenticator struct {
auth *Authentication
}
var _ Authenticator = (*LocalAuthenticator)(nil)
2022-07-07 14:08:37 +02:00
func (la *LocalAuthenticator) Init(auth *Authentication, _ interface{}) error {
2022-07-07 12:11:49 +02:00
la.auth = auth
return nil
}
func (la *LocalAuthenticator) CanLogin(user *User, rw http.ResponseWriter, r *http.Request) bool {
2022-07-07 13:40:38 +02:00
return user != nil && user.AuthSource == AuthViaLocalPassword
2022-07-07 12:11:49 +02:00
}
2022-07-07 13:40:38 +02:00
func (la *LocalAuthenticator) Login(user *User, rw http.ResponseWriter, r *http.Request) (*User, error) {
if e := bcrypt.CompareHashAndPassword([]byte(user.Password), []byte(r.FormValue("password"))); e != nil {
2022-07-07 12:48:04 +02:00
return nil, fmt.Errorf("user '%s' provided the wrong password (%w)", user.Username, e)
2022-07-07 12:11:49 +02:00
}
2022-07-07 12:48:04 +02:00
return user, nil
2022-07-07 12:11:49 +02:00
}
func (la *LocalAuthenticator) Auth(rw http.ResponseWriter, r *http.Request) (*User, error) {
2022-07-07 13:40:38 +02:00
return la.auth.AuthViaSession(rw, r)
2022-07-07 12:11:49 +02:00
}