prom and influx support
This commit is contained in:
parent
0ab3de2ec4
commit
26e2771229
|
|
@ -368,6 +368,8 @@ func (u *InfluxUnifi) switchExport(r report, v any) { //nolint:cyclop
|
||||||
u.batchUAP(r, v)
|
u.batchUAP(r, v)
|
||||||
case *unifi.USW:
|
case *unifi.USW:
|
||||||
u.batchUSW(r, v)
|
u.batchUSW(r, v)
|
||||||
|
case *unifi.PDU:
|
||||||
|
u.batchPDU(r, v)
|
||||||
case *unifi.USG:
|
case *unifi.USG:
|
||||||
u.batchUSG(r, v)
|
u.batchUSG(r, v)
|
||||||
case *unifi.UXG:
|
case *unifi.UXG:
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,120 @@
|
||||||
|
package influxunifi
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/unpoller/unifi"
|
||||||
|
)
|
||||||
|
|
||||||
|
// pduT is used as a name for printed/logged counters.
|
||||||
|
const pduT = item("PDU")
|
||||||
|
|
||||||
|
// batchPDU generates Unifi PDU data points for InfluxDB.
|
||||||
|
// These points can be passed directly to influx.
|
||||||
|
func (u *InfluxUnifi) batchPDU(r report, s *unifi.PDU) {
|
||||||
|
if !s.Adopted.Val || s.Locating.Val {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
tags := map[string]string{
|
||||||
|
"mac": s.Mac,
|
||||||
|
"site_name": s.SiteName,
|
||||||
|
"source": s.SourceName,
|
||||||
|
"name": s.Name,
|
||||||
|
"version": s.Version,
|
||||||
|
"model": s.Model,
|
||||||
|
"serial": s.Serial,
|
||||||
|
"type": s.Type,
|
||||||
|
}
|
||||||
|
fields := Combine(
|
||||||
|
u.batchPDUstat(s.Stat.Sw),
|
||||||
|
u.batchSysStats(s.SysStats, s.SystemStats),
|
||||||
|
map[string]any{
|
||||||
|
"guest-num_sta": s.GuestNumSta.Val,
|
||||||
|
"ip": s.IP,
|
||||||
|
"bytes": s.Bytes.Val,
|
||||||
|
"last_seen": s.LastSeen.Val,
|
||||||
|
"rx_bytes": s.RxBytes.Val,
|
||||||
|
"tx_bytes": s.TxBytes.Val,
|
||||||
|
"uptime": s.Uptime.Val,
|
||||||
|
"state": s.State.Val,
|
||||||
|
"user-num_sta": s.UserNumSta.Val,
|
||||||
|
"upgradeable": s.Upgradeable.Val,
|
||||||
|
"outlet_ac_power_budget": s.OutletACPowerBudget.Val,
|
||||||
|
"outlet_ac_power_consumption": s.OutletACPowerConsumption.Val,
|
||||||
|
"outlet_enabled": s.OutletEnabled.Val,
|
||||||
|
"overheating": s.Overheating.Val,
|
||||||
|
"power_source": s.PowerSource.Val,
|
||||||
|
"total_max_power": s.TotalMaxPower.Val,
|
||||||
|
})
|
||||||
|
|
||||||
|
r.addCount(pduT)
|
||||||
|
r.send(&metric{Table: "pdu", Tags: tags, Fields: fields})
|
||||||
|
u.batchPortTable(r, tags, s.PortTable)
|
||||||
|
|
||||||
|
for _, oo := range s.OutletOverrides {
|
||||||
|
oot := cleanTags(map[string]string{
|
||||||
|
"mac": s.Mac,
|
||||||
|
"site_name": s.SiteName,
|
||||||
|
"source": s.SourceName,
|
||||||
|
"name": s.Name,
|
||||||
|
"version": s.Version,
|
||||||
|
"model": s.Model,
|
||||||
|
"serial": s.Serial,
|
||||||
|
"type": s.Type,
|
||||||
|
"ip": s.IP,
|
||||||
|
"outlet_index": oo.Index.Txt,
|
||||||
|
"outlet_name": oo.Name,
|
||||||
|
})
|
||||||
|
ood := map[string]any{
|
||||||
|
"cycle_enabled": oo.CycleEnabled.Val,
|
||||||
|
"relay_state": oo.RelayState.Val,
|
||||||
|
}
|
||||||
|
r.send(&metric{Table: "pdu.outlet_overrides", Tags: oot, Fields: ood})
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, ot := range s.OutletTable {
|
||||||
|
ott := cleanTags(map[string]string{
|
||||||
|
"mac": s.Mac,
|
||||||
|
"site_name": s.SiteName,
|
||||||
|
"source": s.SourceName,
|
||||||
|
"name": s.Name,
|
||||||
|
"version": s.Version,
|
||||||
|
"model": s.Model,
|
||||||
|
"serial": s.Serial,
|
||||||
|
"type": s.Type,
|
||||||
|
"ip": s.IP,
|
||||||
|
"outlet_index": ot.Index.Txt,
|
||||||
|
"outlet_name": ot.Name,
|
||||||
|
})
|
||||||
|
otd := map[string]any{
|
||||||
|
"cycle_enabled": ot.CycleEnabled.Val,
|
||||||
|
"relay_state": ot.RelayState.Val,
|
||||||
|
"outlet_caps": ot.OutletCaps.Val,
|
||||||
|
"outlet_power_factor": ot.OutletPowerFactor.Val,
|
||||||
|
"outlet_current": ot.OutletCurrent.Val,
|
||||||
|
"outlet_power": ot.OutletPower.Val,
|
||||||
|
"outlet_voltage": ot.OutletVoltage.Val,
|
||||||
|
}
|
||||||
|
r.send(&metric{Table: "pdu.outlet_table", Tags: ott, Fields: otd})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (u *InfluxUnifi) batchPDUstat(sw *unifi.Sw) map[string]any {
|
||||||
|
if sw == nil {
|
||||||
|
return map[string]any{}
|
||||||
|
}
|
||||||
|
|
||||||
|
return map[string]any{
|
||||||
|
"stat_bytes": sw.Bytes.Val,
|
||||||
|
"stat_rx_bytes": sw.RxBytes.Val,
|
||||||
|
"stat_rx_crypts": sw.RxCrypts.Val,
|
||||||
|
"stat_rx_dropped": sw.RxDropped.Val,
|
||||||
|
"stat_rx_errors": sw.RxErrors.Val,
|
||||||
|
"stat_rx_frags": sw.RxFrags.Val,
|
||||||
|
"stat_rx_packets": sw.TxPackets.Val,
|
||||||
|
"stat_tx_bytes": sw.TxBytes.Val,
|
||||||
|
"stat_tx_dropped": sw.TxDropped.Val,
|
||||||
|
"stat_tx_errors": sw.TxErrors.Val,
|
||||||
|
"stat_tx_packets": sw.TxPackets.Val,
|
||||||
|
"stat_tx_retries": sw.TxRetries.Val,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -39,6 +39,7 @@ type promUnifi struct {
|
||||||
UAP *uap
|
UAP *uap
|
||||||
USG *usg
|
USG *usg
|
||||||
USW *usw
|
USW *usw
|
||||||
|
PDU *pdu
|
||||||
Site *site
|
Site *site
|
||||||
RogueAP *rogueap
|
RogueAP *rogueap
|
||||||
// This interface is passed to the Collect() method. The Collect method uses
|
// This interface is passed to the Collect() method. The Collect method uses
|
||||||
|
|
@ -85,6 +86,7 @@ type Report struct {
|
||||||
Zeros int // Total count of metrics equal to zero.
|
Zeros int // Total count of metrics equal to zero.
|
||||||
USG int // Total count of USG devices.
|
USG int // Total count of USG devices.
|
||||||
USW int // Total count of USW devices.
|
USW int // Total count of USW devices.
|
||||||
|
PDU int // Total count of PDU devices.
|
||||||
UAP int // Total count of UAP devices.
|
UAP int // Total count of UAP devices.
|
||||||
UDM int // Total count of UDM devices.
|
UDM int // Total count of UDM devices.
|
||||||
UXG int // Total count of UXG devices.
|
UXG int // Total count of UXG devices.
|
||||||
|
|
@ -152,6 +154,7 @@ func (u *promUnifi) Run(c poller.Collect) error {
|
||||||
u.UAP = descUAP(u.Namespace + "_device_")
|
u.UAP = descUAP(u.Namespace + "_device_")
|
||||||
u.USG = descUSG(u.Namespace + "_device_")
|
u.USG = descUSG(u.Namespace + "_device_")
|
||||||
u.USW = descUSW(u.Namespace + "_device_")
|
u.USW = descUSW(u.Namespace + "_device_")
|
||||||
|
u.PDU = descPDU(u.Namespace + "_device_")
|
||||||
u.Site = descSite(u.Namespace + "_site_")
|
u.Site = descSite(u.Namespace + "_site_")
|
||||||
u.RogueAP = descRogueAP(u.Namespace + "_rogueap_")
|
u.RogueAP = descRogueAP(u.Namespace + "_rogueap_")
|
||||||
|
|
||||||
|
|
@ -235,7 +238,7 @@ func (t *target) Describe(ch chan<- *prometheus.Desc) {
|
||||||
// Describe satisfies the prometheus Collector. This returns all of the
|
// Describe satisfies the prometheus Collector. This returns all of the
|
||||||
// metric descriptions that this packages produces.
|
// metric descriptions that this packages produces.
|
||||||
func (u *promUnifi) Describe(ch chan<- *prometheus.Desc) {
|
func (u *promUnifi) Describe(ch chan<- *prometheus.Desc) {
|
||||||
for _, f := range []any{u.Client, u.Device, u.UAP, u.USG, u.USW, u.Site} {
|
for _, f := range []any{u.Client, u.Device, u.UAP, u.USG, u.USW, u.PDU, u.Site} {
|
||||||
v := reflect.Indirect(reflect.ValueOf(f))
|
v := reflect.Indirect(reflect.ValueOf(f))
|
||||||
|
|
||||||
// Loop each struct member and send it to the provided channel.
|
// Loop each struct member and send it to the provided channel.
|
||||||
|
|
@ -357,6 +360,9 @@ func (u *promUnifi) switchExport(r report, v any) {
|
||||||
case *unifi.USW:
|
case *unifi.USW:
|
||||||
r.addUSW()
|
r.addUSW()
|
||||||
u.exportUSW(r, v)
|
u.exportUSW(r, v)
|
||||||
|
case *unifi.PDU:
|
||||||
|
r.addPDU()
|
||||||
|
u.exportPDU(r, v)
|
||||||
case *unifi.USG:
|
case *unifi.USG:
|
||||||
r.addUSG()
|
r.addUSG()
|
||||||
u.exportUSG(r, v)
|
u.exportUSG(r, v)
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,276 @@
|
||||||
|
package promunifi
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/unpoller/unifi"
|
||||||
|
)
|
||||||
|
|
||||||
|
type pdu struct {
|
||||||
|
// Switch "total" traffic stats
|
||||||
|
SwRxPackets *prometheus.Desc
|
||||||
|
SwRxBytes *prometheus.Desc
|
||||||
|
SwRxErrors *prometheus.Desc
|
||||||
|
SwRxDropped *prometheus.Desc
|
||||||
|
SwRxCrypts *prometheus.Desc
|
||||||
|
SwRxFrags *prometheus.Desc
|
||||||
|
SwTxPackets *prometheus.Desc
|
||||||
|
SwTxBytes *prometheus.Desc
|
||||||
|
SwTxErrors *prometheus.Desc
|
||||||
|
SwTxDropped *prometheus.Desc
|
||||||
|
SwTxRetries *prometheus.Desc
|
||||||
|
SwRxMulticast *prometheus.Desc
|
||||||
|
SwRxBroadcast *prometheus.Desc
|
||||||
|
SwTxMulticast *prometheus.Desc
|
||||||
|
SwTxBroadcast *prometheus.Desc
|
||||||
|
SwBytes *prometheus.Desc
|
||||||
|
// Port data.
|
||||||
|
PoeCurrent *prometheus.Desc
|
||||||
|
PoePower *prometheus.Desc
|
||||||
|
PoeVoltage *prometheus.Desc
|
||||||
|
RxBroadcast *prometheus.Desc
|
||||||
|
RxBytes *prometheus.Desc
|
||||||
|
RxBytesR *prometheus.Desc
|
||||||
|
RxDropped *prometheus.Desc
|
||||||
|
RxErrors *prometheus.Desc
|
||||||
|
RxMulticast *prometheus.Desc
|
||||||
|
RxPackets *prometheus.Desc
|
||||||
|
Satisfaction *prometheus.Desc
|
||||||
|
Speed *prometheus.Desc
|
||||||
|
TxBroadcast *prometheus.Desc
|
||||||
|
TxBytes *prometheus.Desc
|
||||||
|
TxBytesR *prometheus.Desc
|
||||||
|
TxDropped *prometheus.Desc
|
||||||
|
TxErrors *prometheus.Desc
|
||||||
|
TxMulticast *prometheus.Desc
|
||||||
|
TxPackets *prometheus.Desc
|
||||||
|
SFPCurrent *prometheus.Desc
|
||||||
|
SFPRxPower *prometheus.Desc
|
||||||
|
SFPTemperature *prometheus.Desc
|
||||||
|
SFPTxPower *prometheus.Desc
|
||||||
|
SFPVoltage *prometheus.Desc
|
||||||
|
// other
|
||||||
|
Upgradeable *prometheus.Desc
|
||||||
|
// power
|
||||||
|
CycleEnabled *prometheus.Desc
|
||||||
|
RelayState *prometheus.Desc
|
||||||
|
OutletCaps *prometheus.Desc
|
||||||
|
OutletCurrent *prometheus.Desc
|
||||||
|
OutletPower *prometheus.Desc
|
||||||
|
OutletPowerFactor *prometheus.Desc
|
||||||
|
OutletVoltage *prometheus.Desc
|
||||||
|
}
|
||||||
|
|
||||||
|
func descPDU(ns string) *pdu {
|
||||||
|
pns := ns + "port_"
|
||||||
|
sfp := pns + "sfp_"
|
||||||
|
labelS := []string{"site_name", "name", "source"}
|
||||||
|
labelP := []string{"port_id", "port_num", "port_name", "port_mac", "port_ip", "site_name", "name", "source"}
|
||||||
|
labelF := []string{
|
||||||
|
"sfp_part", "sfp_vendor", "sfp_serial", "sfp_compliance",
|
||||||
|
"port_id", "port_num", "port_name", "port_mac", "port_ip", "site_name", "name", "source",
|
||||||
|
}
|
||||||
|
nd := prometheus.NewDesc
|
||||||
|
|
||||||
|
return &pdu{
|
||||||
|
// This data may be derivable by sum()ing the port data.
|
||||||
|
SwRxPackets: nd(ns+"switch_receive_packets_total", "Switch Packets Received Total", labelS, nil),
|
||||||
|
SwRxBytes: nd(ns+"switch_receive_bytes_total", "Switch Bytes Received Total", labelS, nil),
|
||||||
|
SwRxErrors: nd(ns+"switch_receive_errors_total", "Switch Errors Received Total", labelS, nil),
|
||||||
|
SwRxDropped: nd(ns+"switch_receive_dropped_total", "Switch Dropped Received Total", labelS, nil),
|
||||||
|
SwRxCrypts: nd(ns+"switch_receive_crypts_total", "Switch Crypts Received Total", labelS, nil),
|
||||||
|
SwRxFrags: nd(ns+"switch_receive_frags_total", "Switch Frags Received Total", labelS, nil),
|
||||||
|
SwTxPackets: nd(ns+"switch_transmit_packets_total", "Switch Packets Transmit Total", labelS, nil),
|
||||||
|
SwTxBytes: nd(ns+"switch_transmit_bytes_total", "Switch Bytes Transmit Total", labelS, nil),
|
||||||
|
SwTxErrors: nd(ns+"switch_transmit_errors_total", "Switch Errors Transmit Total", labelS, nil),
|
||||||
|
SwTxDropped: nd(ns+"switch_transmit_dropped_total", "Switch Dropped Transmit Total", labelS, nil),
|
||||||
|
SwTxRetries: nd(ns+"switch_transmit_retries_total", "Switch Retries Transmit Total", labelS, nil),
|
||||||
|
SwRxMulticast: nd(ns+"switch_receive_multicast_total", "Switch Multicast Receive Total", labelS, nil),
|
||||||
|
SwRxBroadcast: nd(ns+"switch_receive_broadcast_total", "Switch Broadcast Receive Total", labelS, nil),
|
||||||
|
SwTxMulticast: nd(ns+"switch_transmit_multicast_total", "Switch Multicast Transmit Total", labelS, nil),
|
||||||
|
SwTxBroadcast: nd(ns+"switch_transmit_broadcast_total", "Switch Broadcast Transmit Total", labelS, nil),
|
||||||
|
SwBytes: nd(ns+"switch_bytes_total", "Switch Bytes Transferred Total", labelS, nil),
|
||||||
|
// per-port data
|
||||||
|
PoeCurrent: nd(pns+"poe_amperes", "POE Current", labelP, nil),
|
||||||
|
PoePower: nd(pns+"poe_watts", "POE Power", labelP, nil),
|
||||||
|
PoeVoltage: nd(pns+"poe_volts", "POE Voltage", labelP, nil),
|
||||||
|
RxBroadcast: nd(pns+"receive_broadcast_total", "Receive Broadcast", labelP, nil),
|
||||||
|
RxBytes: nd(pns+"receive_bytes_total", "Total Receive Bytes", labelP, nil),
|
||||||
|
RxBytesR: nd(pns+"receive_rate_bytes", "Receive Bytes Rate", labelP, nil),
|
||||||
|
RxDropped: nd(pns+"receive_dropped_total", "Total Receive Dropped", labelP, nil),
|
||||||
|
RxErrors: nd(pns+"receive_errors_total", "Total Receive Errors", labelP, nil),
|
||||||
|
RxMulticast: nd(pns+"receive_multicast_total", "Total Receive Multicast", labelP, nil),
|
||||||
|
RxPackets: nd(pns+"receive_packets_total", "Total Receive Packets", labelP, nil),
|
||||||
|
Satisfaction: nd(pns+"satisfaction_ratio", "Satisfaction", labelP, nil),
|
||||||
|
Speed: nd(pns+"port_speed_bps", "Speed", labelP, nil),
|
||||||
|
TxBroadcast: nd(pns+"transmit_broadcast_total", "Total Transmit Broadcast", labelP, nil),
|
||||||
|
TxBytes: nd(pns+"transmit_bytes_total", "Total Transmit Bytes", labelP, nil),
|
||||||
|
TxBytesR: nd(pns+"transmit_rate_bytes", "Transmit Bytes Rate", labelP, nil),
|
||||||
|
TxDropped: nd(pns+"transmit_dropped_total", "Total Transmit Dropped", labelP, nil),
|
||||||
|
TxErrors: nd(pns+"transmit_errors_total", "Total Transmit Errors", labelP, nil),
|
||||||
|
TxMulticast: nd(pns+"transmit_multicast_total", "Total Tranmist Multicast", labelP, nil),
|
||||||
|
TxPackets: nd(pns+"transmit_packets_total", "Total Transmit Packets", labelP, nil),
|
||||||
|
SFPCurrent: nd(sfp+"current", "SFP Current", labelF, nil),
|
||||||
|
SFPRxPower: nd(sfp+"rx_power", "SFP Receive Power", labelF, nil),
|
||||||
|
SFPTemperature: nd(sfp+"temperature", "SFP Temperature", labelF, nil),
|
||||||
|
SFPTxPower: nd(sfp+"tx_power", "SFP Transmit Power", labelF, nil),
|
||||||
|
SFPVoltage: nd(sfp+"voltage", "SFP Voltage", labelF, nil),
|
||||||
|
// other data
|
||||||
|
Upgradeable: nd(ns+"upgradeable", "Upgrade-able", labelS, nil),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (u *promUnifi) exportPDU(r report, d *unifi.PDU) {
|
||||||
|
if !d.Adopted.Val || d.Locating.Val {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
labels := []string{d.Type, d.SiteName, d.Name, d.SourceName}
|
||||||
|
infoLabels := []string{d.Version, d.Model, d.Serial, d.Mac, d.IP, d.ID}
|
||||||
|
|
||||||
|
u.exportPDUstats(r, labels, d.Stat.Sw)
|
||||||
|
u.exportPDUPrtTable(r, labels, d.PortTable)
|
||||||
|
u.exportPDUOutletTable(r, labels, d.OutletTable, d.OutletOverrides)
|
||||||
|
u.exportBYTstats(r, labels, d.TxBytes, d.RxBytes)
|
||||||
|
u.exportSYSstats(r, labels, d.SysStats, d.SystemStats)
|
||||||
|
u.exportSTAcount(r, labels, d.UserNumSta, d.GuestNumSta)
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.Device.Info, gauge, 1.0, append(labels, infoLabels...)},
|
||||||
|
{u.Device.Uptime, gauge, d.Uptime, labels},
|
||||||
|
{u.Device.Upgradeable, gauge, d.Upgradeable.Val, labels},
|
||||||
|
})
|
||||||
|
|
||||||
|
// Switch System Data.
|
||||||
|
if d.OutletACPowerConsumption.Txt != "" {
|
||||||
|
r.send([]*metric{{u.Device.OutletACPowerConsumption, gauge, d.OutletACPowerConsumption, labels}})
|
||||||
|
}
|
||||||
|
if d.PowerSource.Txt != "" {
|
||||||
|
r.send([]*metric{{u.Device.PowerSource, gauge, d.PowerSource, labels}})
|
||||||
|
}
|
||||||
|
if d.TotalMaxPower.Txt != "" {
|
||||||
|
r.send([]*metric{{u.Device.TotalMaxPower, gauge, d.TotalMaxPower, labels}})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switch Stats.
|
||||||
|
func (u *promUnifi) exportPDUstats(r report, labels []string, sw *unifi.Sw) {
|
||||||
|
if sw == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
labelS := labels[1:]
|
||||||
|
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.SwRxPackets, counter, sw.RxPackets, labelS},
|
||||||
|
{u.PDU.SwRxBytes, counter, sw.RxBytes, labelS},
|
||||||
|
{u.PDU.SwRxErrors, counter, sw.RxErrors, labelS},
|
||||||
|
{u.PDU.SwRxDropped, counter, sw.RxDropped, labelS},
|
||||||
|
{u.PDU.SwRxCrypts, counter, sw.RxCrypts, labelS},
|
||||||
|
{u.PDU.SwRxFrags, counter, sw.RxFrags, labelS},
|
||||||
|
{u.PDU.SwTxPackets, counter, sw.TxPackets, labelS},
|
||||||
|
{u.PDU.SwTxBytes, counter, sw.TxBytes, labelS},
|
||||||
|
{u.PDU.SwTxErrors, counter, sw.TxErrors, labelS},
|
||||||
|
{u.PDU.SwTxDropped, counter, sw.TxDropped, labelS},
|
||||||
|
{u.PDU.SwTxRetries, counter, sw.TxRetries, labelS},
|
||||||
|
{u.PDU.SwRxMulticast, counter, sw.RxMulticast, labelS},
|
||||||
|
{u.PDU.SwRxBroadcast, counter, sw.RxBroadcast, labelS},
|
||||||
|
{u.PDU.SwTxMulticast, counter, sw.TxMulticast, labelS},
|
||||||
|
{u.PDU.SwTxBroadcast, counter, sw.TxBroadcast, labelS},
|
||||||
|
{u.PDU.SwBytes, counter, sw.Bytes, labelS},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switch Port Table.
|
||||||
|
func (u *promUnifi) exportPDUPrtTable(r report, labels []string, pt []unifi.Port) {
|
||||||
|
// Per-port data on a switch
|
||||||
|
for _, p := range pt {
|
||||||
|
if !u.DeadPorts && (!p.Up.Val || !p.Enable.Val) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy labels, and add four new ones.
|
||||||
|
labelP := []string{
|
||||||
|
labels[2] + " Port " + p.PortIdx.Txt, p.PortIdx.Txt,
|
||||||
|
p.Name, p.Mac, p.IP, labels[1], labels[2], labels[3],
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.PoeEnable.Val && p.PortPoe.Val {
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.PoeCurrent, gauge, p.PoeCurrent, labelP},
|
||||||
|
{u.PDU.PoePower, gauge, p.PoePower, labelP},
|
||||||
|
{u.PDU.PoeVoltage, gauge, p.PoeVoltage, labelP},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.SFPFound.Val {
|
||||||
|
labelF := []string{
|
||||||
|
p.SFPPart, p.SFPVendor, p.SFPSerial, p.SFPCompliance,
|
||||||
|
labelP[0], labelP[1], labelP[2], labelP[3], labelP[4], labelP[5], labelP[6], labelP[7],
|
||||||
|
}
|
||||||
|
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.SFPCurrent, gauge, p.SFPCurrent.Val, labelF},
|
||||||
|
{u.PDU.SFPVoltage, gauge, p.SFPVoltage.Val, labelF},
|
||||||
|
{u.PDU.SFPTemperature, gauge, p.SFPTemperature.Val, labelF},
|
||||||
|
{u.PDU.SFPRxPower, gauge, p.SFPRxpower.Val, labelF},
|
||||||
|
{u.PDU.SFPTxPower, gauge, p.SFPTxpower.Val, labelF},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.RxBroadcast, counter, p.RxBroadcast, labelP},
|
||||||
|
{u.PDU.RxBytes, counter, p.RxBytes, labelP},
|
||||||
|
{u.PDU.RxBytesR, gauge, p.RxBytesR, labelP},
|
||||||
|
{u.PDU.RxDropped, counter, p.RxDropped, labelP},
|
||||||
|
{u.PDU.RxErrors, counter, p.RxErrors, labelP},
|
||||||
|
{u.PDU.RxMulticast, counter, p.RxMulticast, labelP},
|
||||||
|
{u.PDU.RxPackets, counter, p.RxPackets, labelP},
|
||||||
|
{u.PDU.Satisfaction, gauge, p.Satisfaction.Val / 100.0, labelP},
|
||||||
|
{u.PDU.Speed, gauge, p.Speed.Val * 1000000, labelP},
|
||||||
|
{u.PDU.TxBroadcast, counter, p.TxBroadcast, labelP},
|
||||||
|
{u.PDU.TxBytes, counter, p.TxBytes, labelP},
|
||||||
|
{u.PDU.TxBytesR, gauge, p.TxBytesR, labelP},
|
||||||
|
{u.PDU.TxDropped, counter, p.TxDropped, labelP},
|
||||||
|
{u.PDU.TxErrors, counter, p.TxErrors, labelP},
|
||||||
|
{u.PDU.TxMulticast, counter, p.TxMulticast, labelP},
|
||||||
|
{u.PDU.TxPackets, counter, p.TxPackets, labelP},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switch Port Table.
|
||||||
|
func (u *promUnifi) exportPDUOutletTable(r report, labels []string, ot []unifi.OutletTable, oto []unifi.OutletOverride) {
|
||||||
|
// Per-outlet data on a switch
|
||||||
|
for _, o := range ot {
|
||||||
|
|
||||||
|
// Copy labels, and add four new ones.
|
||||||
|
labelOutlet := []string{
|
||||||
|
labels[2] + " Outlet " + o.Index.Txt, o.Index.Txt,
|
||||||
|
o.Name, labels[1], labels[2], labels[3],
|
||||||
|
}
|
||||||
|
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.CycleEnabled, counter, o.CycleEnabled, labelOutlet},
|
||||||
|
{u.PDU.RelayState, counter, o.RelayState, labelOutlet},
|
||||||
|
{u.PDU.OutletCaps, counter, o.OutletCaps, labelOutlet},
|
||||||
|
{u.PDU.OutletCurrent, gauge, o.OutletCurrent, labelOutlet},
|
||||||
|
{u.PDU.OutletPower, counter, o.OutletPower, labelOutlet},
|
||||||
|
{u.PDU.OutletPowerFactor, counter, o.OutletPowerFactor, labelOutlet},
|
||||||
|
{u.PDU.OutletVoltage, counter, o.OutletVoltage, labelOutlet},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Per-outlet data on a switch
|
||||||
|
for _, o := range oto {
|
||||||
|
|
||||||
|
// Copy labels, and add four new ones.
|
||||||
|
labelOutlet := []string{
|
||||||
|
labels[2] + " Outlet Override " + o.Index.Txt, o.Index.Txt,
|
||||||
|
o.Name, labels[1], labels[2], labels[3],
|
||||||
|
}
|
||||||
|
|
||||||
|
r.send([]*metric{
|
||||||
|
{u.PDU.CycleEnabled, counter, o.CycleEnabled, labelOutlet},
|
||||||
|
{u.PDU.RelayState, counter, o.RelayState, labelOutlet},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -24,6 +24,7 @@ type report interface {
|
||||||
addUSG()
|
addUSG()
|
||||||
addUAP()
|
addUAP()
|
||||||
addUSW()
|
addUSW()
|
||||||
|
addPDU()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Satisfy gomnd.
|
// Satisfy gomnd.
|
||||||
|
|
@ -76,6 +77,10 @@ func (r *Report) addUSW() {
|
||||||
r.USW++
|
r.USW++
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *Report) addPDU() {
|
||||||
|
r.PDU++
|
||||||
|
}
|
||||||
|
|
||||||
func (r *Report) addUAP() {
|
func (r *Report) addUAP() {
|
||||||
r.UAP++
|
r.UAP++
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -12,6 +12,8 @@ type unifiDevice struct {
|
||||||
Temperature *prometheus.Desc
|
Temperature *prometheus.Desc
|
||||||
Storage *prometheus.Desc
|
Storage *prometheus.Desc
|
||||||
TotalMaxPower *prometheus.Desc // sw only
|
TotalMaxPower *prometheus.Desc // sw only
|
||||||
|
OutletACPowerConsumption *prometheus.Desc // pdu only
|
||||||
|
PowerSource *prometheus.Desc // pdu only
|
||||||
FanLevel *prometheus.Desc // sw only
|
FanLevel *prometheus.Desc // sw only
|
||||||
TotalTxBytes *prometheus.Desc
|
TotalTxBytes *prometheus.Desc
|
||||||
TotalRxBytes *prometheus.Desc
|
TotalRxBytes *prometheus.Desc
|
||||||
|
|
@ -44,6 +46,8 @@ func descDevice(ns string) *unifiDevice {
|
||||||
Storage: prometheus.NewDesc(ns+"storage", "Storage",
|
Storage: prometheus.NewDesc(ns+"storage", "Storage",
|
||||||
append(labels, "mountpoint", "storage_name", "storage_reading"), nil),
|
append(labels, "mountpoint", "storage_name", "storage_reading"), nil),
|
||||||
TotalMaxPower: prometheus.NewDesc(ns+"max_power_total", "Total Max Power", labels, nil),
|
TotalMaxPower: prometheus.NewDesc(ns+"max_power_total", "Total Max Power", labels, nil),
|
||||||
|
OutletACPowerConsumption: prometheus.NewDesc(ns+"outlet_ac_power_consumption", "Outlet AC Power Consumption", labels, nil),
|
||||||
|
PowerSource: prometheus.NewDesc(ns+"power_source", "Power Source", labels, nil),
|
||||||
FanLevel: prometheus.NewDesc(ns+"fan_level", "Fan Level", labels, nil),
|
FanLevel: prometheus.NewDesc(ns+"fan_level", "Fan Level", labels, nil),
|
||||||
TotalTxBytes: prometheus.NewDesc(ns+"transmit_bytes_total", "Total Transmitted Bytes", labels, nil),
|
TotalTxBytes: prometheus.NewDesc(ns+"transmit_bytes_total", "Total Transmitted Bytes", labels, nil),
|
||||||
TotalRxBytes: prometheus.NewDesc(ns+"receive_bytes_total", "Total Received Bytes", labels, nil),
|
TotalRxBytes: prometheus.NewDesc(ns+"receive_bytes_total", "Total Received Bytes", labels, nil),
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue