238 lines
7.7 KiB
Go
238 lines
7.7 KiB
Go
package controller
|
|
|
|
import (
|
|
"narasi-ahli-be/app/module/education_history/request"
|
|
"narasi-ahli-be/app/module/education_history/service"
|
|
"narasi-ahli-be/utils/paginator"
|
|
utilRes "narasi-ahli-be/utils/response"
|
|
utilVal "narasi-ahli-be/utils/validator"
|
|
"strconv"
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
)
|
|
|
|
type educationHistoryController struct {
|
|
educationHistoryService service.EducationHistoryService
|
|
}
|
|
|
|
type EducationHistoryController 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
|
|
UploadCertificate(c *fiber.Ctx) error
|
|
}
|
|
|
|
func NewEducationHistoryController(educationHistoryService service.EducationHistoryService) EducationHistoryController {
|
|
return &educationHistoryController{
|
|
educationHistoryService: educationHistoryService,
|
|
}
|
|
}
|
|
|
|
// All Education History
|
|
// @Summary Get all Education History
|
|
// @Description API for getting all Education History for authenticated user
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param req query request.EducationHistoryQueryRequest false "query parameters"
|
|
// @Param req query paginator.Pagination false "pagination parameters"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history [get]
|
|
func (_i *educationHistoryController) All(c *fiber.Ctx) error {
|
|
paginate, err := paginator.Paginate(c)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
reqContext := request.EducationHistoryQueryRequestContext{
|
|
SchoolName: c.Query("schoolName"),
|
|
Major: c.Query("major"),
|
|
EducationLevel: c.Query("educationLevel"),
|
|
GraduationYear: c.Query("graduationYear"),
|
|
}
|
|
req := reqContext.ToParamRequest()
|
|
req.Pagination = paginate
|
|
|
|
educationData, paging, err := _i.educationHistoryService.All(authHeader, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Education history list successfully retrieved"},
|
|
Data: educationData,
|
|
Meta: paging,
|
|
})
|
|
}
|
|
|
|
// Show Education History
|
|
// @Summary Get one Education History
|
|
// @Description API for getting one Education History
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param id path int true "Education History ID"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history/{id} [get]
|
|
func (_i *educationHistoryController) Show(c *fiber.Ctx) error {
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
educationData, err := _i.educationHistoryService.Show(authHeader, uint(id))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Education history successfully retrieved"},
|
|
Data: educationData,
|
|
})
|
|
}
|
|
|
|
// Save Education History
|
|
// @Summary Create Education History
|
|
// @Description API for create Education History
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
|
|
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
|
|
// @Param payload body request.EducationHistoryCreateRequest true "Required payload"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history [post]
|
|
func (_i *educationHistoryController) Save(c *fiber.Ctx) error {
|
|
req := new(request.EducationHistoryCreateRequest)
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
dataResult, err := _i.educationHistoryService.Save(authHeader, *req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Education history successfully created"},
|
|
Data: dataResult,
|
|
})
|
|
}
|
|
|
|
// Update Education History
|
|
// @Summary Update Education History
|
|
// @Description API for update Education History
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
|
|
// @Param id path int true "Education History ID"
|
|
// @Param payload body request.EducationHistoryUpdateRequest true "Required payload"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history/{id} [put]
|
|
func (_i *educationHistoryController) Update(c *fiber.Ctx) error {
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
req := new(request.EducationHistoryUpdateRequest)
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
err = _i.educationHistoryService.Update(authHeader, uint(id), *req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Education history successfully updated"},
|
|
})
|
|
}
|
|
|
|
// Delete Education History
|
|
// @Summary Delete Education History
|
|
// @Description API for delete Education History
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
|
|
// @Param id path int true "Education History ID"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history/{id} [delete]
|
|
func (_i *educationHistoryController) Delete(c *fiber.Ctx) error {
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
err = _i.educationHistoryService.Delete(authHeader, uint(id))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Education history successfully deleted"},
|
|
})
|
|
}
|
|
|
|
// UploadCertificate Education History
|
|
// @Summary Upload Certificate for Education History
|
|
// @Description API for upload certificate image for Education History
|
|
// @Tags Education History
|
|
// @Security Bearer
|
|
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
|
|
// @Param id path int true "Education History ID"
|
|
// @Param certificate formData file true "Certificate image file"
|
|
// @Success 200 {object} response.Response
|
|
// @Failure 400 {object} response.BadRequestError
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
// @Failure 500 {object} response.InternalServerError
|
|
// @Router /education-history/{id}/certificate [post]
|
|
func (_i *educationHistoryController) UploadCertificate(c *fiber.Ctx) error {
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
authHeader := c.Get("Authorization")
|
|
|
|
err = _i.educationHistoryService.UploadCertificate(authHeader, uint(id), c)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
Success: true,
|
|
Messages: utilRes.Messages{"Certificate successfully uploaded"},
|
|
})
|
|
}
|