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

263 lines
7.6 KiB
Go
Raw Normal View History

2024-03-05 19:15:53 +00:00
package controller
import (
"github.com/gofiber/fiber/v2"
2024-11-22 04:14:14 +00:00
_ "github.com/gofiber/fiber/v2"
2024-03-05 19:15:53 +00:00
"go-humas-be/app/module/users/request"
"go-humas-be/app/module/users/service"
"go-humas-be/utils/paginator"
"strconv"
utilRes "go-humas-be/utils/response"
utilVal "go-humas-be/utils/validator"
)
type usersController struct {
usersService service.UsersService
}
type UsersController interface {
All(c *fiber.Ctx) error
Show(c *fiber.Ctx) error
2024-07-02 17:46:52 +00:00
ShowInfo(c *fiber.Ctx) error
2024-03-05 19:15:53 +00:00
Save(c *fiber.Ctx) error
Update(c *fiber.Ctx) error
Login(c *fiber.Ctx) error
2024-03-05 19:15:53 +00:00
Delete(c *fiber.Ctx) error
}
func NewUsersController(usersService service.UsersService) UsersController {
return &usersController{
usersService: usersService,
}
}
// All Users
2024-03-05 19:15:53 +00:00
// @Summary Get all Users
// @Description API for getting all Users
// @Tags Users
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param req query request.UsersQueryRequest 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 /users [get]
func (_i *usersController) All(c *fiber.Ctx) error {
paginate, err := paginator.Paginate(c)
if err != nil {
return err
}
reqContext := request.UsersQueryRequestContext{
Username: c.Query("username"),
Email: c.Query("email"),
Fullname: c.Query("fullname"),
PhoneNumber: c.Query("phoneNumber"),
WorkType: c.Query("workType"),
GenderType: c.Query("genderType"),
IdentityType: c.Query("identityType"),
IdentityGroup: c.Query("identityGroup"),
IdentityGroupNumber: c.Query("identityGroupNumber"),
IdentityNumber: c.Query("identityNumber"),
UserRoleId: c.Query("userRoleId"),
StatusId: c.Query("statusId"),
}
req := reqContext.ToParamRequest()
2024-03-05 19:15:53 +00:00
req.Pagination = paginate
usersData, paging, err := _i.usersService.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{"Users list successfully retrieved"},
Data: usersData,
Meta: paging,
})
}
// Show Users
2024-03-05 19:15:53 +00:00
// @Summary Get one Users
// @Description API for getting one Users
// @Tags Users
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param id path int true "Users ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
2024-07-02 17:46:52 +00:00
// @Router /users/detail/{id} [get]
2024-03-05 19:15:53 +00:00
func (_i *usersController) Show(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
usersData, err := _i.usersService.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{"Users successfully retrieved"},
Data: usersData,
})
}
2024-07-02 17:46:52 +00:00
// ShowInfo Users
// @Summary ShowInfo Users
// @Description API for ShowUserInfo
// @Tags Users
// @Security Bearer
// @Param Authorization header string true "Insert your access token" default(Bearer <Add access token here>)
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /users/info [get]
func (_i *usersController) ShowInfo(c *fiber.Ctx) error {
authToken := c.Get("Authorization")
dataResult, err := _i.usersService.ShowUserInfo(authToken)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Users successfully retrieve"},
Data: dataResult,
})
}
// Save Users
2024-03-05 19:15:53 +00:00
// @Summary Create Users
// @Description API for create Users
// @Tags Users
2024-03-05 19:15:53 +00:00
// @Security Bearer
2024-07-15 02:36:19 +00:00
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
// @Param payload body request.UsersCreateRequest true "Required payload"
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 /users [post]
func (_i *usersController) Save(c *fiber.Ctx) error {
req := new(request.UsersCreateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
authToken := c.Get("Authorization")
2024-11-22 04:14:14 +00:00
dataResult, err := _i.usersService.Save(*req, authToken)
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{"Users successfully created"},
2024-11-22 04:14:14 +00:00
Data: dataResult,
2024-03-05 19:15:53 +00:00
})
}
// Update Users
2024-03-05 19:15:53 +00:00
// @Summary update Users
// @Description API for update Users
// @Tags Users
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param payload body request.UsersUpdateRequest true "Required payload"
2024-03-05 19:15:53 +00:00
// @Param id path int true "Users 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 /users/{id} [put]
func (_i *usersController) Update(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
req := new(request.UsersUpdateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
err = _i.usersService.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{"Users successfully updated"},
})
}
// Login Users
// @Summary Login Users
// @Description API for Login Users
// @Tags Users
// @Security Bearer
// @Param payload body request.UserLogin true "Required payload"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /users/login [post]
func (_i *usersController) Login(c *fiber.Ctx) error {
req := new(request.UserLogin)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
loginResponse, err := _i.usersService.Login(*req)
if err != nil {
return utilRes.Resp(c, utilRes.Response{
Success: false,
Code: 401,
Messages: utilRes.Messages{err.Error()},
})
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"Users successfully login"},
Data: loginResponse,
})
}
// Delete Users
2024-03-05 19:15:53 +00:00
// @Summary delete Users
// @Description API for delete Users
// @Tags Users
2024-03-05 19:15:53 +00:00
// @Security Bearer
// @Param id path int true "Users 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 /users/{id} [delete]
func (_i *usersController) Delete(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
err = _i.usersService.Delete(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
2024-03-31 15:19:45 +00:00
Success: true,
2024-03-05 19:15:53 +00:00
Messages: utilRes.Messages{"Users successfully deleted"},
})
}