2025-02-24 16:48:20 +08:00
|
|
|
package authsvc
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"errors"
|
|
|
|
|
|
2025-02-27 07:25:25 +08:00
|
|
|
authdomain "legalgo-BE-go/internal/domain/auth"
|
2025-03-05 21:21:44 +08:00
|
|
|
userdomain "legalgo-BE-go/internal/domain/user"
|
2025-02-27 07:25:25 +08:00
|
|
|
"legalgo-BE-go/internal/utilities/utils"
|
2025-02-28 12:18:47 +08:00
|
|
|
|
|
|
|
|
"github.com/google/uuid"
|
2025-02-24 16:48:20 +08:00
|
|
|
)
|
|
|
|
|
|
2025-03-05 21:21:44 +08:00
|
|
|
func (a *impl) LoginAsUser(spec userdomain.UserLogin) (string, error) {
|
2025-02-24 19:47:40 +08:00
|
|
|
user, err := a.userRepo.GetUserByEmail(spec.Email)
|
2025-02-24 16:48:20 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return "", errors.New(err.Error())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
matchPassword := ComparePassword(user.Password, spec.Password)
|
|
|
|
|
if !matchPassword {
|
|
|
|
|
return "", errors.New("wrong password")
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-28 12:18:47 +08:00
|
|
|
authToken := authdomain.AuthToken{
|
|
|
|
|
Email: user.Email,
|
|
|
|
|
SessionID: uuid.NewString(),
|
2025-03-05 21:21:44 +08:00
|
|
|
Role: "user",
|
2025-02-28 12:18:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
token, err := utils.GenerateToken(authToken)
|
2025-02-24 16:48:20 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return "", errors.New(err.Error())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return token, nil
|
|
|
|
|
}
|