Files
tp/serv_nginx/api_bb/internal/service/auth_service.go
T
valitovgaziz 7eaddd9f37 modified: serv_nginx/api_bb/internal/handlers/auth.go
modified:   serv_nginx/api_bb/internal/service/auth_service.go
add update user path to put:profile
2025-10-11 05:11:21 +05:00

100 lines
2.9 KiB
Go

// service/auth_service.go
package service
import (
"errors"
"go-rest-api/internal/models"
"go-rest-api/internal/repository"
)
type AuthService interface {
Register(user *models.User) error
Login(email, password string) (*models.User, string, error)
GetUserProfile(userID uint) (*models.User, error)
}
type authService struct {
userRepo repository.UserRepository
jwtService JWTService
}
func NewAuthService(userRepo repository.UserRepository, jwtService JWTService) AuthService {
return &authService{
userRepo: userRepo,
jwtService: jwtService,
}
}
func (s *authService) UpdateProfile(user *models.User) error {
// Находим существующего пользователя через репозиторий
existingUser, err := s.userRepo.FindByID(user.ID)
if err != nil {
return fmt.Errorf("user not found")
}
// Создаем карту для обновления только разрешенных полей
updateData := &models.User{
ID: existingUser.ID, // Важно сохранить ID
FirstName: user.FirstName,
LastName: user.LastName,
Phone: user.Phone,
Experience: user.Experience,
Goals: user.Goals,
Newsletter: user.Newsletter,
UpdatedAt: time.Now(),
// Не обновляем: Email, Password, Role, CreatedAt
}
// Сохраняем обновленные данные через репозиторий
if err := s.userRepo.Update(updateData); err != nil {
fmt.Errorf("failed to update user: %v", err)
return
}
// Копируем обновленные данные обратно в переданный объект
user.Email = existingUser.Email
user.Password = existingUser.Password
user.Role = existingUser.Role
user.CreatedAt = existingUser.CreatedAt
user.UpdatedAt = updateData.UpdatedAt
return nil
}
func (s *authService) Register(user *models.User) error {
// Проверяем, существует ли пользователь
existingUser, err := s.userRepo.FindByEmail(user.Email)
if err == nil && existingUser != nil {
return errors.New("user with this email already exists")
}
// Хешируем пароль
if err := user.HashPassword(); err != nil {
return err
}
return s.userRepo.Create(user)
}
func (s *authService) Login(email, password string) (*models.User, string, error) {
user, err := s.userRepo.FindByEmail(email)
if err != nil {
return nil, "", errors.New("invalid email or password")
}
if !user.CheckPassword(password) {
return nil, "", errors.New("invalid email or password")
}
token, err := s.jwtService.GenerateToken(user.ID, user.Email)
if err != nil {
return nil, "", err
}
return user, token, nil
}
func (s *authService) GetUserProfile(userID uint) (*models.User, error) {
return s.userRepo.FindByID(userID)
}