mirror of
https://github.com/wgh136/nysoure.git
synced 2025-09-27 12:17:24 +00:00
125 lines
2.8 KiB
Go
125 lines
2.8 KiB
Go
package dao
|
|
|
|
import (
|
|
"errors"
|
|
"gorm.io/gorm"
|
|
"nysoure/server/model"
|
|
)
|
|
|
|
func CreateUser(username string, hashedPassword []byte) (model.User, error) {
|
|
isEmpty, err := IsUserDataBaseEmpty()
|
|
if err != nil {
|
|
return model.User{}, err
|
|
}
|
|
user := model.User{
|
|
Username: username,
|
|
PasswordHash: hashedPassword,
|
|
IsAdmin: isEmpty,
|
|
}
|
|
exists, err := ExistsUser(username)
|
|
if err != nil {
|
|
return user, err
|
|
}
|
|
if exists {
|
|
return user, &model.RequestError{
|
|
Message: "User already exists",
|
|
}
|
|
}
|
|
if err := db.Create(&user).Error; err != nil {
|
|
return user, err
|
|
}
|
|
return user, nil
|
|
}
|
|
|
|
func ExistsUser(username string) (bool, error) {
|
|
var count int64
|
|
if err := db.Model(&model.User{}).Where("username = ?", username).Count(&count).Error; err != nil {
|
|
return false, err
|
|
}
|
|
return count > 0, nil
|
|
}
|
|
|
|
func ExistsUserByID(id uint) (bool, error) {
|
|
var count int64
|
|
if err := db.Model(&model.User{}).Where("id = ?", id).Count(&count).Error; err != nil {
|
|
return false, err
|
|
}
|
|
return count > 0, nil
|
|
}
|
|
|
|
func GetUserByUsername(username string) (model.User, error) {
|
|
var user model.User
|
|
if err := db.Where("username = ?", username).First(&user).Error; err != nil {
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
return user, model.NewNotFoundError("User not found")
|
|
}
|
|
return user, err
|
|
}
|
|
return user, nil
|
|
}
|
|
|
|
func GetUserByID(id uint) (model.User, error) {
|
|
var user model.User
|
|
if err := db.First(&user, id).Error; err != nil {
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
return user, model.NewNotFoundError("User not found")
|
|
}
|
|
return user, err
|
|
}
|
|
return user, nil
|
|
}
|
|
|
|
func UpdateUser(user model.User) error {
|
|
if err := db.Save(&user).Error; err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func IsUserDataBaseEmpty() (bool, error) {
|
|
var user model.User
|
|
if err := db.First(&user).Error; err != nil {
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
return true, nil
|
|
}
|
|
return false, err
|
|
}
|
|
return false, nil
|
|
}
|
|
|
|
func ListUsers(page, pageSize int) ([]model.User, int64, error) {
|
|
var users []model.User
|
|
var total int64
|
|
|
|
if err := db.Model(&model.User{}).Count(&total).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
offset := (page - 1) * pageSize
|
|
if err := db.Offset(offset).Limit(pageSize).Order("id desc").Find(&users).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
return users, total, nil
|
|
}
|
|
|
|
func SearchUsersByUsername(username string, page, pageSize int) ([]model.User, int64, error) {
|
|
var users []model.User
|
|
var total int64
|
|
|
|
if err := db.Model(&model.User{}).Where("username LIKE ?", "%"+username+"%").Count(&total).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
offset := (page - 1) * pageSize
|
|
if err := db.Where("username LIKE ?", "%"+username+"%").Offset(offset).Limit(pageSize).Order("id desc").Find(&users).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
return users, total, nil
|
|
}
|
|
|
|
func DeleteUser(id uint) error {
|
|
return db.Delete(&model.User{}, id).Error
|
|
}
|