f823127825
Ensure logger creation is consistent between Web and Collector Create logger in main, pass down to downstream functions (like gin) In debug mode, print a copy of AppConfig Better debugging for logger.
54 lines
1.6 KiB
Go
54 lines
1.6 KiB
Go
package handler
|
|
|
|
import (
|
|
"github.com/analogj/scrutiny/webapp/backend/pkg/database"
|
|
"github.com/analogj/scrutiny/webapp/backend/pkg/models"
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/samber/lo"
|
|
"github.com/sirupsen/logrus"
|
|
"net/http"
|
|
)
|
|
|
|
// register devices that are detected by various collectors.
|
|
// This function is run everytime a collector is about to start a run. It can be used to update device metadata.
|
|
func RegisterDevices(c *gin.Context) {
|
|
deviceRepo := c.MustGet("DEVICE_REPOSITORY").(database.DeviceRepo)
|
|
logger := c.MustGet("LOGGER").(*logrus.Entry)
|
|
|
|
var collectorDeviceWrapper models.DeviceWrapper
|
|
err := c.BindJSON(&collectorDeviceWrapper)
|
|
if err != nil {
|
|
logger.Errorln("Cannot parse detected devices", err)
|
|
c.JSON(http.StatusInternalServerError, gin.H{"success": false})
|
|
return
|
|
}
|
|
|
|
//filter any device with empty wwn (they are invalid)
|
|
detectedStorageDevices := lo.Filter[models.Device](collectorDeviceWrapper.Data, func(dev models.Device, _ int) bool {
|
|
return len(dev.WWN) > 0
|
|
})
|
|
|
|
errs := []error{}
|
|
for _, dev := range detectedStorageDevices {
|
|
//insert devices into DB (and update specified columns if device is already registered)
|
|
// update device fields that may change: (DeviceType, HostID)
|
|
if err := deviceRepo.RegisterDevice(c, dev); err != nil {
|
|
errs = append(errs, err)
|
|
}
|
|
}
|
|
|
|
if len(errs) > 0 {
|
|
logger.Errorln("An error occurred while registering devices", errs)
|
|
c.JSON(http.StatusInternalServerError, gin.H{
|
|
"success": false,
|
|
})
|
|
return
|
|
} else {
|
|
c.JSON(http.StatusOK, models.DeviceWrapper{
|
|
Success: true,
|
|
Data: detectedStorageDevices,
|
|
})
|
|
return
|
|
}
|
|
}
|