package controller import ( "net/http" "github.com/Caknoooo/go-gin-clean-starter/modules/mvendor/dto" "github.com/Caknoooo/go-gin-clean-starter/modules/mvendor/query" "github.com/Caknoooo/go-gin-clean-starter/modules/mvendor/service" "github.com/Caknoooo/go-gin-clean-starter/pkg/constants" "github.com/Caknoooo/go-gin-clean-starter/pkg/utils" "github.com/gin-gonic/gin" "github.com/samber/do" "gorm.io/gorm" ) type VendorController interface { Create(ctx *gin.Context) Update(ctx *gin.Context) Delete(ctx *gin.Context) GetById(ctx *gin.Context) GetAll(ctx *gin.Context) } type vendorController struct { vendorService service.VendorService db *gorm.DB } func NewVendorController(i *do.Injector, vendorService service.VendorService) VendorController { db := do.MustInvokeNamed[*gorm.DB](i, constants.DB) return &vendorController{ vendorService: vendorService, db: db, } } func (c *vendorController) Create(ctx *gin.Context) { var req dto.VendorCreateRequest if err := ctx.ShouldBindJSON(&req); err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_GET_DATA_FROM_BODY, err.Error(), nil) ctx.JSON(http.StatusBadRequest, res) return } created, err := c.vendorService.Create(ctx, req) if err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_CREATE_VENDOR, err.Error(), nil) ctx.JSON(http.StatusInternalServerError, res) return } res := utils.BuildResponseSuccess(dto.MESSAGE_SUCCESS_CREATE_VENDOR, created) ctx.JSON(http.StatusOK, res) } func (c *vendorController) Update(ctx *gin.Context) { id := ctx.Param("id") var req dto.VendorUpdateRequest if err := ctx.ShouldBindJSON(&req); err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_GET_DATA_FROM_BODY, err.Error(), nil) ctx.JSON(http.StatusBadRequest, res) return } updated, err := c.vendorService.Update(ctx, req, id) if err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_UPDATE_VENDOR, err.Error(), nil) ctx.JSON(http.StatusInternalServerError, res) return } res := utils.BuildResponseSuccess(dto.MESSAGE_SUCCESS_UPDATE_VENDOR, updated) ctx.JSON(http.StatusOK, res) } func (c *vendorController) Delete(ctx *gin.Context) { id := ctx.Param("id") if err := c.vendorService.Delete(ctx, id); err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_DELETE_VENDOR, err.Error(), nil) ctx.JSON(http.StatusInternalServerError, res) return } res := utils.BuildResponseSuccess(dto.MESSAGE_SUCCESS_DELETE_VENDOR, nil) ctx.JSON(http.StatusOK, res) } func (c *vendorController) GetById(ctx *gin.Context) { id := ctx.Param("id") vendor, err := c.vendorService.GetById(ctx, id) if err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_GET_VENDOR, err.Error(), nil) ctx.JSON(http.StatusNotFound, res) return } res := utils.BuildResponseSuccess(dto.MESSAGE_SUCCESS_GET_VENDOR, vendor) ctx.JSON(http.StatusOK, res) } func (c *vendorController) GetAll(ctx *gin.Context) { clientId := ctx.MustGet("client_id").(string) var filter query.VendorFilter filter.ClientID = clientId if err := ctx.ShouldBindQuery(&filter); err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_GET_VENDOR, err.Error(), nil) ctx.JSON(http.StatusBadRequest, res) return } perPage := utils.ParseInt(ctx.DefaultQuery("per_page", "10")) page := utils.ParseInt(ctx.DefaultQuery("page", "1")) filter.PerPage = perPage filter.Page = (page - 1) * perPage vendors, total, err := c.vendorService.GetAll(ctx, filter) if err != nil { res := utils.BuildResponseFailed(dto.MESSAGE_FAILED_GET_VENDOR, err.Error(), nil) ctx.JSON(http.StatusBadRequest, res) return } paginationResponse := utils.BuildPaginationResponse(perPage, page, total) response := utils.BuildResponseSuccessWithPagination(http.StatusOK, dto.MESSAGE_SUCCESS_GET_VENDOR, vendors, paginationResponse) ctx.JSON(http.StatusOK, response) }