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 ) // @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"}, }) }