jaecoo-be/app/module/banners/controller/banners.controller.go

435 lines
12 KiB
Go
Raw Normal View History

2025-11-15 17:43:23 +00:00
package controller
import (
2026-02-05 12:23:59 +00:00
"jaecoo-be/app/middleware"
2025-11-15 17:43:23 +00:00
"jaecoo-be/app/module/banners/request"
"jaecoo-be/app/module/banners/service"
"jaecoo-be/utils/paginator"
"strconv"
"github.com/gofiber/fiber/v2"
2026-02-05 12:23:59 +00:00
"github.com/rs/zerolog"
2025-11-15 17:43:23 +00:00
utilRes "jaecoo-be/utils/response"
)
type bannersController struct {
bannersService service.BannersService
2026-02-05 12:23:59 +00:00
Log zerolog.Logger
2025-11-15 17:43:23 +00:00
}
2026-01-25 16:50:49 +00:00
2025-11-15 17:43:23 +00:00
type BannersController interface {
All(c *fiber.Ctx) error
Show(c *fiber.Ctx) error
Save(c *fiber.Ctx) error
Update(c *fiber.Ctx) error
Delete(c *fiber.Ctx) error
2026-01-20 01:08:14 +00:00
Approve(c *fiber.Ctx) error
Reject(c *fiber.Ctx) error
2026-01-25 16:50:49 +00:00
Comment(c *fiber.Ctx) error
Viewer(c *fiber.Ctx) error
2025-11-15 17:43:23 +00:00
}
func NewBannersController(bannersService service.BannersService) BannersController {
return &bannersController{
bannersService: bannersService,
}
}
// All Banners
// @Summary Get all Banners
// @Description API for getting all Banners
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param req query request.BannersQueryRequestContext false "query parameters"
// @Param req query paginator.Pagination false "pagination parameters"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners [get]
func (_i *bannersController) All(c *fiber.Ctx) error {
paginate, err := paginator.Paginate(c)
if err != nil {
return err
}
reqContext := request.BannersQueryRequestContext{
Title: c.Query("title"),
Position: c.Query("position"),
Status: c.Query("status"),
}
req := reqContext.ToParamRequest()
req.Pagination = paginate
2026-02-05 12:23:59 +00:00
// ✅ ambil ClientId dari middleware
clientId := middleware.GetClientID(c)
// ✅ ambil Authorization token (kalau dibutuhkan)
_i.Log.Info().Interface("clientId", clientId).Msg("")
bannersData, paging, err := _i.bannersService.GetAll(clientId,req)
2025-11-15 17:43:23 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banners list successfully retrieved"},
Data: bannersData,
Meta: paging,
})
}
2026-02-05 12:23:59 +00:00
2025-11-15 17:43:23 +00:00
// Show Banner
// @Summary Get Banner by ID
// @Description API for getting Banner by ID
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param id path int true "Banner ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/{id} [get]
func (_i *bannersController) Show(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
bannerData, err := _i.bannersService.GetOne(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully retrieved"},
Data: bannerData,
})
}
// Save Banner
// @Summary Create Banner
// @Description API for creating Banner with file upload
2025-11-15 17:43:23 +00:00
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param file formData file false "Upload file"
// @Param title formData string true "Banner title"
// @Param description formData string false "Banner description"
// @Param position formData string false "Banner position"
// @Param status formData string false "Banner status"
2025-11-15 17:43:23 +00:00
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners [post]
func (_i *bannersController) Save(c *fiber.Ctx) error {
// Parse multipart form
form, err := c.MultipartForm()
if err != nil {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Failed to parse form data"},
})
}
// Extract form values
req := request.BannersCreateRequest{
Title: c.FormValue("title"),
}
if description := c.FormValue("description"); description != "" {
req.Description = &description
}
if position := c.FormValue("position"); position != "" {
req.Position = &position
2025-11-15 17:43:23 +00:00
}
if status := c.FormValue("status"); status != "" {
req.Status = &status
}
// Validate required fields
if req.Title == "" {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Title is required"},
})
}
// Check if file is uploaded
if len(form.File["file"]) > 0 {
// File will be handled in service
}
dataResult, err := _i.bannersService.Create(c, req)
2025-11-15 17:43:23 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully created"},
Data: dataResult,
})
}
// Update Banner
// @Summary Update Banner
// @Description API for updating Banner with file upload
2025-11-15 17:43:23 +00:00
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param id path int true "Banner ID"
// @Param file formData file false "Upload file"
// @Param title formData string false "Banner title"
// @Param description formData string false "Banner description"
// @Param position formData string false "Banner position"
// @Param status formData string false "Banner status"
// @Param is_active formData bool false "Banner is_active"
2025-11-15 17:43:23 +00:00
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/{id} [put]
func (_i *bannersController) Update(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
// Parse multipart form
form, err := c.MultipartForm()
if err != nil {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Failed to parse form data"},
})
}
// Extract form values
req := request.BannersUpdateRequest{}
if title := c.FormValue("title"); title != "" {
req.Title = &title
}
if description := c.FormValue("description"); description != "" {
req.Description = &description
}
if position := c.FormValue("position"); position != "" {
req.Position = &position
}
if status := c.FormValue("status"); status != "" {
req.Status = &status
}
if isActiveStr := c.FormValue("is_active"); isActiveStr != "" {
isActive := isActiveStr == "true" || isActiveStr == "1"
req.IsActive = &isActive
}
// Check if file is uploaded
if len(form.File["file"]) > 0 {
// File will be handled in service
2025-11-15 17:43:23 +00:00
}
dataResult, err := _i.bannersService.Update(c, uint(id), req)
2025-11-15 17:43:23 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully updated"},
Data: dataResult,
})
}
// Delete Banner
// @Summary Delete Banner
// @Description API for deleting Banner (soft delete)
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param id path int true "Banner ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/{id} [delete]
func (_i *bannersController) Delete(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
err = _i.bannersService.Delete(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully deleted"},
})
}
2026-01-20 01:08:14 +00:00
// Approve Banner
// @Summary Approve Banner
// @Description API for approving Banner (only for admin with roleId = 1)
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param id path int true "Banner ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/{id}/approve [put]
func (_i *bannersController) Approve(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
// Get token from Authorization header
authToken := c.Get("Authorization")
if authToken == "" {
2026-01-20 01:08:14 +00:00
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Unauthorized: token not found"},
2026-01-20 01:08:14 +00:00
})
}
bannerData, err := _i.bannersService.Approve(uint(id), authToken)
if err != nil {
return err
2026-01-20 01:08:14 +00:00
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully approved"},
Data: bannerData,
})
}
// Reject Banner
// @Summary Reject Banner
// @Description API for rejecting Banner (only for admin with roleId = 1)
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param id path int true "Banner ID"
// @Param message body string false "Rejection message"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/{id}/reject [put]
func (_i *bannersController) Reject(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
// Get token from Authorization header
authToken := c.Get("Authorization")
if authToken == "" {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Unauthorized: token not found"},
})
}
// Get optional message from request body
var body struct {
Message *string `json:"message"`
}
if err := c.BodyParser(&body); err != nil {
// Message is optional, so ignore parsing error
body.Message = nil
}
bannerData, err := _i.bannersService.Reject(uint(id), authToken, body.Message)
2026-01-20 01:08:14 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Banner successfully rejected"},
2026-01-20 01:08:14 +00:00
Data: bannerData,
})
}
2026-01-25 16:50:49 +00:00
// Comment Banner
// @Summary Comment Banner
// @Description API for comment Banner (only admin)
// @Tags Banners
// @Security BearerAuth
// @Param id path int true "Banner ID"
// @Param body body request.CommentRequest true "Comment payload"
// @Success 200 {object} response.Response
// @Router /banners/{id}/comment [put]
func (_i *bannersController) Comment(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
authToken := c.Get("Authorization")
if authToken == "" {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Unauthorized"},
})
}
var req request.CommentRequest
if err := c.BodyParser(&req); err != nil {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Messages: utilRes.Messages{"Invalid request"},
})
}
bannerData, err := _i.bannersService.Comment(uint(id), authToken, &req.Message)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Komentar berhasil disimpan"},
Data: bannerData,
})
}
// Viewer Banner
// @Summary Viewer Banner
// @Description API for viewing Banner file
// @Tags Banners
// @Security Bearer
// @Param X-Client-Key header string true "Insert the X-Client-Key"
// @Param filename path string true "Banner File Name (e.g., user_277788.png)"
// @Success 200 {file} file
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /banners/viewer/{filename} [get]
func (_i *bannersController) Viewer(c *fiber.Ctx) error {
return _i.bannersService.Viewer(c)
}