mirror of
https://github.com/idanoo/autobrr
synced 2025-07-23 00:39:13 +00:00

* feat(api): add auth * feat(web): add auth and refactor * refactor(web): baseurl * feat: add autobrrctl cli for user creation * build: move static assets * refactor(web): auth guard and routing * refactor: rename var * fix: remove subrouter * build: update default config
51 lines
997 B
Go
51 lines
997 B
Go
package auth
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/autobrr/autobrr/internal/domain"
|
|
"github.com/autobrr/autobrr/internal/user"
|
|
"github.com/autobrr/autobrr/pkg/argon2id"
|
|
)
|
|
|
|
type Service interface {
|
|
Login(username, password string) (*domain.User, error)
|
|
}
|
|
|
|
type service struct {
|
|
userSvc user.Service
|
|
}
|
|
|
|
func NewService(userSvc user.Service) Service {
|
|
return &service{
|
|
userSvc: userSvc,
|
|
}
|
|
}
|
|
|
|
func (s *service) Login(username, password string) (*domain.User, error) {
|
|
if username == "" || password == "" {
|
|
return nil, errors.New("bad credentials")
|
|
}
|
|
|
|
// find user
|
|
u, err := s.userSvc.FindByUsername(username)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if u == nil {
|
|
return nil, errors.New("bad credentials")
|
|
}
|
|
|
|
// compare password from request and the saved password
|
|
match, err := argon2id.ComparePasswordAndHash(password, u.Password)
|
|
if err != nil {
|
|
return nil, errors.New("error checking credentials")
|
|
}
|
|
|
|
if !match {
|
|
return nil, errors.New("bad credentials")
|
|
}
|
|
|
|
return u, nil
|
|
}
|