woj-server/internal/api/user/login.go

61 lines
1.4 KiB
Go
Raw Normal View History

2022-09-17 11:22:55 +08:00
package user
import (
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/e"
2023-07-15 16:19:49 +08:00
"git.0x7f.app/WOJ/woj-server/internal/model"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/service/user"
2022-09-17 11:22:55 +08:00
"github.com/gin-gonic/gin"
)
type loginRequest struct {
UserName string `form:"username" binding:"required"`
2022-09-17 11:22:55 +08:00
Password string `form:"password" binding:"required"`
}
// Login
// @Summary login
// @Description login and return token
2023-12-18 21:21:15 +08:00
// @Tags user
2022-09-17 11:22:55 +08:00
// @Accept application/x-www-form-urlencoded
// @Produce json
// @Param username formData string true "username"
// @Param password formData string true "password"
// @Response 200 {object} e.Response "jwt token and user nickname"
2022-09-17 11:22:55 +08:00
// @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, nil)
2022-09-17 11:22:55 +08:00
return
}
// check password
loginData := &user.LoginData{
UserName: req.UserName,
Password: req.Password,
2022-09-17 11:22:55 +08:00
}
u, status := h.userService.Login(loginData)
2022-09-20 14:15:21 +08:00
if status != e.Success {
e.Pong(c, status, nil)
2022-09-17 11:22:55 +08:00
return
}
// sign and return token
version, status := h.userService.IncrVersion(u.ID)
2022-09-20 14:15:21 +08:00
if status != e.Success {
e.Pong(c, status, nil)
return
}
2023-07-15 16:19:49 +08:00
claim := &model.Claim{
UID: u.ID,
Role: u.Role,
Version: version,
}
2022-09-20 14:15:21 +08:00
token, status := h.jwtService.SignClaim(claim)
e.Pong(c, status, gin.H{
"token": token,
"nickname": u.NickName,
})
2022-09-17 11:22:55 +08:00
}