mirror of
https://git.rwth-aachen.de/acs/public/villas/web-backend-go/
synced 2025-03-30 00:00:12 +01:00
73 lines
1.4 KiB
Go
73 lines
1.4 KiB
Go
package dashboard
|
|
|
|
import (
|
|
"git.rwth-aachen.de/acs/public/villas/web-backend-go/database"
|
|
"git.rwth-aachen.de/acs/public/villas/web-backend-go/routes/scenario"
|
|
)
|
|
|
|
type Dashboard struct {
|
|
database.Dashboard
|
|
}
|
|
|
|
func (v *Dashboard) save() error {
|
|
db := database.GetDB()
|
|
err := db.Create(v).Error
|
|
return err
|
|
}
|
|
|
|
func (d *Dashboard) ByID(id uint) error {
|
|
db := database.GetDB()
|
|
err := db.Find(d, id).Error
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (d *Dashboard) addToScenario() error {
|
|
db := database.GetDB()
|
|
var sim scenario.Scenario
|
|
err := sim.ByID(d.ScenarioID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// save dashboard to DB
|
|
err = d.save()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// associate dashboard with scenario
|
|
err = db.Model(&sim).Association("Dashboards").Append(d).Error
|
|
|
|
return err
|
|
}
|
|
|
|
func (d *Dashboard) update(modifiedDab Dashboard) error {
|
|
|
|
db := database.GetDB()
|
|
|
|
err := db.Model(d).Updates(map[string]interface{}{
|
|
"Name": modifiedDab.Name,
|
|
"Grid": modifiedDab.Grid,
|
|
}).Error
|
|
|
|
return err
|
|
}
|
|
|
|
func (d *Dashboard) delete() error {
|
|
|
|
db := database.GetDB()
|
|
var sim scenario.Scenario
|
|
err := sim.ByID(d.ScenarioID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// remove association between Dashboard and Scenario
|
|
// Dashboard itself is not deleted from DB, it remains as "dangling"
|
|
err = db.Model(&sim).Association("Dashboards").Delete(d).Error
|
|
|
|
return err
|
|
}
|