wlansta: Record wifi signal strength

signal-strength-ch0 is only accurate for devices with one antenna. Many
mikrotik devices have two, or even three channels, and just looking at ch0 is
not helpful in those cases.

Instead, look at the property 'signal-strength'. Annoyingly, it is does come as
a string with the negotiated bandwidth attached (e.g.,
signal-strength=-66dBm@HT20-7) which needs to be parsed out.
This commit is contained in:
Reinhard Tartler 2020-03-30 06:48:04 -04:00
parent 3b33400d24
commit aa5ef26ed3

View File

@ -21,7 +21,7 @@ func newWlanSTACollector() routerOSCollector {
} }
func (c *wlanSTACollector) init() { func (c *wlanSTACollector) init() {
c.props = []string{"interface", "mac-address", "signal-to-noise", "signal-strength-ch0", "packets", "bytes", "frames"} c.props = []string{"interface", "mac-address", "signal-to-noise", "signal-strength", "packets", "bytes", "frames"}
labelNames := []string{"name", "address", "interface", "mac_address"} labelNames := []string{"name", "address", "interface", "mac_address"}
c.descriptions = make(map[string]*prometheus.Desc) c.descriptions = make(map[string]*prometheus.Desc)
for _, p := range c.props[:len(c.props)-3] { for _, p := range c.props[:len(c.props)-3] {
@ -81,7 +81,12 @@ func (c *wlanSTACollector) collectMetricForProperty(property, iface, mac string,
if re.Map[property] == "" { if re.Map[property] == "" {
return return
} }
v, err := strconv.ParseFloat(re.Map[property], 64) p := re.Map[property]
i := strings.Index(p, "@")
if i > -1 {
p = p[:i]
}
v, err := strconv.ParseFloat(p, 64)
if err != nil { if err != nil {
log.WithFields(log.Fields{ log.WithFields(log.Fields{
"device": ctx.device.Name, "device": ctx.device.Name,