update auth_service, add updateProfile method into interface

change main package to api_bb
This commit is contained in:
2025-10-11 05:41:15 +05:00
parent 62b0d4763d
commit a5ca98b549
12 changed files with 136 additions and 50 deletions
+65 -4
View File
@@ -9,10 +9,10 @@ import (
"net/http"
"time"
"go-rest-api/internal/models"
"go-rest-api/internal/service"
"go-rest-api/pkg/middleware"
"go-rest-api/pkg/utils"
"api_bb/internal/models"
"api_bb/internal/service"
"api_bb/pkg/middleware"
"api_bb/pkg/utils"
"github.com/go-chi/chi/v5"
)
@@ -252,3 +252,64 @@ func toUserResponse(user *models.User) UserResponse {
UpdatedAt: user.UpdatedAt,
}
}
type UpdateProfileRequest struct {
FirstName string `json:"firstName"`
LastName string `json:"lastName"`
Phone string `json:"phone"`
Experience string `json:"experience"`
Goals string `json:"goals"`
Newsletter bool `json:"newsletter"`
}
func (h *AuthHandler) UpdateProfile(w http.ResponseWriter, r *http.Request) {
// Устанавливаем CORS заголовки
w.Header().Set("Access-Control-Allow-Origin", r.Header.Get("Origin"))
w.Header().Set("Access-Control-Allow-Credentials", "true")
// Получаем пользователя из контекста
currentUser, ok := middleware.GetUserFromContext(r.Context())
if !ok {
utils.RespondWithError(w, http.StatusUnauthorized, "Authentication required")
return
}
var req UpdateProfileRequest
if err := json.NewDecoder(r.Body).Decode(&req); err != nil {
utils.RespondWithError(w, http.StatusBadRequest, "Invalid request payload: "+err.Error())
return
}
// Валидация обязательных полей
if req.FirstName == "" {
utils.RespondWithError(w, http.StatusBadRequest, "First name is required")
return
}
if req.LastName == "" {
utils.RespondWithError(w, http.StatusBadRequest, "Last name is required")
return
}
// Обновляем данные пользователя
updatedUser := &models.User{
ID: currentUser.ID,
FirstName: req.FirstName,
LastName: req.LastName,
Phone: req.Phone,
Experience: req.Experience,
Goals: req.Goals,
Newsletter: req.Newsletter,
UpdatedAt: time.Now(),
}
// Сохраняем обновленные данные
if err := h.authService.UpdateProfile(updatedUser); err != nil {
utils.RespondWithError(w, http.StatusInternalServerError, "Failed to update profile: "+err.Error())
return
}
utils.RespondWithJSON(w, http.StatusOK, map[string]interface{}{
"message": "Profile updated successfully",
"user": toUserResponse(updatedUser),
})
}
@@ -2,9 +2,9 @@
package handlers
import (
"go-rest-api/internal/repository"
"go-rest-api/internal/service"
"go-rest-api/internal/config"
"api_bb/internal/repository"
"api_bb/internal/service"
"api_bb/internal/config"
"gorm.io/gorm"
)
@@ -3,7 +3,7 @@ package handlers
import (
"net/http"
"go-rest-api/pkg/utils"
"api_bb/pkg/utils"
"github.com/go-chi/chi/v5"
)
@@ -1,7 +1,7 @@
package repository
import (
"go-rest-api/internal/models"
"api_bb/internal/models"
"gorm.io/gorm"
)
+5 -5
View File
@@ -7,11 +7,11 @@ import (
"github.com/go-chi/chi/v5"
"gorm.io/gorm"
"go-rest-api/internal/config"
"go-rest-api/internal/handlers"
"go-rest-api/internal/repository"
"go-rest-api/internal/service"
"go-rest-api/pkg/middleware"
"api_bb/internal/config"
"api_bb/internal/handlers"
"api_bb/internal/repository"
"api_bb/internal/service"
"api_bb/pkg/middleware"
)
func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
@@ -3,15 +3,18 @@ package service
import (
"errors"
"fmt"
"time"
"go-rest-api/internal/models"
"go-rest-api/internal/repository"
"api_bb/internal/models"
"api_bb/internal/repository"
)
type AuthService interface {
Register(user *models.User) error
Login(email, password string) (*models.User, string, error)
GetUserProfile(userID uint) (*models.User, error)
UpdateProfile(user *models.User) error
}
type authService struct {
@@ -48,8 +51,7 @@ func (s *authService) UpdateProfile(user *models.User) error {
// Сохраняем обновленные данные через репозиторий
if err := s.userRepo.Update(updateData); err != nil {
fmt.Errorf("failed to update user: %v", err)
return
return err
}
// Копируем обновленные данные обратно в переданный объект