2024-03-05 19:15:53 +00:00
|
|
|
package controller
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
|
"go-humas-be/app/module/articles/request"
|
|
|
|
|
"go-humas-be/app/module/articles/service"
|
|
|
|
|
"go-humas-be/utils/paginator"
|
|
|
|
|
"strconv"
|
|
|
|
|
|
|
|
|
|
utilRes "go-humas-be/utils/response"
|
|
|
|
|
utilVal "go-humas-be/utils/validator"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type articlesController struct {
|
|
|
|
|
articlesService service.ArticlesService
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type ArticlesController 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
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewArticlesController(articlesService service.ArticlesService) ArticlesController {
|
|
|
|
|
return &articlesController{
|
|
|
|
|
articlesService: articlesService,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-31 15:19:45 +00:00
|
|
|
// All Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Get all Articles
|
|
|
|
|
// @Description API for getting all Articles
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Tags Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Param req query request.ArticlesQueryRequest false "query parameters"
|
2024-04-28 18:39:43 +00:00
|
|
|
// @Param req query paginator.Pagination false "pagination parameters"
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Success 200 {object} response.Response
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Router /articles [get]
|
|
|
|
|
func (_i *articlesController) All(c *fiber.Ctx) error {
|
|
|
|
|
paginate, err := paginator.Paginate(c)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
reqContext := request.ArticlesQueryRequestContext{
|
|
|
|
|
Title: c.Query("title"),
|
|
|
|
|
Description: c.Query("description"),
|
|
|
|
|
Tags: c.Query("tags"),
|
|
|
|
|
TypeId: c.Query("typeId"),
|
|
|
|
|
StatusId: c.Query("statusId"),
|
|
|
|
|
IsPublish: c.Query("isPublish"),
|
|
|
|
|
}
|
|
|
|
|
req := reqContext.ToParamRequest()
|
2024-03-05 19:15:53 +00:00
|
|
|
req.Pagination = paginate
|
|
|
|
|
|
|
|
|
|
articlesData, paging, err := _i.articlesService.All(req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
2024-03-31 15:19:45 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"Articles list successfully retrieved"},
|
|
|
|
|
Data: articlesData,
|
|
|
|
|
Meta: paging,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-31 15:19:45 +00:00
|
|
|
// Show Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Get one Articles
|
|
|
|
|
// @Description API for getting one Articles
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Tags Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param id path int true "Articles ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Router /articles/{id} [get]
|
|
|
|
|
func (_i *articlesController) Show(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
articlesData, err := _i.articlesService.Show(uint(id))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
2024-03-31 15:19:45 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"Articles successfully retrieved"},
|
|
|
|
|
Data: articlesData,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-31 15:19:45 +00:00
|
|
|
// Save Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Create Articles
|
|
|
|
|
// @Description API for create Articles
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Tags Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Param payload body request.ArticlesCreateRequest true "Required payload"
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Success 200 {object} response.Response
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Router /articles [post]
|
|
|
|
|
func (_i *articlesController) Save(c *fiber.Ctx) error {
|
|
|
|
|
req := new(request.ArticlesCreateRequest)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := _i.articlesService.Save(*req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
2024-03-31 15:19:45 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"Articles successfully created"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-31 15:19:45 +00:00
|
|
|
// Update Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary update Articles
|
|
|
|
|
// @Description API for update Articles
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Tags Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Param payload body request.ArticlesUpdateRequest true "Required payload"
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Param id path int true "Articles ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Router /articles/{id} [put]
|
|
|
|
|
func (_i *articlesController) Update(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req := new(request.ArticlesUpdateRequest)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = _i.articlesService.Update(uint(id), *req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
2024-03-31 15:19:45 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"Articles successfully updated"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-31 15:19:45 +00:00
|
|
|
// Delete Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary delete Articles
|
|
|
|
|
// @Description API for delete Articles
|
2024-03-31 15:19:45 +00:00
|
|
|
// @Tags Articles
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param id path int true "Articles ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Router /articles/{id} [delete]
|
|
|
|
|
func (_i *articlesController) Delete(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = _i.articlesService.Delete(uint(id))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
2024-03-31 15:19:45 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"Articles successfully deleted"},
|
|
|
|
|
})
|
|
|
|
|
}
|