104 lines
2.8 KiB
Go
104 lines
2.8 KiB
Go
package server
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
func (s *Server) GetAuthenticatedUserHandlerV2(ctx *gin.Context) {
|
|
user := s.deps.UserService.GetAuthenicatedUser(ctx)
|
|
if user == nil {
|
|
ctx.JSON(http.StatusUnauthorized, gin.H{
|
|
"status": http.StatusUnauthorized,
|
|
"message": "[UNAUTHORIZED] Could not fetch authenticated user.",
|
|
})
|
|
return
|
|
}
|
|
|
|
ctx.JSON(http.StatusOK, gin.H{
|
|
"status": http.StatusOK,
|
|
"message": "[OK] Successfully retrieved authenticated user.",
|
|
"user": user,
|
|
})
|
|
}
|
|
|
|
func (s *Server) GetAuthenicatedUserRecipesV2(ctx *gin.Context) {
|
|
user := s.deps.UserService.GetAuthenicatedUser(ctx)
|
|
if user == nil {
|
|
ctx.JSON(http.StatusUnauthorized, gin.H{
|
|
"status": http.StatusUnauthorized,
|
|
"message": "[UNAUTHORIZED] Could not fetch authenticated user.",
|
|
})
|
|
return
|
|
}
|
|
|
|
recipes, err := s.deps.RecipeService.GetUserRecipes(user.Id)
|
|
if err != nil {
|
|
ctx.JSON(http.StatusBadRequest, gin.H{
|
|
"status": http.StatusBadRequest,
|
|
"message": fmt.Sprintf("[FAILED] Could not fetch authenticated users's recipes. %s", err.Error()),
|
|
})
|
|
return
|
|
}
|
|
|
|
ctx.JSON(http.StatusOK, gin.H{
|
|
"status": http.StatusOK,
|
|
"message": "[OK] Successfully retrieved authenticated user's recipes.",
|
|
"recipes": recipes,
|
|
})
|
|
}
|
|
|
|
func (s *Server) GetAuthenicatedUserFavoritesV2(ctx *gin.Context) {
|
|
user := s.deps.UserService.GetAuthenicatedUser(ctx)
|
|
if user == nil {
|
|
ctx.JSON(http.StatusUnauthorized, gin.H{
|
|
"status": http.StatusUnauthorized,
|
|
"message": "[UNAUTHORIZED] Could not fetch authenticated user.",
|
|
})
|
|
return
|
|
}
|
|
|
|
favorites, err := s.deps.RecipeService.GetUserFavoriteRecipes(user.Id)
|
|
if err != nil {
|
|
ctx.JSON(http.StatusBadRequest, gin.H{
|
|
"status": http.StatusBadRequest,
|
|
"message": fmt.Sprintf("[FAILED] Could not fetch authenticated users's favorites. %s", err.Error()),
|
|
})
|
|
return
|
|
}
|
|
|
|
ctx.JSON(http.StatusOK, gin.H{
|
|
"status": http.StatusOK,
|
|
"message": "[OK] Successfully retrieved authenticated user's favorites.",
|
|
"favorites": favorites,
|
|
})
|
|
}
|
|
|
|
func (s *Server) GetAuthenicatedUserEngagementV2(ctx *gin.Context) {
|
|
user := s.deps.UserService.GetAuthenicatedUser(ctx)
|
|
if user == nil {
|
|
ctx.JSON(http.StatusUnauthorized, gin.H{
|
|
"status": http.StatusUnauthorized,
|
|
"message": "[UNAUTHORIZED] Could not fetch authenticated user.",
|
|
})
|
|
return
|
|
}
|
|
|
|
engagement, err := s.deps.EngagementService.GetUserEngagement(user.Id, 6)
|
|
if err != nil {
|
|
ctx.JSON(http.StatusBadRequest, gin.H{
|
|
"status": http.StatusBadRequest,
|
|
"message": fmt.Sprintf("[FAILED] Failed to get authenticated user engagement. %s", err.Error()),
|
|
})
|
|
return
|
|
}
|
|
|
|
ctx.JSON(http.StatusOK, gin.H{
|
|
"status": http.StatusOK,
|
|
"message": "[OK] Successfully retrieved authenticated user engagement.",
|
|
"engagement": engagement,
|
|
})
|
|
}
|