2025-09-28 01:53:09 +00:00
|
|
|
package controller
|
|
|
|
|
|
|
|
|
|
import (
|
2025-09-30 13:34:56 +00:00
|
|
|
"netidhub-saas-be/app/middleware"
|
|
|
|
|
"netidhub-saas-be/app/module/user_levels/request"
|
|
|
|
|
"netidhub-saas-be/app/module/user_levels/service"
|
|
|
|
|
"netidhub-saas-be/utils/paginator"
|
2025-09-28 01:53:09 +00:00
|
|
|
"strconv"
|
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
|
|
2025-09-30 13:34:56 +00:00
|
|
|
utilRes "netidhub-saas-be/utils/response"
|
|
|
|
|
utilVal "netidhub-saas-be/utils/validator"
|
2025-09-28 01:53:09 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type userLevelsController struct {
|
|
|
|
|
userLevelsService service.UserLevelsService
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type UserLevelsController interface {
|
|
|
|
|
All(c *fiber.Ctx) error
|
|
|
|
|
Show(c *fiber.Ctx) error
|
|
|
|
|
ShowByAlias(c *fiber.Ctx) error
|
|
|
|
|
Save(c *fiber.Ctx) error
|
|
|
|
|
Update(c *fiber.Ctx) error
|
|
|
|
|
Delete(c *fiber.Ctx) error
|
|
|
|
|
EnableApproval(c *fiber.Ctx) error
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewUserLevelsController(userLevelsService service.UserLevelsService) UserLevelsController {
|
|
|
|
|
return &userLevelsController{
|
|
|
|
|
userLevelsService: userLevelsService,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// All UserLevels
|
|
|
|
|
// @Summary Get all UserLevels
|
|
|
|
|
// @Description API for getting all UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param req query request.UserLevelsQueryRequest 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 /user-levels [get]
|
|
|
|
|
func (_i *userLevelsController) All(c *fiber.Ctx) error {
|
|
|
|
|
paginate, err := paginator.Paginate(c)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
reqContext := request.UserLevelsQueryRequestContext{
|
|
|
|
|
Name: c.Query("name"),
|
|
|
|
|
LevelNumber: c.Query("levelNumber"),
|
|
|
|
|
ParentLevelId: c.Query("parentLevelId"),
|
|
|
|
|
ProvinceId: c.Query("provinceId"),
|
|
|
|
|
}
|
|
|
|
|
req := reqContext.ToParamRequest()
|
|
|
|
|
req.Pagination = paginate
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
userLevelsData, paging, err := _i.userLevelsService.All(clientId, req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels list successfully retrieved"},
|
|
|
|
|
Data: userLevelsData,
|
|
|
|
|
Meta: paging,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Show UserLevels
|
|
|
|
|
// @Summary Get one UserLevels
|
|
|
|
|
// @Description API for getting one UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param id path int true "UserLevels ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /user-levels/{id} [get]
|
|
|
|
|
func (_i *userLevelsController) Show(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
userLevelsData, err := _i.userLevelsService.Show(clientId, uint(id))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels successfully retrieved"},
|
|
|
|
|
Data: userLevelsData,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ShowByAlias UserLevels
|
|
|
|
|
// @Summary Get one UserLevels
|
|
|
|
|
// @Description API for getting one UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param alias path string true "UserLevels Alias"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /user-levels/alias/{alias} [get]
|
|
|
|
|
func (_i *userLevelsController) ShowByAlias(c *fiber.Ctx) error {
|
|
|
|
|
alias := c.Params("alias")
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
userLevelsData, err := _i.userLevelsService.ShowByAlias(clientId, alias)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels successfully retrieved"},
|
|
|
|
|
Data: userLevelsData,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Save UserLevels
|
|
|
|
|
// @Summary Create UserLevels
|
|
|
|
|
// @Description API for create UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param X-Csrf-Token header string false "Insert the X-Csrf-Token"
|
|
|
|
|
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
|
|
|
|
|
// @Param payload body request.UserLevelsCreateRequest true "Required payload"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /user-levels [post]
|
|
|
|
|
func (_i *userLevelsController) Save(c *fiber.Ctx) error {
|
|
|
|
|
req := new(request.UserLevelsCreateRequest)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
dataResult, err := _i.userLevelsService.Save(clientId, *req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels successfully created"},
|
|
|
|
|
Data: dataResult,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Update UserLevels
|
|
|
|
|
// @Summary update UserLevels
|
|
|
|
|
// @Description API for update UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param X-Csrf-Token header string false "Insert the X-Csrf-Token"
|
|
|
|
|
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
|
|
|
|
|
// @Param payload body request.UserLevelsUpdateRequest true "Required payload"
|
|
|
|
|
// @Param id path int true "UserLevels ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /user-levels/{id} [put]
|
|
|
|
|
func (_i *userLevelsController) Update(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req := new(request.UserLevelsUpdateRequest)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
err = _i.userLevelsService.Update(clientId, uint(id), *req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels successfully updated"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Delete UserLevels
|
|
|
|
|
// @Summary delete UserLevels
|
|
|
|
|
// @Description API for delete UserLevels
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
|
|
|
|
|
// @Param X-Csrf-Token header string false "Insert the X-Csrf-Token"
|
|
|
|
|
// @Param id path int true "UserLevels ID"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 401 {object} response.Response
|
|
|
|
|
// @Failure 404 {object} response.Response
|
|
|
|
|
// @Failure 422 {object} response.Response
|
|
|
|
|
// @Failure 500 {object} response.Response
|
|
|
|
|
// @Router /user-levels/{id} [delete]
|
|
|
|
|
func (_i *userLevelsController) Delete(c *fiber.Ctx) error {
|
|
|
|
|
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
err = _i.userLevelsService.Delete(clientId, uint(id))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"UserLevels successfully deleted"},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// EnableApproval Articles
|
|
|
|
|
// @Summary EnableApproval Articles
|
|
|
|
|
// @Description API for Enable Approval of Article
|
|
|
|
|
// @Tags UserLevels
|
|
|
|
|
// @Security Bearer
|
|
|
|
|
// @Param X-Client-Key header string true "Client Key"
|
|
|
|
|
// @Param X-Csrf-Token header string false "Insert the X-Csrf-Token"
|
|
|
|
|
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
|
|
|
|
|
// @Param payload body request.UserLevelsApprovalRequest true "Required payload"
|
|
|
|
|
// @Success 200 {object} response.Response
|
|
|
|
|
// @Failure 400 {object} response.BadRequestError
|
|
|
|
|
// @Failure 401 {object} response.UnauthorizedError
|
|
|
|
|
// @Failure 500 {object} response.InternalServerError
|
|
|
|
|
// @Router /user-levels/enable-approval [post]
|
|
|
|
|
func (_i *userLevelsController) EnableApproval(c *fiber.Ctx) error {
|
|
|
|
|
req := new(request.UserLevelsApprovalRequest)
|
|
|
|
|
if err := utilVal.ParseAndValidate(c, req); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get ClientId from context
|
|
|
|
|
clientId := middleware.GetClientID(c)
|
|
|
|
|
|
|
|
|
|
ids := strings.Split(req.Ids, ",")
|
|
|
|
|
for _, id := range ids {
|
|
|
|
|
idUint, err := strconv.ParseUint(id, 10, 64)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
err = _i.userLevelsService.EnableApproval(clientId, uint(idUint), req.IsApprovalActive)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return utilRes.Resp(c, utilRes.Response{
|
|
|
|
|
Success: true,
|
|
|
|
|
Messages: utilRes.Messages{"isApprovalActive of UserLevels successfully saved"},
|
|
|
|
|
})
|
|
|
|
|
}
|