Files
projectx/internal/erpserver/store/system/user.go
2025-04-14 15:28:51 +08:00

111 lines
2.7 KiB
Go

package system
import (
"context"
"management/internal/db/model/dto"
"management/internal/erpserver/model/system"
"gorm.io/gorm"
)
// UserStore 定义了 user 模块在 store 层所实现的方法.
type UserStore interface {
Create(ctx context.Context, obj *system.User) error
Update(ctx context.Context, obj *system.User) error
Get(ctx context.Context, id int32) (*system.User, error)
GetByEmail(ctx context.Context, email string) (*system.User, error)
All(ctx context.Context) ([]*system.User, error)
List(ctx context.Context, q dto.SearchDto) ([]*system.User, int64, error)
UserExpansion
}
// UserExpansion 定义了用户操作的附加方法.
type UserExpansion interface{}
// userStore 是 UserStore 接口的实现.
type userStore struct {
db *gorm.DB
}
// 确保 userStore 实现了 UserStore 接口.
var _ UserStore = (*userStore)(nil)
// NewUserStore 创建 userStore 的实例.
func NewUserStore(db *gorm.DB) *userStore {
return &userStore{
db: db,
}
}
func (s *userStore) Create(ctx context.Context, obj *system.User) error {
return s.db.WithContext(ctx).Create(obj).Error
}
func (s *userStore) Update(ctx context.Context, obj *system.User) error {
return s.db.WithContext(ctx).Save(obj).Error
}
func (s *userStore) Get(ctx context.Context, id int32) (*system.User, error) {
var user system.User
err := s.db.WithContext(ctx).Where("id = ?", id).First(&user).Error
if err != nil {
return nil, err
}
return &user, nil
}
func (s *userStore) GetByEmail(ctx context.Context, email string) (*system.User, error) {
var user system.User
err := s.db.WithContext(ctx).Where("email = ?", email).First(&user).Error
if err != nil {
return nil, err
}
return &user, nil
}
func (s *userStore) All(ctx context.Context) ([]*system.User, error) {
var users []*system.User
err := s.db.WithContext(ctx).Find(&users).Error
if err != nil {
return nil, err
}
return users, nil
}
func (s *userStore) List(ctx context.Context, q dto.SearchDto) ([]*system.User, int64, error) {
query := s.db.WithContext(ctx).
Model(&system.User{}).
Where("created_at BETWEEN? AND?", q.SearchTimeBegin, q.SearchTimeEnd)
if q.SearchID != 0 {
query = query.Where("id = ?", q.SearchID)
}
if q.SearchName != "" {
query = query.Where("username LIKE ?", "%"+q.SearchName+"%")
}
if q.SearchEmail != "" {
query = query.Where("email LIKE ?", "%"+q.SearchEmail+"%")
}
if q.SearchStatus != 9999 {
query = query.Where("status = ?", q.SearchStatus)
}
var count int64
err := query.Count(&count).Error
if err != nil {
return nil, 0, err
}
var users []*system.User
err = query.
Order("id DESC").
Offset((q.Page - 1) * q.Rows).
Limit(q.Rows).
Find(&users).Error
if err != nil {
return nil, 0, err
}
return users, count, nil
}