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

238 lines
7.5 KiB
Go
Raw Normal View History

2024-03-05 19:15:53 +00:00
package controller
import (
"github.com/gofiber/fiber/v2"
"github.com/rs/zerolog"
2024-03-05 19:15:53 +00:00
"go-humas-be/app/module/ppid_data_files/request"
"go-humas-be/app/module/ppid_data_files/service"
"go-humas-be/utils/paginator"
utilRes "go-humas-be/utils/response"
utilVal "go-humas-be/utils/validator"
"strconv"
2024-03-05 19:15:53 +00:00
)
type ppidDataFilesController struct {
ppidDataFilesService service.PpidDataFilesService
Log zerolog.Logger
2024-03-05 19:15:53 +00:00
}
type PpidDataFilesController interface {
All(c *fiber.Ctx) error
Show(c *fiber.Ctx) error
Save(c *fiber.Ctx) error
Update(c *fiber.Ctx) error
UpdatePosition(c *fiber.Ctx) error
2024-03-05 19:15:53 +00:00
Delete(c *fiber.Ctx) error
Viewer(c *fiber.Ctx) error
2024-03-05 19:15:53 +00:00
}
func NewPpidDataFilesController(ppidDataFilesService service.PpidDataFilesService, log zerolog.Logger) PpidDataFilesController {
2024-03-05 19:15:53 +00:00
return &ppidDataFilesController{
ppidDataFilesService: ppidDataFilesService,
Log: log,
2024-03-05 19:15:53 +00:00
}
}
// All PpidDataFiles
2024-03-05 19:15:53 +00:00
// @Summary Get all PpidDataFiles
// @Description API for getting all PpidDataFiles
// @Tags PPID Files
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param req query request.PpidDataFilesQueryRequest 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-data-files [get]
func (_i *ppidDataFilesController) All(c *fiber.Ctx) error {
paginate, err := paginator.Paginate(c)
if err != nil {
return err
}
reqContext := request.PpidDataFilesQueryRequestContext{
Title: c.Query("title"),
PpidDataId: c.Query("ppidDataId"),
Description: c.Query("description"),
Unit: c.Query("unit"),
FileType: c.Query("fileType"),
StatusId: c.Query("statusId"),
IsPublish: c.Query("isPublish"),
}
req := reqContext.ToParamRequest()
2024-03-05 19:15:53 +00:00
req.Pagination = paginate
ppidDataFilesData, paging, err := _i.ppidDataFilesService.All(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{"PpidDataFiles list successfully retrieved"},
Data: ppidDataFilesData,
Meta: paging,
})
}
// Show PpidDataFiles
2024-03-05 19:15:53 +00:00
// @Summary Get one PpidDataFiles
// @Description API for getting one PpidDataFiles
// @Tags PPID Files
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param id path int true "PpidDataFiles 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-data-files/{id} [get]
func (_i *ppidDataFilesController) Show(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
ppidDataFilesData, err := _i.ppidDataFilesService.Show(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{"PpidDataFiles successfully retrieved"},
Data: ppidDataFilesData,
})
}
// Save PpidDataFiles
2024-03-05 19:15:53 +00:00
// @Summary Create PpidDataFiles
// @Description API for create PpidDataFiles
// @Tags PPID Files
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Produce json
// @Param files formData file true "Upload file"
// @Param ppidDataId path int true "Ppid Data ID"
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
// @Router /ppid-data-files/{ppidDataId} [post]
2024-03-05 19:15:53 +00:00
func (_i *ppidDataFilesController) Save(c *fiber.Ctx) error {
err := _i.ppidDataFilesService.Save(c)
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{"PpidDataFiles successfully created"},
})
}
// Update PpidDataFiles
2024-03-05 19:15:53 +00:00
// @Summary update PpidDataFiles
// @Description API for update PpidDataFiles
// @Tags PPID Files
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param payload body request.PpidDataFilesUpdateRequest true "Required payload"
// @Param id path int true "Ppid Data ID"
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-data-files/{id} [put]
func (_i *ppidDataFilesController) Update(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
req := new(request.PpidDataFilesUpdateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
err = _i.ppidDataFilesService.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{"PpidDataFiles successfully updated"},
})
}
// UpdatePosition PpidDataFiles
// @Summary updatePosition PpidDataFiles
// @Description API for PpidDataFiles
// @Tags PPID Files
// @Security Bearer
// @Param payload body request.PpidDataFilesUpdatePositionPayload 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-data-files/update/position [post]
func (_i *ppidDataFilesController) UpdatePosition(c *fiber.Ctx) error {
req := new(request.PpidDataFilesUpdatePositionPayload)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
err := _i.ppidDataFilesService.UpdatePosition(req.Positions)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"PpidDataFiles successfully updated"},
})
}
// Delete PpidDataFiles
2024-03-05 19:15:53 +00:00
// @Summary delete PpidDataFiles
// @Description API for delete PpidDataFiles
// @Tags PPID Files
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param id path int true "PpidDataFiles 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-data-files/{id} [delete]
func (_i *ppidDataFilesController) Delete(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
err = _i.ppidDataFilesService.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{"PpidDataFiles successfully deleted"},
})
}
// Viewer PpidDataFiles
// @Summary Create PpidDataFiles
// @Description API for create PpidDataFiles
// @Tags PPID Files
// @Security Bearer
// @Param filename path string true "Ppid Data Filename"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /ppid-data-files/viewer/{filename} [get]
func (_i *ppidDataFilesController) Viewer(c *fiber.Ctx) error {
filename := c.Params("filename")
return _i.ppidDataFilesService.Viewer(c, filename)
}