2024-03-05 19:15:53 +00:00
|
|
|
package controller
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
2024-05-12 10:09:54 +00:00
|
|
|
"github.com/rs/zerolog"
|
2024-03-05 19:15:53 +00:00
|
|
|
"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
|
2024-05-12 10:09:54 +00:00
|
|
|
log zerolog.Logger
|
2024-03-05 19:15:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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-28 03:07:38 +00:00
|
|
|
UpdatePosition(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,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
// All PpidDatas
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Get all PpidDatas
|
|
|
|
|
// @Description API for getting all PpidDatas
|
2024-04-28 18:39:43 +00:00
|
|
|
// @Tags PPID Data
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-05-12 05:15:13 +00:00
|
|
|
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
|
2024-04-28 18:39:43 +00:00
|
|
|
// @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
|
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 /ppid-datas [get]
|
|
|
|
|
func (_i *ppidDatasController) All(c *fiber.Ctx) error {
|
|
|
|
|
paginate, err := paginator.Paginate(c)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-12 05:15:13 +00:00
|
|
|
authToken := c.Get("Authorization")
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
reqContext := request.PpidDatasQueryRequestContext{
|
|
|
|
|
Title: c.Query("title"),
|
|
|
|
|
Description: c.Query("description"),
|
|
|
|
|
CategoryId: c.Query("categoryId"),
|
2024-05-12 05:15:13 +00:00
|
|
|
UserId: c.Query("userId"),
|
|
|
|
|
UserRoleId: c.Query("userRoleId"),
|
|
|
|
|
UserLevelId: c.Query("userLevelId"),
|
2024-04-16 02:08:00 +00:00
|
|
|
StatusId: c.Query("statusId"),
|
|
|
|
|
IsPublish: c.Query("isPublish"),
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req := reqContext.ToParamRequest()
|
2024-03-05 19:15:53 +00:00
|
|
|
req.Pagination = paginate
|
|
|
|
|
|
2024-05-12 10:09:54 +00:00
|
|
|
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{
|
2024-04-16 02:08:00 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"PpidDatas list successfully retrieved"},
|
|
|
|
|
Data: ppidDatasData,
|
|
|
|
|
Meta: paging,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
// Show PpidDatas
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Get one PpidDatas
|
|
|
|
|
// @Description API for getting one PpidDatas
|
2024-04-28 18:39:43 +00:00
|
|
|
// @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
|
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 /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{
|
2024-04-16 02:08:00 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"PpidDatas successfully retrieved"},
|
|
|
|
|
Data: ppidDatasData,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
// Save PpidDatas
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary Create PpidDatas
|
|
|
|
|
// @Description API for create PpidDatas
|
2024-04-28 18:39:43 +00:00
|
|
|
// @Tags PPID Data
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-04-29 09:46:37 +00:00
|
|
|
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
|
2024-04-16 02:08:00 +00:00
|
|
|
// @Param payload body request.PpidDatasCreateRequest 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 /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
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-29 09:46:37 +00:00
|
|
|
authToken := c.Get("Authorization")
|
2024-04-29 17:34:05 +00:00
|
|
|
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{
|
2024-04-16 02:08:00 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"PpidDatas successfully created"},
|
2024-04-29 17:34:05 +00:00
|
|
|
Data: dataResult,
|
2024-03-05 19:15:53 +00:00
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
// Update PpidDatas
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary update PpidDatas
|
|
|
|
|
// @Description API for update PpidDatas
|
2024-04-28 18:39:43 +00:00
|
|
|
// @Tags PPID Data
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Security Bearer
|
2024-04-16 02:08:00 +00:00
|
|
|
// @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
|
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 /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{
|
2024-04-16 02:08:00 +00:00
|
|
|
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"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-28 03:07:38 +00:00
|
|
|
// UpdatePosition PpidDatas
|
|
|
|
|
// @Summary UpdatePosition PpidDatas
|
|
|
|
|
// @Description API for Update Position PpidDatas
|
|
|
|
|
// @Tags PPID Data
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param payload body request.PpidDatasUpdatePositionPayload true "Required payload"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /ppid-datas/position [post]
|
|
|
|
|
func (_i *ppidDatasController) UpdatePosition(c *fiber.Ctx) error {
|
|
|
|
|
req := new(request.PpidDatasUpdatePositionPayload)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := _i.ppidDatasService.UpdatePosition(req.Positions)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"PpidDataCategories successfully updated"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 02:08:00 +00:00
|
|
|
// Delete PpidDatas
|
2024-03-05 19:15:53 +00:00
|
|
|
// @Summary delete PpidDatas
|
|
|
|
|
// @Description API for delete PpidDatas
|
2024-04-28 18:39:43 +00:00
|
|
|
// @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
|
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 /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{
|
2024-04-16 02:08:00 +00:00
|
|
|
Success: true,
|
2024-03-05 19:15:53 +00:00
|
|
|
Messages: utilRes.Messages{"PpidDatas successfully deleted"},
|
|
|
|
|
})
|
|
|
|
|
}
|