mirror of
https://github.com/nshttpd/mikrotik-exporter.git
synced 2025-01-21 20:41:45 +01:00
beb09ce540
* fix import name conflict * adding in ethernet monitor information via prometheus gauge * set CGO_ENABLED env var on build
46 lines
977 B
Go
46 lines
977 B
Go
package collector
|
|
|
|
import (
|
|
"math"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
)
|
|
|
|
func metricStringCleanup(in string) string {
|
|
return strings.Replace(in, "-", "_", -1)
|
|
}
|
|
|
|
func descriptionForPropertyName(prefix, property string, labelNames []string) *prometheus.Desc {
|
|
return prometheus.NewDesc(
|
|
prometheus.BuildFQName(namespace, prefix, metricStringCleanup(property)),
|
|
property,
|
|
labelNames,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func description(prefix, name, helpText string, labelNames []string) *prometheus.Desc {
|
|
return prometheus.NewDesc(
|
|
prometheus.BuildFQName(namespace, prefix, name),
|
|
helpText,
|
|
labelNames,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func splitStringToFloats(metric string) (float64, float64, error) {
|
|
strs := strings.Split(metric, ",")
|
|
|
|
m1, err := strconv.ParseFloat(strs[0], 64)
|
|
if err != nil {
|
|
return math.NaN(), math.NaN(), err
|
|
}
|
|
m2, err := strconv.ParseFloat(strs[1], 64)
|
|
if err != nil {
|
|
return math.NaN(), math.NaN(), err
|
|
}
|
|
return m1, m2, nil
|
|
}
|