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 loginRequest struct { Email string `form:"email" json:"email" binding:"required"` Password string `form:"password" json:"password" binding:"required"` } type LoginResponse struct { Token string `json:"token"` NickName string `json:"nickname"` } // Login // @Summary login // @Description login and return token // @Tags user // @Accept application/x-www-form-urlencoded // @Produce json // @Param email formData string true "email" // @Param password formData string true "password" // @Response 200 {object} e.Response[LoginResponse] "jwt token and user's nickname" // @Router /v1/user/login [post] func (h *handler) Login(c *gin.Context) { req := new(loginRequest) if err := c.ShouldBind(req); err != nil { e.Pong(c, e.InvalidParameter, err.Error()) return } // check password loginData := &user.LoginData{ Email: req.Email, Password: req.Password, } u, status := h.userService.Login(loginData) if status != e.Success { e.Pong[any](c, status, nil) return } // sign and return token version, status := h.userService.IncrVersion(u.ID) if status != e.Success { e.Pong[any](c, status, nil) return } claim := &model.Claim{ UID: u.ID, Role: u.Role, Version: version, } token, status := h.jwtService.SignClaim(claim) e.Pong(c, status, LoginResponse{Token: token, NickName: u.NickName}) }