medol-be/app/module/ppid_datas/controller/ppid_datas.controller.go

230 lines
7.1 KiB
Go
Raw Normal View History

2024-03-05 19:15:53 +00:00
package controller
import (
"github.com/gofiber/fiber/v2"
"go-humas-be/app/module/ppid_datas/request"
"go-humas-be/app/module/ppid_datas/service"
"go-humas-be/utils/paginator"
"strconv"
2024-05-05 14:55:06 +00:00
requestPpidApproval "go-humas-be/app/module/ppid_data_approval_histories/request"
2024-03-05 19:15:53 +00:00
utilRes "go-humas-be/utils/response"
utilVal "go-humas-be/utils/validator"
)
type ppidDatasController struct {
ppidDatasService service.PpidDatasService
}
type PpidDatasController interface {
All(c *fiber.Ctx) error
Show(c *fiber.Ctx) error
Save(c *fiber.Ctx) error
Update(c *fiber.Ctx) error
2024-05-05 14:55:06 +00:00
UpdateApprovalStatus(c *fiber.Ctx) error
2024-03-05 19:15:53 +00:00
Delete(c *fiber.Ctx) error
}
func NewPpidDatasController(ppidDatasService service.PpidDatasService) PpidDatasController {
return &ppidDatasController{
ppidDatasService: ppidDatasService,
}
}
// All PpidDatas
2024-03-05 19:15:53 +00:00
// @Summary Get all PpidDatas
// @Description API for getting all PpidDatas
// @Tags PPID Data
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
// @Param req query request.PpidDatasQueryRequest false "query parameters"
// @Param req query paginator.Pagination false "pagination parameters"
2024-03-05 19:15:53 +00:00
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-03-05 19:15:53 +00:00
// @Router /ppid-datas [get]
func (_i *ppidDatasController) All(c *fiber.Ctx) error {
paginate, err := paginator.Paginate(c)
if err != nil {
return err
}
authToken := c.Get("Authorization")
reqContext := request.PpidDatasQueryRequestContext{
Title: c.Query("title"),
Description: c.Query("description"),
CategoryId: c.Query("categoryId"),
UserId: c.Query("userId"),
UserRoleId: c.Query("userRoleId"),
UserLevelId: c.Query("userLevelId"),
StatusId: c.Query("statusId"),
IsPublish: c.Query("isPublish"),
}
req := reqContext.ToParamRequest()
2024-03-05 19:15:53 +00:00
req.Pagination = paginate
ppidDatasData, paging, err := _i.ppidDatasService.All(req, authToken)
2024-03-05 19:15:53 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"PpidDatas list successfully retrieved"},
Data: ppidDatasData,
Meta: paging,
})
}
// Show PpidDatas
2024-03-05 19:15:53 +00:00
// @Summary Get one PpidDatas
// @Description API for getting one PpidDatas
// @Tags PPID Data
2024-03-05 19:15:53 +00:00
// @Security Bearer
2024-04-30 03:53:50 +00:00
// @Param id path string true "PpidDatas [ ID / Slug ]"
2024-03-05 19:15:53 +00:00
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-03-05 19:15:53 +00:00
// @Router /ppid-datas/{id} [get]
func (_i *ppidDatasController) Show(c *fiber.Ctx) error {
2024-04-30 03:53:50 +00:00
id := c.Params("id")
ppidDatasData, err := _i.ppidDatasService.Show(id)
2024-03-05 19:15:53 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"PpidDatas successfully retrieved"},
Data: ppidDatasData,
})
}
// Save PpidDatas
2024-03-05 19:15:53 +00:00
// @Summary Create PpidDatas
// @Description API for create PpidDatas
// @Tags PPID Data
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
// @Param payload body request.PpidDatasCreateRequest true "Required payload"
2024-03-05 19:15:53 +00:00
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-03-05 19:15:53 +00:00
// @Router /ppid-datas [post]
func (_i *ppidDatasController) Save(c *fiber.Ctx) error {
req := new(request.PpidDatasCreateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
authToken := c.Get("Authorization")
dataResult, err := _i.ppidDatasService.Save(*req, authToken)
2024-03-05 19:15:53 +00:00
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"PpidDatas successfully created"},
Data: dataResult,
2024-03-05 19:15:53 +00:00
})
}
// Update PpidDatas
2024-03-05 19:15:53 +00:00
// @Summary update PpidDatas
// @Description API for update PpidDatas
// @Tags PPID Data
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param payload body request.PpidDatasCreateRequest true "Required payload"
2024-03-05 19:15:53 +00:00
// @Param id path int true "PpidDatas ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-03-05 19:15:53 +00:00
// @Router /ppid-datas/{id} [put]
func (_i *ppidDatasController) Update(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
req := new(request.PpidDatasUpdateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
err = _i.ppidDatasService.Update(uint(id), *req)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"PpidDatas successfully updated"},
})
}
2024-05-05 14:55:06 +00:00
// UpdateApprovalStatus PpidDatas
// @Summary UpdateApprovalStatus PpidDatas
// @Description API for UpdateApprovalStatus PpidDatas
// @Tags PPID Data
// @Security Bearer
2024-05-07 17:30:55 +00:00
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
2024-05-05 14:55:06 +00:00
// @Param payload body requestPpidApproval.PpidDataApprovalHistoriesCreateRequest true "Required payload"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-05-07 17:30:55 +00:00
// @Router /ppid-datas/approval [post]
2024-05-05 14:55:06 +00:00
func (_i *ppidDatasController) UpdateApprovalStatus(c *fiber.Ctx) error {
req := new(requestPpidApproval.PpidDataApprovalHistoriesCreateRequest)
2024-05-07 17:30:55 +00:00
2024-05-05 14:55:06 +00:00
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
authToken := c.Get("Authorization")
err := _i.ppidDatasService.UpdateApprovalStatus(*req, authToken)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"PpidDatas successfully updated"},
})
}
// Delete PpidDatas
2024-03-05 19:15:53 +00:00
// @Summary delete PpidDatas
// @Description API for delete PpidDatas
// @Tags PPID Data
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param id path int true "PpidDatas ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-03-05 19:15:53 +00:00
// @Router /ppid-datas/{id} [delete]
func (_i *ppidDatasController) Delete(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
err = _i.ppidDatasService.Delete(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"PpidDatas successfully deleted"},
})
}