package controller import ( "jaecoo-be/app/module/galleries/request" "jaecoo-be/app/module/galleries/service" "jaecoo-be/utils/paginator" "strconv" "github.com/gofiber/fiber/v2" utilRes "jaecoo-be/utils/response" utilVal "jaecoo-be/utils/validator" ) type galleriesController struct { galleriesService service.GalleriesService } type GalleriesController 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 Approve(c *fiber.Ctx) error Comment(c *fiber.Ctx) error Reject(c *fiber.Ctx) error } func NewGalleriesController(galleriesService service.GalleriesService) GalleriesController { return &galleriesController{ galleriesService: galleriesService, } } // All Galleries // @Summary Get all Galleries // @Description API for getting all Galleries // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param req query request.GalleriesQueryRequestContext 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 /galleries [get] func (_i *galleriesController) All(c *fiber.Ctx) error { paginate, err := paginator.Paginate(c) if err != nil { return err } reqContext := request.GalleriesQueryRequestContext{ Title: c.Query("title"), } req := reqContext.ToParamRequest() req.Pagination = paginate galleriesData, paging, err := _i.galleriesService.GetAll(req) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Galleries list successfully retrieved"}, Data: galleriesData, Meta: paging, }) } // Show Gallery // @Summary Get Gallery by ID // @Description API for getting Gallery by ID // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param id path int true "Gallery ID" // @Success 200 {object} response.Response // @Failure 400 {object} response.BadRequestError // @Failure 401 {object} response.UnauthorizedError // @Failure 500 {object} response.InternalServerError // @Router /galleries/{id} [get] func (_i *galleriesController) Show(c *fiber.Ctx) error { id, err := strconv.ParseUint(c.Params("id"), 10, 0) if err != nil { return err } galleryData, err := _i.galleriesService.GetOne(uint(id)) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully retrieved"}, Data: galleryData, }) } // Save Gallery // @Summary Create Gallery // @Description API for creating Gallery // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param payload body request.GalleriesCreateRequest true "Required payload" // @Success 200 {object} response.Response // @Failure 400 {object} response.BadRequestError // @Failure 401 {object} response.UnauthorizedError // @Failure 500 {object} response.InternalServerError // @Router /galleries [post] func (_i *galleriesController) Save(c *fiber.Ctx) error { req := new(request.GalleriesCreateRequest) if err := utilVal.ParseAndValidate(c, req); err != nil { return err } dataResult, err := _i.galleriesService.Create(*req) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully created"}, Data: dataResult, }) } // Update Gallery // @Summary Update Gallery // @Description API for updating Gallery // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param id path int true "Gallery ID" // @Param payload body request.GalleriesUpdateRequest true "Required payload" // @Success 200 {object} response.Response // @Failure 400 {object} response.BadRequestError // @Failure 401 {object} response.UnauthorizedError // @Failure 500 {object} response.InternalServerError // @Router /galleries/{id} [put] func (_i *galleriesController) Update(c *fiber.Ctx) error { id, err := strconv.ParseUint(c.Params("id"), 10, 0) if err != nil { return err } req := new(request.GalleriesUpdateRequest) if err := utilVal.ParseAndValidate(c, req); err != nil { return err } dataResult, err := _i.galleriesService.Update(uint(id), *req) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully updated"}, Data: dataResult, }) } // Delete Gallery // @Summary Delete Gallery // @Description API for deleting Gallery (soft delete) // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param id path int true "Gallery ID" // @Success 200 {object} response.Response // @Failure 400 {object} response.BadRequestError // @Failure 401 {object} response.UnauthorizedError // @Failure 500 {object} response.InternalServerError // @Router /galleries/{id} [delete] func (_i *galleriesController) Delete(c *fiber.Ctx) error { id, err := strconv.ParseUint(c.Params("id"), 10, 0) if err != nil { return err } err = _i.galleriesService.Delete(uint(id)) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully deleted"}, }) } // Approve Gallery // @Summary Approve Gallery // @Description API for approving Gallery (only for admin with roleId = 1) // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param id path int true "Gallery ID" // @Success 200 {object} response.Response // @Failure 400 {object} response.BadRequestError // @Failure 401 {object} response.UnauthorizedError // @Failure 500 {object} response.InternalServerError // @Router /galleries/{id}/approve [put] func (_i *galleriesController) 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 == "" { return utilRes.Resp(c, utilRes.Response{ Success: false, Messages: utilRes.Messages{"Unauthorized: token not found"}, }) } galleryData, err := _i.galleriesService.Approve(uint(id), authToken) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully approved"}, Data: galleryData, }) } // Reject Gallery // @Summary Reject Gallery // @Description API for rejecting Gallery (only for admin with roleId = 1) // @Tags Galleries // @Security Bearer // @Param X-Client-Key header string true "Insert the X-Client-Key" // @Param id path int true "Gallery 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 /galleries/{id}/reject [put] func (_i *galleriesController) 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 { body.Message = nil } galleryData, err := _i.galleriesService.Reject(uint(id), authToken, body.Message) if err != nil { return err } return utilRes.Resp(c, utilRes.Response{ Success: true, Messages: utilRes.Messages{"Gallery successfully rejected"}, Data: galleryData, }) } // 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 /galleries/{id}/comment [put] func (_i *galleriesController) 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.galleriesService.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, }) }