woj-server/internal/service/user/login.go

44 lines
907 B
Go
Raw Normal View History

2022-09-17 11:22:55 +08:00
package user
import (
"errors"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/e"
"git.0x7f.app/WOJ/woj-server/internal/model"
"go.uber.org/zap"
2022-09-17 11:22:55 +08:00
"golang.org/x/crypto/bcrypt"
"gorm.io/gorm"
)
type LoginData struct {
2024-01-05 14:31:09 +08:00
Email string
Password string
}
func (s *service) Login(data *LoginData) (*model.User, e.Status) {
2024-01-05 14:31:09 +08:00
user := &model.User{Email: data.Email}
2022-09-17 11:22:55 +08:00
2023-07-15 16:19:49 +08:00
err := s.db.Get().Where(user).First(&user).Error
2022-09-17 11:22:55 +08:00
if errors.Is(err, gorm.ErrRecordNotFound) {
return nil, e.UserNotFound
2022-09-17 11:22:55 +08:00
}
if err != nil {
s.log.Warn("DatabaseError", zap.Error(err), zap.Any("user", user))
return nil, e.DatabaseError
}
if !user.IsEnabled {
return nil, e.UserDisabled
2022-09-17 11:22:55 +08:00
}
2024-01-03 00:55:41 +08:00
if len(user.Password) == 0 {
// created by oauth
return nil, e.UserWithoutPassword
}
2022-09-17 11:22:55 +08:00
err = bcrypt.CompareHashAndPassword(user.Password, []byte(data.Password))
2022-09-17 11:22:55 +08:00
if err != nil {
return nil, e.UserWrongPassword
2022-09-17 11:22:55 +08:00
}
return user, e.Success
}