package user import ( "git.0x7f.app/WOJ/woj-server/internal/e" "git.0x7f.app/WOJ/woj-server/internal/model" "git.0x7f.app/WOJ/woj-server/internal/service/user" "github.com/gin-gonic/gin" ) type createRequest struct { Email string `form:"email" json:"email" binding:"required"` NickName string `form:"nickname" json:"nickname" binding:"required"` Password string `form:"password" json:"password" binding:"required"` } // Create // @Summary create a new user // @Description create a new user // @Tags user // @Accept application/x-www-form-urlencoded // @Produce json // @Param email formData string true "email" // @Param nickname formData string true "nickname" // @Param password formData string true "password" // @Response 200 {object} e.Response[string] "jwt token" // @Router /v1/user/create [post] func (h *handler) Create(c *gin.Context) { req := new(createRequest) if err := c.ShouldBind(req); err != nil { e.Pong(c, e.InvalidParameter, err.Error()) return } // create user createData := &user.CreateData{ Email: req.Email, NickName: req.NickName, Password: req.Password, } u, status := h.userService.Create(createData) if status != e.Success { e.Pong[any](c, status, nil) return } // update version in cache version, status := h.userService.IncrVersion(u.ID) if status != e.Success { e.Pong[any](c, status, nil) return } // sign jwt token claim := &model.Claim{ UID: u.ID, Role: u.Role, Version: version, } token, status := h.jwtService.SignClaim(claim) e.Pong(c, status, token) }