qudoco-be/app/module/cms_content_submissions/controller/cms_content_submissions.con...

115 lines
3.3 KiB
Go

package controller
import (
"web-qudo-be/app/middleware"
"web-qudo-be/app/module/cms_content_submissions/request"
"web-qudo-be/app/module/cms_content_submissions/service"
"web-qudo-be/utils/paginator"
"github.com/gofiber/fiber/v2"
"github.com/google/uuid"
utilRes "web-qudo-be/utils/response"
utilVal "web-qudo-be/utils/validator"
)
type CmsContentSubmissionsController interface {
Submit(c *fiber.Ctx) error
List(c *fiber.Ctx) error
Approve(c *fiber.Ctx) error
Reject(c *fiber.Ctx) error
}
type cmsContentSubmissionsController struct {
svc service.CmsContentSubmissionsService
}
func NewCmsContentSubmissionsController(svc service.CmsContentSubmissionsService) CmsContentSubmissionsController {
return &cmsContentSubmissionsController{svc: svc}
}
func (_i *cmsContentSubmissionsController) Submit(c *fiber.Ctx) error {
user := middleware.GetUser(c)
clientID := middleware.GetClientID(c)
if user == nil || clientID == nil {
return fiber.NewError(fiber.StatusUnauthorized, "Unauthorized")
}
req := new(request.SubmitCmsContentSubmissionRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
row, err := _i.svc.Submit(clientID, user, req)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"CMS submission saved"},
Data: row,
})
}
func (_i *cmsContentSubmissionsController) List(c *fiber.Ctx) error {
user := middleware.GetUser(c)
clientID := middleware.GetClientID(c)
if user == nil || clientID == nil {
return fiber.NewError(fiber.StatusUnauthorized, "Unauthorized")
}
p, err := paginator.Paginate(c)
if err != nil {
return err
}
status := c.Query("status")
mineOnly := c.Query("mine") == "1" || c.Query("mine") == "true"
rows, paging, err := _i.svc.List(clientID, user, status, mineOnly, p)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"CMS submissions loaded"},
Data: rows,
Meta: paging,
})
}
func (_i *cmsContentSubmissionsController) Approve(c *fiber.Ctx) error {
user := middleware.GetUser(c)
clientID := middleware.GetClientID(c)
if user == nil || clientID == nil {
return fiber.NewError(fiber.StatusUnauthorized, "Unauthorized")
}
id, err := uuid.Parse(c.Params("id"))
if err != nil {
return err
}
if err := _i.svc.Approve(clientID, user, id); err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"CMS submission approved and applied"},
})
}
func (_i *cmsContentSubmissionsController) Reject(c *fiber.Ctx) error {
user := middleware.GetUser(c)
clientID := middleware.GetClientID(c)
if user == nil || clientID == nil {
return fiber.NewError(fiber.StatusUnauthorized, "Unauthorized")
}
id, err := uuid.Parse(c.Params("id"))
if err != nil {
return err
}
req := new(request.RejectCmsContentSubmissionRequest)
_ = c.BodyParser(req)
if err := _i.svc.Reject(clientID, user, id, req.Note); err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"CMS submission rejected"},
})
}