2016-07-27 18:48:39 +02:00
|
|
|
<?php
|
|
|
|
|
/*
|
|
|
|
|
* LibreNMS
|
|
|
|
|
*
|
2017-08-24 22:08:42 +02:00
|
|
|
* Copyright (c) 2016 Søren Friis Rosiak <sorenrosiak@gmail.com>
|
2016-07-27 18:48:39 +02:00
|
|
|
* 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 3 of the License, or (at your
|
|
|
|
|
* option) any later version. Please see LICENSE.txt at the top level of
|
|
|
|
|
* the source code distribution for details.
|
|
|
|
|
*/
|
2017-02-03 12:39:38 +00:00
|
|
|
|
|
|
|
|
echo 'Comware ';
|
2017-08-24 22:08:42 +02:00
|
|
|
|
2017-02-03 12:39:38 +00:00
|
|
|
$multiplier = 1;
|
|
|
|
|
$divisor = 100;
|
|
|
|
|
foreach ($pre_cache['comware_oids'] as $index => $entry) {
|
2017-08-24 22:08:42 +02:00
|
|
|
if (is_numeric($entry['hh3cTransceiverCurRXPower']) && $entry['hh3cTransceiverCurRXPower'] != 2147483647 && isset($entry['hh3cTransceiverDiagnostic'])) {
|
2017-02-03 12:39:38 +00:00
|
|
|
$oid = '.1.3.6.1.4.1.25506.2.70.1.1.1.12.' . $index;
|
2019-03-04 17:31:17 +00:00
|
|
|
$dbquery = dbFetchRows("SELECT `ifDescr` FROM `ports` WHERE `ifIndex`= ? AND `device_id` = ? AND `ifAdminStatus` = 'up'", [$index, $device['device_id']]);
|
2017-08-24 22:08:42 +02:00
|
|
|
$limit_low = round(uw_to_dbm($entry['hh3cTransceiverRcvPwrLoAlarm'] / 10), 2);
|
|
|
|
|
$warn_limit_low = round(uw_to_dbm($entry['hh3cTransceiverRcvPwrLoWarn'] / 10), 2);
|
|
|
|
|
$limit = round(uw_to_dbm($entry['hh3cTransceiverRcvPwrHiAlarm'] / 10), 2);
|
|
|
|
|
$warn_limit = round(uw_to_dbm($entry['hh3cTransceiverRcvPwrHiWarn'] / 10), 2);
|
2017-02-03 12:39:38 +00:00
|
|
|
$current = $entry['hh3cTransceiverCurRXPower'] / $divisor;
|
|
|
|
|
$entPhysicalIndex = $index;
|
|
|
|
|
$entPhysicalIndex_measured = 'ports';
|
|
|
|
|
foreach ($dbquery as $dbindex => $dbresult) {
|
2017-08-24 22:08:42 +02:00
|
|
|
$descr = makeshortif($dbresult['ifDescr']) . ' Receive Power';
|
2017-02-03 12:39:38 +00:00
|
|
|
discover_sensor($valid['sensor'], 'dbm', $device, $oid, 'rx-' . $index, 'comware', $descr, $divisor, $multiplier, $limit_low, $warn_limit_low, $warn_limit, $limit, $current, 'snmp', $entPhysicalIndex, $entPhysicalIndex_measured);
|
2016-07-27 18:48:39 +02:00
|
|
|
}
|
2017-02-03 12:39:38 +00:00
|
|
|
}
|
2017-08-24 22:08:42 +02:00
|
|
|
|
|
|
|
|
if (is_numeric($entry['hh3cTransceiverCurTXPower']) && $entry['hh3cTransceiverCurTXPower'] != 2147483647 && isset($entry['hh3cTransceiverDiagnostic'])) {
|
2017-02-03 12:39:38 +00:00
|
|
|
$oid = '.1.3.6.1.4.1.25506.2.70.1.1.1.9.' . $index;
|
2019-03-04 17:31:17 +00:00
|
|
|
$dbquery = dbFetchRows("SELECT `ifDescr` FROM `ports` WHERE `ifIndex`= ? AND `device_id` = ? AND `ifAdminStatus` = 'up'", [$index, $device['device_id']]);
|
2017-08-24 22:08:42 +02:00
|
|
|
$limit_low = round(uw_to_dbm($entry['hh3cTransceiverPwrOutLoAlarm'] / 10), 2);
|
|
|
|
|
$warn_limit_low = round(uw_to_dbm($entry['hh3cTransceiverPwrOutLoWarn'] / 10), 2);
|
|
|
|
|
$limit = round(uw_to_dbm($entry['hh3cTransceiverPwrOutHiAlarm'] / 10), 2);
|
|
|
|
|
$warn_limit = round(uw_to_dbm($entry['hh3cTransceiverPwrOutHiWarn'] / 10), 2);
|
2017-02-03 12:39:38 +00:00
|
|
|
$current = $entry['hh3cTransceiverCurTXPower'] / $divisor;
|
|
|
|
|
$entPhysicalIndex = $index;
|
|
|
|
|
$entPhysicalIndex_measured = 'ports';
|
|
|
|
|
foreach ($dbquery as $dbindex => $dbresult) {
|
2017-08-24 22:08:42 +02:00
|
|
|
$descr = makeshortif($dbresult['ifDescr']) . ' Transmit Power';
|
2017-02-03 12:39:38 +00:00
|
|
|
discover_sensor($valid['sensor'], 'dbm', $device, $oid, 'tx-' . $index, 'comware', $descr, $divisor, $multiplier, $limit_low, $warn_limit_low, $warn_limit, $limit, $current, 'snmp', $entPhysicalIndex, $entPhysicalIndex_measured);
|
2016-07-27 18:48:39 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|