Add station name as metric label (#3)

This commit is contained in:
Andreas B 2018-09-02 17:54:15 +02:00 committed by Robert Jacob
parent 3cd880a5c5
commit 4a463b65c4

View file

@ -20,6 +20,7 @@ var (
varLabels = []string{ varLabels = []string{
"module", "module",
"station",
} }
prefix = "netatmo_sensor_" prefix = "netatmo_sensor_"
@ -101,15 +102,16 @@ func (m *netatmoCollector) Collect(mChan chan<- prometheus.Metric) {
mChan <- netatmoUp mChan <- netatmoUp
for _, dev := range devices.Devices() { for _, dev := range devices.Devices() {
collectData(mChan, dev) stationName := dev.StationName
collectData(mChan, dev, stationName)
for _, module := range dev.LinkedModules { for _, module := range dev.LinkedModules {
collectData(mChan, module) collectData(mChan, module, stationName)
} }
} }
} }
func collectData(ch chan<- prometheus.Metric, device *netatmo.Device) { func collectData(ch chan<- prometheus.Metric, device *netatmo.Device, stationName string) {
moduleName := device.ModuleName moduleName := device.ModuleName
data := device.DashboardData data := device.DashboardData
@ -122,43 +124,43 @@ func collectData(ch chan<- prometheus.Metric, device *netatmo.Device) {
return return
} }
sendMetric(ch, updatedDesc, prometheus.CounterValue, float64(date.UTC().Unix()), moduleName) sendMetric(ch, updatedDesc, prometheus.CounterValue, float64(date.UTC().Unix()), moduleName, stationName)
if data.Temperature != nil { if data.Temperature != nil {
sendMetric(ch, tempDesc, prometheus.GaugeValue, float64(*data.Temperature), moduleName) sendMetric(ch, tempDesc, prometheus.GaugeValue, float64(*data.Temperature), moduleName, stationName)
} }
if data.Humidity != nil { if data.Humidity != nil {
sendMetric(ch, humidityDesc, prometheus.GaugeValue, float64(*data.Humidity), moduleName) sendMetric(ch, humidityDesc, prometheus.GaugeValue, float64(*data.Humidity), moduleName, stationName)
} }
if data.CO2 != nil { if data.CO2 != nil {
sendMetric(ch, cotwoDesc, prometheus.GaugeValue, float64(*data.CO2), moduleName) sendMetric(ch, cotwoDesc, prometheus.GaugeValue, float64(*data.CO2), moduleName, stationName)
} }
if data.Noise != nil { if data.Noise != nil {
sendMetric(ch, noiseDesc, prometheus.GaugeValue, float64(*data.Noise), moduleName) sendMetric(ch, noiseDesc, prometheus.GaugeValue, float64(*data.Noise), moduleName, stationName)
} }
if data.Pressure != nil { if data.Pressure != nil {
sendMetric(ch, pressureDesc, prometheus.GaugeValue, float64(*data.Pressure), moduleName) sendMetric(ch, pressureDesc, prometheus.GaugeValue, float64(*data.Pressure), moduleName, stationName)
} }
if data.WindStrength != nil { if data.WindStrength != nil {
sendMetric(ch, windStrengthDesc, prometheus.GaugeValue, float64(*data.WindStrength), moduleName) sendMetric(ch, windStrengthDesc, prometheus.GaugeValue, float64(*data.WindStrength), moduleName, stationName)
} }
if data.WindAngle != nil { if data.WindAngle != nil {
sendMetric(ch, windDirectionDesc, prometheus.GaugeValue, float64(*data.WindAngle), moduleName) sendMetric(ch, windDirectionDesc, prometheus.GaugeValue, float64(*data.WindAngle), moduleName, stationName)
} }
if data.Rain != nil { if data.Rain != nil {
sendMetric(ch, rainDesc, prometheus.GaugeValue, float64(*data.Rain), moduleName) sendMetric(ch, rainDesc, prometheus.GaugeValue, float64(*data.Rain), moduleName, stationName)
} }
} }
func sendMetric(ch chan<- prometheus.Metric, desc *prometheus.Desc, valueType prometheus.ValueType, value float64, moduleName string) { func sendMetric(ch chan<- prometheus.Metric, desc *prometheus.Desc, valueType prometheus.ValueType, value float64, moduleName string, stationName string) {
m, err := prometheus.NewConstMetric(desc, valueType, value, moduleName) m, err := prometheus.NewConstMetric(desc, valueType, value, moduleName, stationName)
if err != nil { if err != nil {
log.Printf("Error creating %s metric: %s", updatedDesc.String(), err) log.Printf("Error creating %s metric: %s", updatedDesc.String(), err)
} }