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
|
|
}
|