48 lines
1.1 KiB
Go
48 lines
1.1 KiB
Go
package service
|
|
|
|
import (
|
|
"s-ui/database"
|
|
"s-ui/database/model"
|
|
"s-ui/logger"
|
|
"s-ui/util/common"
|
|
"time"
|
|
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type UserService struct {
|
|
}
|
|
|
|
func (s *UserService) Login(username string, password string, remoteIP string) (string, error) {
|
|
user := s.CheckUser(username, password, remoteIP)
|
|
if user == nil {
|
|
return "", common.NewError("wrong user or password! IP: ", remoteIP)
|
|
}
|
|
return user.Username, nil
|
|
}
|
|
|
|
func (s *UserService) CheckUser(username string, password string, remoteIP string) *model.User {
|
|
db := database.GetDB()
|
|
|
|
user := &model.User{}
|
|
err := db.Model(model.User{}).
|
|
Where("username = ? and password = ?", username, password).
|
|
First(user).
|
|
Error
|
|
if err == gorm.ErrRecordNotFound {
|
|
return nil
|
|
} else if err != nil {
|
|
logger.Warning("check user err:", err, " IP: ", remoteIP)
|
|
return nil
|
|
}
|
|
|
|
lastLoginTxt := time.Now().Format("2006-01-02 15:04:05") + "-" + remoteIP
|
|
err = db.Model(model.User{}).
|
|
Where("username = ?", username).
|
|
Update("last_logins", &lastLoginTxt).Error
|
|
if err != nil {
|
|
logger.Warning("unable to log login data", err)
|
|
}
|
|
return user
|
|
}
|