merch-api/internal/user/controller.go

124 lines
3.3 KiB
Go
Raw Normal View History

2026-03-20 16:09:12 +03:00
package user
import (
"github.com/gin-gonic/gin"
"merch-api/internal/appLog"
"merch-api/pkg/responses"
2026-03-21 15:21:30 +03:00
"merch-api/pkg/router"
2026-03-20 16:09:12 +03:00
"merch-api/pkg/utils"
"net/http"
)
const controllerLogHeader string = "[Controller]"
type controller struct {
service *service
utils utils.Utils
}
func newController(s *service, utils utils.Utils) *controller {
return &controller{
service: s,
utils: utils,
}
}
2026-03-21 15:21:30 +03:00
func (h *Handler) RegisterRoutes(r *gin.RouterGroup, mw *router.Middlewares) {
2026-03-20 16:09:12 +03:00
userGroup := r.Group("/user")
2026-03-21 15:21:30 +03:00
userGroup.POST("", mw.RegMW, h.controller.create)
userGroup.DELETE("", mw.AuthMW, h.controller.delete)
2026-03-26 20:43:37 +03:00
userGroup.GET("/me", h.controller.me)
2026-03-20 16:09:12 +03:00
}
// create godoc
//
// @Summary Create new user
// @Description Adds local user record based on user uuid from auth service
2026-03-20 16:13:25 +03:00
// @Tags User
2026-03-20 16:09:12 +03:00
// @Accept json
// @Success 201
// @Failure 400 {object} responses.BadRequest
// @Failure 401 {object} responses.Unauthorized
// @Failure 500 {object} responses.InternalServerError
2026-03-20 16:13:25 +03:00
// @Router /user [POST]
2026-03-20 16:09:12 +03:00
func (co *controller) create(c *gin.Context) {
u, err := co.utils.GetUserUuidFromContext(c)
if err != nil {
c.JSON(http.StatusBadRequest, responses.BadRequest{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
if err = co.service.createUser(c, u); err != nil {
c.JSON(http.StatusInternalServerError, responses.InternalServerError{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
c.Status(http.StatusCreated)
}
2026-03-20 16:13:25 +03:00
// delete godoc
2026-03-20 16:09:12 +03:00
//
// @Summary Delete user
// @Description Marks user as deleted by user uuid
2026-03-20 16:13:25 +03:00
// @Tags User
2026-03-20 16:09:12 +03:00
// @Accept json
// @Success 204
// @Failure 400 {object} responses.BadRequest
// @Failure 401 {object} responses.Unauthorized
// @Failure 500 {object} responses.InternalServerError
2026-03-20 16:13:25 +03:00
// @Router /user [DELETE]
2026-03-20 16:09:12 +03:00
func (co *controller) delete(c *gin.Context) {
u, err := co.utils.GetUserUuidFromContext(c)
if err != nil {
c.JSON(http.StatusBadRequest, responses.BadRequest{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
if err = co.service.deleteUser(c, u); err != nil {
c.JSON(http.StatusInternalServerError, responses.InternalServerError{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
c.Status(http.StatusNoContent)
}
2026-03-26 20:29:58 +03:00
// me godoc
//
// @Summary Returns user data
// @Description Returns user data
// @Tags User
// @Accept json
// @Success 200 {object} MeDTO
// @Failure 400 {object} responses.BadRequest
// @Failure 401 {object} responses.Unauthorized
// @Failure 404 {object} responses.NotFound
// @Failure 500 {object} responses.InternalServerError
// @Router /user [DELETE]
func (co *controller) me(c *gin.Context) {
u, err := co.utils.GetUserUuidFromContext(c)
if err != nil {
c.JSON(http.StatusBadRequest, responses.BadRequest{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
response, err := co.service.getUser(c, u)
if err != nil {
c.JSON(http.StatusInternalServerError, responses.InternalServerError{Error: err.Error()})
appLog.LogErr(pkgLogHeader, controllerLogHeader, err)
return
}
if response == nil {
c.Status(http.StatusNoContent)
return
}
c.JSON(http.StatusOK, response)
}