89 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package repository
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
 | 
						|
	"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
 | 
						|
	"gorm.io/gorm"
 | 
						|
)
 | 
						|
 | 
						|
// AreaControllerRepository 定义了对 AreaController 模型的数据库操作接口
 | 
						|
type AreaControllerRepository interface {
 | 
						|
	FindByID(id uint) (*models.AreaController, error)
 | 
						|
	FindByNetworkID(networkID string) (*models.AreaController, error)
 | 
						|
	Create(ac *models.AreaController) error
 | 
						|
	ListAll() ([]*models.AreaController, error)
 | 
						|
	Update(ac *models.AreaController) error
 | 
						|
	Delete(id uint) error
 | 
						|
}
 | 
						|
 | 
						|
// gormAreaControllerRepository 是 AreaControllerRepository 的 GORM 实现。
 | 
						|
type gormAreaControllerRepository struct {
 | 
						|
	db *gorm.DB
 | 
						|
}
 | 
						|
 | 
						|
// NewGormAreaControllerRepository 创建一个新的 AreaControllerRepository GORM 实现实例。
 | 
						|
func NewGormAreaControllerRepository(db *gorm.DB) AreaControllerRepository {
 | 
						|
	return &gormAreaControllerRepository{db: db}
 | 
						|
}
 | 
						|
 | 
						|
// Create 创建一个新的 AreaController 记录。
 | 
						|
func (r *gormAreaControllerRepository) Create(ac *models.AreaController) error {
 | 
						|
	return r.db.Create(ac).Error
 | 
						|
}
 | 
						|
 | 
						|
// ListAll 返回所有 AreaController 的列表。
 | 
						|
func (r *gormAreaControllerRepository) ListAll() ([]*models.AreaController, error) {
 | 
						|
	var areaControllers []*models.AreaController
 | 
						|
	if err := r.db.Find(&areaControllers).Error; err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return areaControllers, nil
 | 
						|
}
 | 
						|
 | 
						|
// Update 更新一个已存在的 AreaController 记录。
 | 
						|
func (r *gormAreaControllerRepository) Update(ac *models.AreaController) error {
 | 
						|
	return r.db.Save(ac).Error
 | 
						|
}
 | 
						|
 | 
						|
// Delete 删除一个 AreaController 记录。
 | 
						|
// 在删除前会检查是否有设备关联到该主控,如果有,则不允许删除。
 | 
						|
func (r *gormAreaControllerRepository) Delete(id uint) error {
 | 
						|
	return r.db.Transaction(func(tx *gorm.DB) error {
 | 
						|
		// 检查是否有设备关联到这个区域主控
 | 
						|
		var count int64
 | 
						|
		if err := tx.Model(&models.Device{}).Where("area_controller_id = ?", id).Count(&count).Error; err != nil {
 | 
						|
			return fmt.Errorf("检查关联设备失败: %w", err)
 | 
						|
		}
 | 
						|
 | 
						|
		if count > 0 {
 | 
						|
			return fmt.Errorf("无法删除区域主控,因为仍有 %d 个设备关联到它", count)
 | 
						|
		}
 | 
						|
 | 
						|
		// 如果没有关联设备,则执行删除操作
 | 
						|
		if err := tx.Delete(&models.AreaController{}, id).Error; err != nil {
 | 
						|
			return fmt.Errorf("删除区域主控失败: %w", err)
 | 
						|
		}
 | 
						|
 | 
						|
		return nil
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// FindByID 通过 ID 查找一个 AreaController。
 | 
						|
func (r *gormAreaControllerRepository) FindByID(id uint) (*models.AreaController, error) {
 | 
						|
	var areaController models.AreaController
 | 
						|
	if err := r.db.First(&areaController, id).Error; err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return &areaController, nil
 | 
						|
}
 | 
						|
 | 
						|
// FindByNetworkID 通过 NetworkID 查找一个 AreaController。
 | 
						|
func (r *gormAreaControllerRepository) FindByNetworkID(networkID string) (*models.AreaController, error) {
 | 
						|
	var areaController models.AreaController
 | 
						|
	if err := r.db.Where("network_id = ?", networkID).First(&areaController).Error; err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	return &areaController, nil
 | 
						|
}
 |