Files
librenms-librenms/includes/polling/os/openbsd.inc.php
Tony Murray fad0bffc43 Escape SNMP & IPMI shell commands (#9537)
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.
2018-12-16 13:42:50 +00:00

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;
}