add option to limit snmp node search to current device only
This commit is contained in:
@@ -54,18 +54,19 @@ ajax '/ajax/data/device/:ip/snmptree/:base' => require_login sub {
|
||||
to_json $items;
|
||||
};
|
||||
|
||||
# TODO add form option for limiting to this device, so leave :ip
|
||||
ajax '/ajax/data/device/:ip/typeahead' => require_login sub {
|
||||
my $device = try { schema('netdisco')->resultset('Device')
|
||||
->find( param('ip') ) }
|
||||
or send_error('Bad Device', 404);
|
||||
|
||||
ajax '/ajax/data/snmp/typeahead' => require_login sub {
|
||||
my $term = param('term') or return to_json [];
|
||||
$term = '%'. $term .'%';
|
||||
|
||||
my @found = schema('netdisco')->resultset('SNMPObject')
|
||||
->search({ leaf => { -ilike => $term } },
|
||||
{ rows => 25, columns => 'leaf' })
|
||||
my $device = param('ip');
|
||||
my $deviceonly = param('deviceonly');
|
||||
my $table = ($deviceonly ? 'DeviceBrowser' : 'SNMPObject');
|
||||
|
||||
my @found = schema('netdisco')->resultset($table)
|
||||
->search({ -or => [ oid => $term,
|
||||
oid => { -like => ($term .'.%') },
|
||||
leaf => { -ilike => ('%'. $term .'%') } ],
|
||||
(($deviceonly and $device) ? (ip => $device) : ()), },
|
||||
{ rows => 25, columns => 'leaf', order_by => 'oid_parts' })
|
||||
->get_column('leaf')->all;
|
||||
return to_json [] unless scalar @found;
|
||||
|
||||
@@ -73,25 +74,24 @@ ajax '/ajax/data/device/:ip/typeahead' => require_login sub {
|
||||
to_json [ sort @found ];
|
||||
};
|
||||
|
||||
# TODO add form option for limiting to this device, so leave :ip
|
||||
ajax '/ajax/data/device/:ip/snmpnodesearch' => require_login sub {
|
||||
my $device = try { schema('netdisco')->resultset('Device')
|
||||
->find( param('ip') ) }
|
||||
or send_error('Bad Device', 404);
|
||||
|
||||
my $to_match = param('str');
|
||||
ajax '/ajax/data/snmp/nodesearch' => require_login sub {
|
||||
my $to_match = param('str') or return to_json [];
|
||||
my $partial = param('partial');
|
||||
my $excludeself = param('excludeself');
|
||||
|
||||
return to_json [] unless $to_match or length($to_match);
|
||||
$to_match = $to_match . '%' if $partial;
|
||||
my $found = undef;
|
||||
|
||||
my $op = ($partial ? '-ilike' : '=');
|
||||
$found = schema('netdisco')->resultset('SNMPObject')
|
||||
->search({ -or => [ oid => { $op => $to_match }, leaf => { $op => $to_match } ] },
|
||||
{ rows => 1, order_by => 'oid_parts' })->first;
|
||||
|
||||
if ($partial) {
|
||||
$found = schema('netdisco')->resultset('SNMPObject')
|
||||
->search({ -or => [ oid => $to_match,
|
||||
oid => { -like => ($to_match .'.%') },
|
||||
leaf => { -ilike => ($to_match .'%') } ] },
|
||||
{ rows => 1, order_by => 'oid_parts' })->first;
|
||||
}
|
||||
else {
|
||||
$found = schema('netdisco')->resultset('SNMPObject')
|
||||
->search({ -or => [ oid => $to_match,
|
||||
leaf => $to_match ] },
|
||||
{ rows => 1, order_by => 'oid_parts' })->first;
|
||||
}
|
||||
return to_json [] unless $found;
|
||||
|
||||
$found = $found->oid;
|
||||
|
||||
@@ -3,15 +3,20 @@
|
||||
<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 id="nd_snmp_search_form" class="form-inline col-md-4">
|
||||
<span class="form-group">
|
||||
<input id="nd_snmp_search_text" type="text" class="form-control nd_snmp_search_param" name="term" size="30" required placeholder="Search for label or OID">
|
||||
|
||||
<button type="submit" class="btn btn-default">Search</button>
|
||||
|
||||
<label class="checkbox-inline"
|
||||
rel="tooltip" data-placement="top" data-offset="5" data-title="Anchored to the beginning">
|
||||
<input type="checkbox" id="nd_snmp_search_partial" name="partial" class="nd_snmp_search_param"> Partial </input>
|
||||
</label>
|
||||
|
||||
<input type="checkbox" id="nd_snmp_search_deviceonly" name="deviceonly" class="nd_snmp_search_param" checked="checked"> Only this device </input>
|
||||
<input type="hidden" id="nd_snmp_search_ip" name="ip" class="nd_snmp_search_param" value="[% device %]" />
|
||||
</span>
|
||||
</form>
|
||||
<div id="node">
|
||||
<table class="table table-bordered">
|
||||
@@ -73,7 +78,7 @@
|
||||
var name = node.text.toLowerCase();
|
||||
var oid = node.id.toLowerCase();
|
||||
|
||||
if (document.getElementById('snmpPartialSearch').checked) {
|
||||
if (document.getElementById('nd_snmp_search_partial').checked) {
|
||||
if ((name.indexOf(pattern) == 0) || (oid.indexOf(pattern) == 0)) {
|
||||
return true;
|
||||
}
|
||||
@@ -103,10 +108,9 @@
|
||||
'plugins': ['search'],
|
||||
'search': {
|
||||
'ajax' : {
|
||||
'url' : '[% uri_base | none %]/ajax/data/device/[% device %]/snmpnodesearch',
|
||||
'url' : '[% uri_base | none %]/ajax/data/snmp/nodesearch',
|
||||
'beforeSend' : function(jqXHR, settings) {
|
||||
settings.url = settings.url + '&excludeself=on';
|
||||
if (document.getElementById('snmpPartialSearch').checked) {
|
||||
if (document.getElementById('nd_snmp_search_partial').checked) {
|
||||
settings.url = settings.url + '&partial=on';
|
||||
}
|
||||
return true;
|
||||
@@ -138,12 +142,17 @@
|
||||
document.getElementById( parent ).scrollIntoView();
|
||||
}
|
||||
});
|
||||
$("#searchTreeForm").submit(function(e) {
|
||||
$("#jstree").jstree("search", $("#treeSearchText").val());
|
||||
$("#nd_snmp_search_form").submit(function(e) {
|
||||
$("#jstree").jstree("search", $("#nd_snmp_search_text").val());
|
||||
e.preventDefault();
|
||||
});
|
||||
$('#treeSearchText').autocomplete({
|
||||
source: uri_base + '/ajax/data/device/[% device %]/typeahead'
|
||||
$('#nd_snmp_search_text').autocomplete({
|
||||
source: function (request, response) {
|
||||
var query = $('.nd_snmp_search_param').serialize();
|
||||
return $.get( uri_base + '/ajax/data/snmp/typeahead', query, function (data) {
|
||||
return response(data);
|
||||
});
|
||||
}
|
||||
,delay: 150
|
||||
,minLength: 2
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user