mirror of
https://github.com/KevinMidboe/mktxp-no-cli.git
synced 2025-12-08 20:38:48 +00:00
Added metrics for kid-control devices
This commit is contained in:
91
mktxp/collector/kid_control_device_collector.py
Normal file
91
mktxp/collector/kid_control_device_collector.py
Normal file
@@ -0,0 +1,91 @@
|
||||
# coding=utf8
|
||||
## Copyright (c) 2020 Arseniy Kuznetsov
|
||||
##
|
||||
## This program is free software; you can redistribute it and/or
|
||||
## modify it under the terms of the GNU General Public License
|
||||
## as published by the Free Software Foundation; either version 2
|
||||
## of the License, or (at your option) any later version.
|
||||
##
|
||||
## This program is distributed in the hope that it will be useful,
|
||||
## but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
## GNU General Public License for more details.
|
||||
|
||||
|
||||
from mktxp.collector.base_collector import BaseCollector
|
||||
from mktxp.flow.processor.output import BaseOutputProcessor
|
||||
from mktxp.datasource.kid_control_device_ds import KidDeviceMetricsDataSource
|
||||
|
||||
|
||||
class KidDeviceCollector(BaseCollector):
|
||||
''' Kid-control device Metrics collector
|
||||
'''
|
||||
@staticmethod
|
||||
def collect(router_entry):
|
||||
if not router_entry.config_entry.kid_control_devices:
|
||||
return
|
||||
|
||||
labels = ['name', 'user', 'mac_address', 'ip_address', 'bytes_down', 'bytes_up', 'rate_up', 'rate_down', 'bytes_up', 'idle_time',
|
||||
'blocked', 'limited', 'inactive', 'disabled']
|
||||
info_labels = ['name', 'user', 'mac_address', 'ip_address', 'disabled']
|
||||
records = KidDeviceMetricsDataSource.metric_records(router_entry, metric_labels = labels)
|
||||
|
||||
if records:
|
||||
# translate records to appropriate values
|
||||
for record in records:
|
||||
for label in record:
|
||||
value = record.get(label, None)
|
||||
if value:
|
||||
record[label] = KidDeviceCollector._translated_values(label, value)
|
||||
|
||||
info_metrics = BaseCollector.info_collector('kid_control_device', 'Kid-control device Info', records, info_labels)
|
||||
yield info_metrics
|
||||
|
||||
bytes_down_metrics = BaseCollector.gauge_collector('kid_control_device_bytes_down', 'Kid-control device bytes down', records, 'bytes_down', ['name'])
|
||||
yield bytes_down_metrics
|
||||
|
||||
bytes_up_metrics = BaseCollector.gauge_collector('kid_control_device_bytes_up', 'Kid-control device bytes up', records, 'bytes_up', ['name'])
|
||||
yield bytes_up_metrics
|
||||
|
||||
rate_down_metrics = BaseCollector.gauge_collector('kid_control_device_rate_down', 'Kid-control device rate down', records, 'rate_down', ['name'])
|
||||
yield rate_down_metrics
|
||||
|
||||
rate_up_metrics = BaseCollector.gauge_collector('kid_control_device_rate_up', 'Kid-control device rate up', records, 'rate_up', ['name'])
|
||||
yield rate_up_metrics
|
||||
|
||||
idle_time_metrics = BaseCollector.gauge_collector('kid_control_device_idle_time', 'Kid-control device idle time', records, 'idle_time', ['name'])
|
||||
yield idle_time_metrics
|
||||
|
||||
# Helpers
|
||||
@staticmethod
|
||||
def _translated_values(monitor_label, value):
|
||||
try:
|
||||
return {
|
||||
'rate_up': lambda value: KidDeviceCollector._rates(value),
|
||||
'rate_down': lambda value: KidDeviceCollector._rates(value),
|
||||
'idle_time': lambda value: BaseOutputProcessor.parse_timedelta_seconds(value),
|
||||
'blocked': lambda value: '1' if value=='true' else '0',
|
||||
'limited': lambda value: '1' if value=='true' else '0',
|
||||
'inactive': lambda value: '1' if value=='true' else '0',
|
||||
'disabled': lambda value: '1' if value=='true' else '0',
|
||||
}[monitor_label](value)
|
||||
except KeyError:
|
||||
return value
|
||||
|
||||
@staticmethod
|
||||
def _rates(rate_option):
|
||||
# according mikrotik docs, an interface rate should be one of these
|
||||
rate_value = {
|
||||
'10Mbps': '10',
|
||||
'100Mbps': '100',
|
||||
'1Gbps': '1000',
|
||||
'2.5Gbps': '2500',
|
||||
'5Gbps': '5000',
|
||||
'10Gbps': '10000',
|
||||
'40Gbps': '40000'
|
||||
}.get(rate_option, None)
|
||||
if rate_value:
|
||||
return rate_value
|
||||
|
||||
# ...or just calculate in case it's not
|
||||
return BaseOutputProcessor.parse_interface_rate(rate_option)
|
||||
Reference in New Issue
Block a user