mirror of
https://github.com/KevinMidboe/mktxp-no-cli.git
synced 2025-10-29 17:50:23 +00:00
POE collector, bandwidth metrics on/off switch, fixes/optimizations
This commit is contained in:
53
mktxp/datasource/poe_ds.py
Normal file
53
mktxp/datasource/poe_ds.py
Normal file
@@ -0,0 +1,53 @@
|
||||
# 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.datasource.base_ds import BaseDSProcessor
|
||||
|
||||
|
||||
class POEMetricsDataSource:
|
||||
''' POE Metrics data provider
|
||||
'''
|
||||
@staticmethod
|
||||
def metric_records(router_entry, *, include_comments = False, metric_labels = []):
|
||||
try:
|
||||
poe_records = router_entry.api_connection.router_api().get_resource('/interface/ethernet/poe').get()
|
||||
for int_num, poe_record in enumerate(poe_records):
|
||||
poe_monitor_record = router_entry.api_connection.router_api().get_resource('/interface/ethernet/poe').call('monitor', {'once':'', 'numbers':f'{int_num}'})
|
||||
if poe_monitor_record[0].get('poe_out_status'):
|
||||
poe_record['poe_out_status'] = poe_monitor_record[0]['poe_out_status']
|
||||
|
||||
if poe_monitor_record[0].get('poe_out_voltage'):
|
||||
poe_record['poe_out_voltage'] = poe_monitor_record[0]['poe_out_voltage']
|
||||
|
||||
if poe_monitor_record[0].get('poe_out_current'):
|
||||
poe_record['poe_out_current'] = poe_monitor_record[0]['poe_out_current']
|
||||
|
||||
if poe_monitor_record[0].get('poe_out_power'):
|
||||
poe_record['poe_out_power'] = poe_monitor_record[0]['poe_out_power']
|
||||
|
||||
if include_comments:
|
||||
interfaces = router_entry.api_connection.router_api().get_resource('/interface/ethernet').get()
|
||||
comment = lambda interface: interface['comment'] if interface.get('comment') else ''
|
||||
for poe_record in poe_records:
|
||||
comment = [comment(interface) for interface in interfaces if interface['name'] == poe_record['name']][0]
|
||||
if comment:
|
||||
# combines name with comment
|
||||
poe_record['name'] = comment if router_entry.config_entry.use_comments_over_names else \
|
||||
f"{poe_record['name']} ({comment})"
|
||||
|
||||
return BaseDSProcessor.trimmed_records(router_entry, router_records = poe_records, metric_labels = metric_labels)
|
||||
except Exception as exc:
|
||||
print(f'Error getting PoE info from router{router_entry.router_name}@{router_entry.config_entry.hostname}: {exc}')
|
||||
return None
|
||||
|
||||
Reference in New Issue
Block a user