MIF_E31222379_BE/internal/handler/product_handler.go

227 lines
7.0 KiB
Go

package handler
import (
"fmt"
"log"
"strconv"
"github.com/gofiber/fiber/v2"
"github.com/pahmiudahgede/senggoldong/dto"
"github.com/pahmiudahgede/senggoldong/internal/services"
"github.com/pahmiudahgede/senggoldong/utils"
)
type ProductHandler struct {
ProductService services.ProductService
}
func NewProductHandler(productService services.ProductService) *ProductHandler {
return &ProductHandler{ProductService: productService}
}
func ConvertStringToInt(value string) (int, error) {
convertedValue, err := strconv.Atoi(value)
if err != nil {
return 0, fmt.Errorf("invalid integer format: %s", value)
}
return convertedValue, nil
}
func GetPaginationParams(c *fiber.Ctx) (int, int, error) {
pageStr := c.Query("page", "1")
limitStr := c.Query("limit", "50")
page, err := strconv.Atoi(pageStr)
if err != nil || page <= 0 {
return 0, 0, fmt.Errorf("invalid page value")
}
limit, err := strconv.Atoi(limitStr)
if err != nil || limit <= 0 {
return 0, 0, fmt.Errorf("invalid limit value")
}
return page, limit, nil
}
func (h *ProductHandler) CreateProduct(c *fiber.Ctx) error {
userID, ok := c.Locals("userID").(string)
if !ok {
log.Println("User ID not found in Locals")
return utils.GenericResponse(c, fiber.StatusUnauthorized, "User ID not found")
}
productName := c.FormValue("product_name")
quantityStr := c.FormValue("quantity")
productImages, err := c.MultipartForm()
if err != nil {
log.Printf("Error parsing form data: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Error parsing form data")
}
quantity, err := ConvertStringToInt(quantityStr)
if err != nil {
log.Printf("Invalid quantity: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Invalid quantity")
}
productDTO := dto.RequestProductDTO{
ProductName: productName,
Quantity: quantity,
ProductImages: productImages.File["product_image"],
}
product, err := h.ProductService.CreateProduct(userID, &productDTO)
if err != nil {
log.Printf("Error creating product: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, err.Error())
}
return utils.CreateResponse(c, product, "Product created successfully")
}
func (h *ProductHandler) GetAllProductsByStoreID(c *fiber.Ctx) error {
userID, ok := c.Locals("userID").(string)
if !ok {
log.Println("User ID not found in Locals")
return utils.GenericResponse(c, fiber.StatusUnauthorized, "User ID not found")
}
page, limit, err := GetPaginationParams(c)
if err != nil {
log.Printf("Invalid pagination params: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Invalid pagination parameters")
}
products, total, err := h.ProductService.GetAllProductsByStoreID(userID, page, limit)
if err != nil {
log.Printf("Error fetching products: %v", err)
return utils.GenericResponse(c, fiber.StatusNotFound, err.Error())
}
return utils.PaginatedResponse(c, products, page, limit, int(total), "Products fetched successfully")
}
func (h *ProductHandler) GetProductByID(c *fiber.Ctx) error {
productID := c.Params("product_id")
if productID == "" {
log.Println("Product ID is required")
return utils.GenericResponse(c, fiber.StatusBadRequest, "Product ID is required")
}
product, err := h.ProductService.GetProductByID(productID)
if err != nil {
log.Printf("Error fetching product: %v", err)
return utils.GenericResponse(c, fiber.StatusNotFound, err.Error())
}
return utils.SuccessResponse(c, product, "Product fetched successfully")
}
func (h *ProductHandler) UpdateProduct(c *fiber.Ctx) error {
userID, ok := c.Locals("userID").(string)
if !ok {
log.Println("User ID not found in Locals")
return utils.GenericResponse(c, fiber.StatusUnauthorized, "User ID not found")
}
productID := c.Params("product_id")
if productID == "" {
return utils.GenericResponse(c, fiber.StatusBadRequest, "Product ID is required")
}
var productDTO dto.RequestProductDTO
if err := c.BodyParser(&productDTO); err != nil {
log.Printf("Error parsing body: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Invalid request body")
}
productImages, err := c.MultipartForm()
if err != nil {
log.Printf("Error parsing form data: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Error parsing form data")
}
productDTO.ProductImages = productImages.File["product_images"]
product, err := h.ProductService.UpdateProduct(userID, productID, &productDTO)
if err != nil {
log.Printf("Error updating product: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, err.Error())
}
return utils.CreateResponse(c, product, "Product updated successfully")
}
func (h *ProductHandler) DeleteProduct(c *fiber.Ctx) error {
productID := c.Params("product_id")
if productID == "" {
return utils.GenericResponse(c, fiber.StatusBadRequest, "Product ID is required")
}
err := h.ProductService.DeleteProduct(productID)
if err != nil {
log.Printf("Error deleting product: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, fmt.Sprintf("Failed to delete product: %v", err))
}
return utils.GenericResponse(c, fiber.StatusOK, "Product deleted successfully")
}
func (h *ProductHandler) DeleteProducts(c *fiber.Ctx) error {
var productIDs []string
if err := c.BodyParser(&productIDs); err != nil {
log.Printf("Error parsing product IDs: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Invalid input for product IDs")
}
if len(productIDs) == 0 {
return utils.GenericResponse(c, fiber.StatusBadRequest, "No product IDs provided")
}
err := h.ProductService.DeleteProducts(productIDs)
if err != nil {
log.Printf("Error deleting products: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, fmt.Sprintf("Failed to delete products: %v", err))
}
return utils.GenericResponse(c, fiber.StatusOK, "Products deleted successfully")
}
func (h *ProductHandler) DeleteProductImage(c *fiber.Ctx) error {
imageID := c.Params("image_id")
if imageID == "" {
return utils.GenericResponse(c, fiber.StatusBadRequest, "Image ID is required")
}
err := h.ProductService.DeleteProductImage(imageID)
if err != nil {
log.Printf("Error deleting product image: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, fmt.Sprintf("Failed to delete product image: %v", err))
}
return utils.GenericResponse(c, fiber.StatusOK, "Product image deleted successfully")
}
func (h *ProductHandler) DeleteProductImages(c *fiber.Ctx) error {
var imageIDs []string
if err := c.BodyParser(&imageIDs); err != nil {
log.Printf("Error parsing image IDs: %v", err)
return utils.GenericResponse(c, fiber.StatusBadRequest, "Invalid input for image IDs")
}
if len(imageIDs) == 0 {
return utils.GenericResponse(c, fiber.StatusBadRequest, "No image IDs provided")
}
err := h.ProductService.DeleteProductImages(imageIDs)
if err != nil {
log.Printf("Error deleting product images: %v", err)
return utils.GenericResponse(c, fiber.StatusConflict, fmt.Sprintf("Failed to delete product images: %v", err))
}
return utils.GenericResponse(c, fiber.StatusOK, "Product images deleted successfully")
}