77 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Package repository 提供了数据访问的仓库实现
 | |
| package repository
 | |
| 
 | |
| import (
 | |
| 	"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
 | |
| 	"gorm.io/gorm"
 | |
| )
 | |
| 
 | |
| // UserRepository 定义了与用户模型相关的数据库操作接口
 | |
| // 这是为了让业务逻辑层依赖于抽象,而不是具体的数据库实现
 | |
| type UserRepository interface {
 | |
| 	Create(user *models.User) error
 | |
| 	FindByUsername(username string) (*models.User, error)
 | |
| 	FindByID(id uint) (*models.User, error)
 | |
| 	FindUserForLogin(identifier string) (*models.User, error)
 | |
| 	FindAll() ([]*models.User, error)
 | |
| }
 | |
| 
 | |
| // gormUserRepository 是 UserRepository 的 GORM 实现
 | |
| type gormUserRepository struct {
 | |
| 	db *gorm.DB
 | |
| }
 | |
| 
 | |
| // NewGormUserRepository 创建一个新的 UserRepository GORM 实现实例
 | |
| func NewGormUserRepository(db *gorm.DB) UserRepository {
 | |
| 	return &gormUserRepository{db: db}
 | |
| }
 | |
| 
 | |
| // Create 创建一个新的用户记录
 | |
| func (r *gormUserRepository) Create(user *models.User) error {
 | |
| 	// BeforeSave 钩子会在这里被自动触发
 | |
| 	return r.db.Create(user).Error
 | |
| }
 | |
| 
 | |
| // FindByUsername 根据用户名查找用户
 | |
| func (r *gormUserRepository) FindByUsername(username string) (*models.User, error) {
 | |
| 	var user models.User
 | |
| 	if err := r.db.Where("username = ?", username).First(&user).Error; err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &user, nil
 | |
| }
 | |
| 
 | |
| // FindUserForLogin 根据提供的标识符查找用户,可用于登录验证
 | |
| // 标识符可以是用户名、邮箱、手机号、微信号或飞书账号
 | |
| func (r *gormUserRepository) FindUserForLogin(identifier string) (*models.User, error) {
 | |
| 	var user models.User
 | |
| 	// 使用 ->> 操作符来查询 JSONB 字段中的文本值
 | |
| 	err := r.db.Where(
 | |
| 		"username = ? OR contact ->> 'email' = ? OR contact ->> 'phone' = ? OR contact ->> 'wechat' = ? OR contact ->> 'feishu' = ?",
 | |
| 		identifier, identifier, identifier, identifier, identifier,
 | |
| 	).First(&user).Error
 | |
| 
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &user, nil
 | |
| }
 | |
| 
 | |
| // FindByID 根据 ID 查找用户
 | |
| func (r *gormUserRepository) FindByID(id uint) (*models.User, error) {
 | |
| 	var user models.User
 | |
| 	if err := r.db.First(&user, id).Error; err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &user, nil
 | |
| }
 | |
| 
 | |
| // FindAll 返回数据库中的所有用户
 | |
| func (r *gormUserRepository) FindAll() ([]*models.User, error) {
 | |
| 	var users []*models.User
 | |
| 	if err := r.db.Where("1 = 1").Find(&users).Error; err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return users, nil
 | |
| }
 |