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() {
labelNames := []string{"name", "disabled", "version", "build_time"}
labelNames := []string{"devicename", "name", "disabled", "version", "build_time"}
c.description = description("system", "package", "system packages version", labelNames)
}
@ -41,10 +41,10 @@ func (c *firmwareCollector) collect(ctx *collectorContext) error {
for _, pkg := range pkgs {
v := 1.0
if strings.Compare(pkg.Map["disabled"], "true") == 0 {
if strings.EqualFold(pkg.Map["disabled"], "true") {
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