Files
librenms-librenms/LibreNMS/OS/Traits/YamlOSDiscovery.php
Tony Murray f2f169ae78 Modernize mempools (#12282)
* mempools to modern module
quick hacky hrstorage port

* port ucd-snmp-mib to Mempools

* Populate DB for ucd
Prep for yaml

* initial yaml attempt

* more complex conversions
fixes to YamlDiscovery, make leading $ optional and allow mib::oid format

* walk full tables and skip values
normalize percentages above 100

* handle precent only ones (specify total as 100)

* Move default polling out of YamlMempoolsDiscovery

* fixes

* Update test data hrstorage should be correct.

* perc_warn for hrstorage

* Host Resources, record buffer, cached, and shared

* Host Resources is always better, don't do both HR and UCD

* fix unix, include warning levels

* variable size

* consolidate skip_values

* define mempools schema

* number instead of integer

* more schema refactor

* one more skip_values reference

* throw error for invalid oid translation
aos6

* a*  and Cisco

* updated test data

* update almost all hrstorage data files

* b*

* c* with test data
use standard cache for hrStorage

* use cache for storage module too

* hand bsnmp properly

* bdcom

* exclude total oid from yaml so it is not polled
May add a way to ignore this behavior and poll it, but I don't know if that is needed.

* automatically handle percent only values

* ciscowlc

* only poll used or free if we have used, free, and total.

* fix skipping

* the dlinkoning
fix find value when value "name" is numeric

* support numeric oids

* dnos/ftos attempt

* I guess we can't filter on total > 0

* edgecos

* e*

* f WIP

* f*

* gwd (aka g*)

* h* + procurve

* i*

* j*

* m*

* support 0% used memory (however unlikely)

* n*

* CISCO-PROCESS-MIB memory, share cache with processors module

* ignore mempools with invalid total

* p*

* quanta

* r*
fix raisecom mibs terribly broken

* s-z

* style fixes

* Move VRP back to PHP and make it actually work

* fix zynos

* update schema

* Update Cisco processor data for description bug fixes

* fix comware processors

* comware mempools with memory size
default precision to 1

* sophos-xg updated data

* hrstorage use ram size for buffers, cache, and shared

* Show memory available instead of free in device overview

* UCD, use same rrd format, store available instead of free in the db.

* Calculate availability for HOST-RESOURCES-MIB

* Convert UCD to standard polling

* rename old rrd files

* initial graph work

* graph WIP

* Graph looking decent

* Graph looking decent for hr

* remove old ucd_graph code

* handle availability mempool
more graph cleanup

* color adjustments

* remove accidental free calculation

* Update test data and fix corner cases

* fis pfsense

* update schema

* add default value for mempool_class

* fix whitespace

* update schema

* update schema correctly

* one more time

* fortigate_1500d-sensors missing oids

* Update docs.

* fix indent

* add implements MempoolsDiscovery explicitly to OS

* remove ucd_memory graph references
remove unused device_memory graph

* remove unused functions

* set devices with mempools to rediscover to prevent/minimize gaps

* use a subquery

* add overview graph

* port health mempools table

* Update device mempool

* only show overview if multiple

* Don't override user set warn percentages in discovery

* fix missed usage

* fix style

* Safety check to not rename rrd files incorrectly if migration has not been run.

* Fix overview percent bar and represent available and used on the bar

* missed an item to convert to mempool_class

* percent on the wrong side
2020-11-23 15:35:35 -06:00

145 lines
4.2 KiB
PHP

<?php
/*
* YamlOSDiscovery.php
*
* -Description-
*
* 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.
*
* 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.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* @package LibreNMS
* @link http://librenms.org
* @copyright 2020 Tony Murray
* @author Tony Murray <murraytony@gmail.com>
*/
namespace LibreNMS\OS\Traits;
use App\Models\Device;
use Illuminate\Support\Arr;
use Log;
trait YamlOSDiscovery
{
private $osDbFields = [
'version',
'hardware',
'features',
'serial',
];
private $osFields = [
'version',
'hardware',
'features',
'serial',
'location',
];
public function discoverOS(Device $device): void
{
$os_yaml = $this->getDiscovery('os');
if (isset($os_yaml['sysDescr_regex'])) {
$this->parseRegex($os_yaml['sysDescr_regex'], $device->sysDescr);
}
if (isset($os_yaml['hardware_mib'])) {
$this->translateSysObjectID($os_yaml['hardware_mib'], $os_yaml['hardware_regex'] ?? null);
}
$oids = Arr::only($os_yaml, $this->osFields);
$fetch_oids = array_unique(Arr::flatten($oids));
$numeric = $this->isNumeric($fetch_oids);
$flags = $numeric ? '-OUQn' : '-OUQ';
$data = snmp_get_multi_oid($this->getDeviceArray(), $fetch_oids, $flags);
Log::debug('Yaml OS data:', $data);
foreach ($oids as $field => $oid_list) {
if ($value = $this->findFirst($data, $oid_list, $numeric)) {
if ($field == 'location') {
$device->setLocation($value);
continue;
}
// extract via regex if requested
if (isset($os_yaml["{$field}_regex"])) {
$this->parseRegex($os_yaml["{$field}_regex"], $value);
$value = $device->$field;
}
$device->$field = isset($os_yaml["{$field}_template"])
? $this->parseTemplate($os_yaml["{$field}_template"], $data)
: $value;
}
}
}
private function findFirst($data, $oids, $numeric = false)
{
foreach (Arr::wrap($oids) as $oid) {
// translate all to numeric to make it easier to match
$oid = ($numeric && ! oid_is_numeric($oid)) ? snmp_translate($oid, 'ALL', null, null, $this->getDeviceArray()) : $oid;
if (! empty($data[$oid])) {
return $data[$oid];
}
}
return null;
}
private function parseRegex($regexes, $subject)
{
$device = $this->getDevice();
foreach (Arr::wrap($regexes) as $regex) {
if (preg_match($regex, $subject, $matches)) {
foreach ($this->osDbFields as $field) {
if (isset($matches[$field])) {
$device->$field = $matches[$field];
}
}
}
}
}
private function parseTemplate($template, $data)
{
return trim(preg_replace_callback('/{{ ([^ ]+) }}/', function ($matches) use ($data) {
return $data[$matches[1]] ?? '';
}, $template));
}
private function translateSysObjectID($mib, $regex)
{
$device = $this->getDevice();
$device->hardware = snmp_translate($device->sysObjectID, $mib, null, '-Os', $this->getDeviceArray());
if ($regex) {
$this->parseRegex($regex, $device->hardware);
}
}
private function isNumeric($oids)
{
foreach ($oids as $oid) {
if (oid_is_numeric($oid)) {
return true;
}
}
return false;
}
}