66 lines
1.5 KiB
Go
66 lines
1.5 KiB
Go
package repository
|
|
|
|
import (
|
|
"users_management/m/model/entity"
|
|
|
|
"github.com/google/uuid"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type TowerRepo interface {
|
|
Post(tower entity.Tower) error
|
|
GetAll() ([]entity.Tower, error)
|
|
Update(id uuid.UUID,updates map[string]interface{}) error
|
|
GetByID(id uuid.UUID) (entity.Tower, error)
|
|
CheckDeviceExists(deviceID uuid.UUID) (bool, error)
|
|
}
|
|
|
|
type towerRepo struct {
|
|
db *gorm.DB
|
|
}
|
|
|
|
func NewTowerRepo(db *gorm.DB) TowerRepo {
|
|
return &towerRepo{
|
|
db: db,
|
|
}
|
|
}
|
|
|
|
func (r *towerRepo) Post(tower entity.Tower) error {
|
|
err := r.db.Create(&tower).Error
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (r *towerRepo) GetAll() ([]entity.Tower, error) {
|
|
var towers []entity.Tower
|
|
// Chain debug methods
|
|
result := r.db.Preload("Device").Find(&towers)
|
|
if result.Error != nil {
|
|
return nil, result.Error
|
|
}
|
|
return towers, nil
|
|
}
|
|
|
|
func (r *towerRepo) CheckDeviceExists(deviceID uuid.UUID) (bool, error) {
|
|
var count int64
|
|
err := r.db.Model(&entity.Device{}).Where("id = ?", deviceID).Count(&count).Error
|
|
return count > 0, err
|
|
}
|
|
func (r *towerRepo) Update(id uuid.UUID,updates map[string]interface{}) error {
|
|
err := r.db.Model(&entity.Tower{}).Where("id = ?", id).Updates(updates).Error
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (r *towerRepo) GetByID(id uuid.UUID) (entity.Tower, error) {
|
|
var tower entity.Tower
|
|
err := r.db.Where("id = ?", id).Preload("Device").First(&tower).Error
|
|
if err != nil {
|
|
return tower, err
|
|
}
|
|
return tower, nil
|
|
} |