mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
hopefully doesn't break anything Mostly issues with snmp oids and options containing spaces. Try to remove all of those. DO NOT DELETE THIS TEXT #### Please note > Please read this information carefully. You can run `./scripts/pre-commit.php` to check your code before submitting. - [x] Have you followed our [code guidelines?](http://docs.librenms.org/Developing/Code-Guidelines/) #### Testers If you would like to test this pull request then please run: `./scripts/github-apply <pr_id>`, i.e `./scripts/github-apply 5926` After you are done testing, you can remove the changes with `./scripts/github-remove`. If there are schema changes, you can ask on discord how to revert.
66 lines
1.6 KiB
PHP
66 lines
1.6 KiB
PHP
<?php
|
|
|
|
use LibreNMS\RRD\RrdDefinition;
|
|
|
|
list(,,$version,$features,$hardware) = explode(" ", $device['sysDescr']);
|
|
$features = str_replace(['(', ')'], '', $features);
|
|
|
|
$oids = snmp_get_multi($device, ['pfStateCount.0', 'pfStateSearches.0', 'pfStateInserts.0', 'pfStateRemovals.0'], '-OQUs', 'OPENBSD-PF-MIB');
|
|
|
|
$states = $oids[0]['pfStateCount'];
|
|
$searches = $oids[0]['pfStateSearches'];
|
|
$inserts = $oids[0]['pfStateInserts'];
|
|
$removals = $oids[0]['pfStateCount'];
|
|
|
|
if (is_numeric($states)) {
|
|
$rrd_def = RrdDefinition::make()->addDataset('states', 'GAUGE', 0);
|
|
|
|
$fields = array(
|
|
'states' => $states,
|
|
);
|
|
|
|
$tags = compact('rrd_def');
|
|
data_update($device, 'pf_states', $tags, $fields);
|
|
|
|
$graphs['pf_states'] = true;
|
|
}
|
|
|
|
if (is_numeric($searches)) {
|
|
$rrd_def = RrdDefinition::make()->addDataset('searches', 'COUNTER', 0);
|
|
|
|
$fields = array(
|
|
'searches' => $searches,
|
|
);
|
|
|
|
$tags = compact('rrd_def');
|
|
data_update($device, 'pf_searches', $tags, $fields);
|
|
|
|
$graphs['pf_searches'] = true;
|
|
}
|
|
|
|
if (is_numeric($inserts)) {
|
|
$rrd_def = RrdDefinition::make()->addDataset('inserts', 'COUNTER', 0);
|
|
|
|
$fields = array(
|
|
'inserts' => $inserts,
|
|
);
|
|
|
|
$tags = compact('rrd_def');
|
|
data_update($device, 'pf_inserts', $tags, $fields);
|
|
|
|
$graphs['pf_inserts'] = true;
|
|
}
|
|
|
|
if (is_numeric($removals)) {
|
|
$rrd_def = RrdDefinition::make()->addDataset('removals', 'COUNTER', 0);
|
|
|
|
$fields = array(
|
|
'removals' => $removals,
|
|
);
|
|
|
|
$tags = compact('rrd_def');
|
|
data_update($device, 'pf_removals', $tags, $fields);
|
|
|
|
$graphs['pf_removals'] = true;
|
|
}
|