You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

72 lines
1.7 KiB

package auth
import (
"net/http"
"task-track-backend/model"
"task-track-backend/pkg/auth"
"github.com/gin-gonic/gin"
"golang.org/x/crypto/bcrypt"
)
func (h *AuthHandler) Login(c *gin.Context) {
var loginData struct {
Username string `json:"username" binding:"required"`
Password string `json:"password" binding:"required"`
}
if err := c.ShouldBindJSON(&loginData); err != nil {
c.JSON(http.StatusBadRequest, gin.H{
"code": 400,
"message": "Invalid request data",
"error": err.Error(),
})
return
}
// 查找用户
var user model.User
if err := h.db.Where("username = ?", loginData.Username).First(&user).Error; err != nil {
c.JSON(http.StatusUnauthorized, gin.H{
"code": 401,
"message": "Invalid credentials",
})
return
}
// 验证密码
if err := bcrypt.CompareHashAndPassword([]byte(user.Password), []byte(loginData.Password)); err != nil {
c.JSON(http.StatusUnauthorized, gin.H{
"code": 401,
"message": "Invalid credentials",
})
return
}
// 获取用户的默认组织ID(如果没有关联组织,使用0)
var organizationID uint = 0
var userOrg model.UserOrganization
if err := h.db.Where("user_id = ?", user.ID).First(&userOrg).Error; err == nil {
organizationID = userOrg.OrganizationID
}
// 生成 JWT token
token, err := auth.GenerateToken(user.ID, user.Username, organizationID)
if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{
"code": 500,
"message": "Failed to generate token",
"error": err.Error(),
})
return
}
c.JSON(http.StatusOK, gin.H{
"code": 200,
"message": "Login successful",
"data": gin.H{
"token": token,
"user": user,
},
})
}