Files
netdisco/share/views/ajax/device/snmp.tt
Oliver Gorwits dc1f76c1aa Feature to gather SNMP Walk, use as Pseudo Device, and Browse Objects
* fix anomalous name

* add gather worker

* fix encoding of binary storage

* store results back to job

* now parsing mbis report to translate

* fix the broken report parser

* rename gather to snapshot

* implement walk code copied from SNMP::Info

* can now bulkwalk and parse mibs report and store resolved walk in cache

* add func/glob aliasing broken

* better aliasing

* implement aliasing from globals and funcs

* fix regexp for matching netdisco-mibs report

* fake cache entry for all ND2 methods called, add comments

* also save to logs/snapshots/IP

* add doc for netdisco-do

* add is_pseudo column to device table

* support for loading cache for pseudo devices

* check for hrSystemUptime as well as sysUpTime for snmp connect

* display pseudo devices with yellow pill for name

* color all cells for layers for pseudo

* no need to b64 encode binary data in scalars as we b64 whole thing after

* tweaked uptime check

* store snapshot to database instead of Job

* expose snapshots in device details tab

* small ux improvements on snap download

* fixes for errors in subnet mask searching

* hide snapshot management for pseudo devices

* update to use new netdisco-mibs object cache

* update for new format oids file

* start of work on loading walk into db for browsing

* store values and meta

* add auto increment col and oid index to browser

* start web plugin for browser

* add virtual search for oid children

* have all oid in separte table (60 seconds load on my laptop)

* rename table and add relation

* store oid as int array

* fix sql for children

* make jstree start working

* working very slow tree expand

* fix to work when first displaying tree

* store both oid and oid_parts

* simplify SQL to speed up (more complicated perl)

* fix sql bug, add better index, prettify tree

* render the snmp node detail

* add node template, make scrollable, pretty print data values (insecure)

* store munge hint

* some dubious code to munge the data

* make sure to filter by IP on device_browser

* make safer the rendering of value data (but need to come back to key ordering)

* fix sorting on object values

* limit the opening of child nodes to keep response good and unclutter

* factor out the munge and make safer

* reject unknown mungers

* show the munger and option (not working) to change

* additional js for munge select

* complete custom munge

* change so that saving to database is only at CLI and on request

* hide snmp tab if no browser rows in the db

* add helpful message when no browser rows for the device

* stub handler for search and add recurse control

* working search

* minor ui fixes

* implement typeahead for leaf search

* limit rows in typeahead

* make sure device_browser is visited in delete and renumber

* add requirements for this branch

* update manifest

* make sure node search and typeahead are restricted to current device only
2021-11-06 07:47:29 +00:00

133 lines
4.4 KiB
Plaintext

<div class="row">
<div class="span5">
<div id="jstree" class="nd_scrollable"></div>
</div>
<div id="snmpnodecontainer" class="span8">
<form id="searchTreeForm" class="form-inline col-md-4">
<span class="form-group">
<input id="treeSearchText" type="text" class="form-control" size="30" required placeholder="Search for label or OID">
<label class="checkbox-inline"
rel="tooltip" data-placement="top" data-offset="5" data-title="Anchored to the beginning">
<input type="checkbox" id="snmpPartialSearch" value="partial"> Partial </input>
</label>
</span>
<button type="submit" class="btn btn-default">Search</button>
</form>
<div id="node">
<table class="table table-bordered">
<tbody>
<tr>
<th scope="row" class="span1">OID</th>
<td></td>
</tr>
<tr>
<th scope="row">Module</th>
<td></td>
</tr>
<tr>
<th scope="row">Leaf</th>
<td></td>
</tr>
<tr>
<th scope="row">Type</th>
<td></td>
</tr>
<tr>
<th scope="row">Munge</th>
<td></td>
</tr>
<tr>
<th scope="row">Access</th>
<td></td>
</tr>
<tr>
<th scope="row">Index</th>
<td></td>
</tr>
<tr>
<th scope="row">Value</th>
<td></td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
<script type="text/javascript">
$(function () {
var jstree_search_callback = function(str, node) {
var pattern = str.toLowerCase();
var name = node.text.toLowerCase();
var oid = node.id.toLowerCase();
if (document.getElementById('snmpPartialSearch').checked) {
if ((name.indexOf(pattern) == 0) || (oid.indexOf(pattern) == 0)) {
return true;
}
}
else {
if ((name.indexOf(pattern + ' ') == 0) || (oid == pattern)) {
return true;
}
}
return false;
};
$('#jstree').jstree({
'core': {
'multiple' : false,
'themes': {
'name': 'proton',
'responsive': true
},
'data' : {
'url' : function (node) {
return ('[% uri_base | none %]/ajax/data/device/[% device %]/snmptree/'
+ (node.id === '#' ? '.1.3.6.1' : node.id) + '?recurse=on');
}
}
},
'plugins': ['search'],
'search': {
'ajax' : {
'url' : '[% uri_base | none %]/ajax/data/device/[% device %]/snmpnodesearch',
'beforeSend' : function(jqXHR, settings) {
settings.url = settings.url + '&excludeself=on';
if (document.getElementById('snmpPartialSearch').checked) {
settings.url = settings.url + '&partial=on';
}
return true;
}
},
'search_callback' : jstree_search_callback
},
});
$('#snmpnodecontainer').on("change", "#munger", function(e, data) {
var ary = $('#jstree').jstree('get_selected');
$('#node').load('[% uri_base | none %]/ajax/content/device/[% device %]/snmpnode/'
+ ary[0] + '?munge=' + $('#munger').find(":selected").text());
});
$('#jstree').on("changed.jstree", function (e, data) {
if (data.selected && data.selected != "#") {
$('#node').load('[% uri_base | none %]/ajax/content/device/[% device %]/snmpnode/' + data.selected);
}
});
$('#jstree').on("search.jstree", function (e, data) {
if (data.res.length) {
document.getElementById( data.res[0] + '_anchor' ).scrollIntoView();
$('#node').load('[% uri_base | none %]/ajax/content/device/[% device %]/snmpnode/' + data.res[0]);
}
});
$("#searchTreeForm").submit(function(e) {
$("#jstree").jstree("search", $("#treeSearchText").val());
e.preventDefault();
});
$('#treeSearchText').autocomplete({
source: uri_base + '/ajax/data/device/[% device %]/typeahead'
,delay: 150
,minLength: 2
});
});
</script>