162 lines
4.2 KiB
Go
162 lines
4.2 KiB
Go
package service
|
|
|
|
import (
|
|
"encoding/json"
|
|
"time"
|
|
|
|
"github.com/alireza0/s-ui/database"
|
|
"github.com/alireza0/s-ui/database/model"
|
|
"github.com/alireza0/s-ui/logger"
|
|
"github.com/alireza0/s-ui/util/common"
|
|
)
|
|
|
|
type UserService struct {
|
|
}
|
|
|
|
func (s *UserService) GetFirstUser() (*model.User, error) {
|
|
db := database.GetDB()
|
|
|
|
user := &model.User{}
|
|
err := db.Model(model.User{}).
|
|
First(user).
|
|
Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return user, nil
|
|
}
|
|
|
|
func (s *UserService) UpdateFirstUser(username string, password string) error {
|
|
if username == "" {
|
|
return common.NewError("username can not be empty")
|
|
} else if password == "" {
|
|
return common.NewError("password can not be empty")
|
|
}
|
|
db := database.GetDB()
|
|
user := &model.User{}
|
|
err := db.Model(model.User{}).First(user).Error
|
|
if database.IsNotFound(err) {
|
|
user.Username = username
|
|
user.Password = password
|
|
return db.Model(model.User{}).Create(user).Error
|
|
} else if err != nil {
|
|
return err
|
|
}
|
|
user.Username = username
|
|
user.Password = password
|
|
return db.Save(user).Error
|
|
}
|
|
|
|
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 database.IsNotFound(err) {
|
|
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
|
|
}
|
|
|
|
func (s *UserService) GetUsers() (*[]model.User, error) {
|
|
var users []model.User
|
|
db := database.GetDB()
|
|
err := db.Model(model.User{}).Select("id,username,last_logins").Scan(&users).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &users, nil
|
|
}
|
|
|
|
func (s *UserService) ChangePass(id string, oldPass string, newUser string, newPass string) error {
|
|
db := database.GetDB()
|
|
user := &model.User{}
|
|
err := db.Model(model.User{}).Where("id = ? AND password = ?", id, oldPass).First(user).Error
|
|
if err != nil || database.IsNotFound(err) {
|
|
return err
|
|
}
|
|
user.Username = newUser
|
|
user.Password = newPass
|
|
return db.Save(user).Error
|
|
}
|
|
|
|
func (s *UserService) LoadTokens() ([]byte, error) {
|
|
db := database.GetDB()
|
|
var tokens []model.Tokens
|
|
err := db.Model(model.Tokens{}).Preload("User").Where("expiry == 0 or expiry > ?", time.Now().Unix()).Find(&tokens).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var result []map[string]interface{}
|
|
for _, t := range tokens {
|
|
result = append(result, map[string]interface{}{
|
|
"token": t.Token,
|
|
"expiry": t.Expiry,
|
|
"username": t.User.Username,
|
|
})
|
|
}
|
|
jsonResult, _ := json.MarshalIndent(result, "", " ")
|
|
return jsonResult, nil
|
|
}
|
|
|
|
func (s *UserService) GetUserTokens(username string) (*[]model.Tokens, error) {
|
|
db := database.GetDB()
|
|
var token []model.Tokens
|
|
err := db.Model(model.Tokens{}).Select("id,desc,'****' as token,expiry,user_id").Where("user_id = (select id from users where username = ?)", username).Find(&token).Error
|
|
if err != nil && !database.IsNotFound(err) {
|
|
println(err.Error())
|
|
return nil, err
|
|
}
|
|
return &token, nil
|
|
}
|
|
|
|
func (s *UserService) AddToken(username string, expiry int64, desc string) (string, error) {
|
|
db := database.GetDB()
|
|
var userId uint
|
|
err := db.Model(model.User{}).Where("username = ?", username).Select("id").Scan(&userId).Error
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
if expiry > 0 {
|
|
expiry = expiry*86400 + time.Now().Unix()
|
|
}
|
|
token := &model.Tokens{
|
|
Token: common.Random(32),
|
|
Desc: desc,
|
|
Expiry: expiry,
|
|
UserId: userId,
|
|
}
|
|
err = db.Create(token).Error
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return token.Token, nil
|
|
}
|
|
|
|
func (s *UserService) DeleteToken(id string) error {
|
|
db := database.GetDB()
|
|
return db.Model(model.Tokens{}).Where("id = ?", id).Delete(&model.Tokens{}).Error
|
|
}
|