fixed firmware collector for multiple devices with same packages

This commit is contained in:
oGi4i 2020-12-08 21:31:12 +03:00
parent d3285ba301
commit 25dc6b22ec

View File

@ -19,7 +19,7 @@ func newFirmwareCollector() routerOSCollector {
} }
func (c *firmwareCollector) init() { func (c *firmwareCollector) init() {
labelNames := []string{"name", "disabled", "version", "build_time"} labelNames := []string{"devicename", "name", "disabled", "version", "build_time"}
c.description = description("system", "package", "system packages version", labelNames) c.description = description("system", "package", "system packages version", labelNames)
} }
@ -41,10 +41,10 @@ func (c *firmwareCollector) collect(ctx *collectorContext) error {
for _, pkg := range pkgs { for _, pkg := range pkgs {
v := 1.0 v := 1.0
if strings.Compare(pkg.Map["disabled"], "true") == 0 { if strings.EqualFold(pkg.Map["disabled"], "true") {
v = 0.0 v = 0.0
} }
ctx.ch <- prometheus.MustNewConstMetric(c.description, prometheus.GaugeValue, v, pkg.Map["name"], pkg.Map["disabled"], pkg.Map["version"], pkg.Map["build-time"]) ctx.ch <- prometheus.MustNewConstMetric(c.description, prometheus.GaugeValue, v, ctx.device.Name, pkg.Map["name"], pkg.Map["disabled"], pkg.Map["version"], pkg.Map["build-time"])
} }
return nil return nil