Files
netdisco/lib/App/Netdisco/Web/Plugin/Device/Details.pm
2023-03-08 22:56:18 +00:00

52 lines
1.5 KiB
Perl

package App::Netdisco::Web::Plugin::Device::Details;
use Dancer ':syntax';
use Dancer::Plugin::Ajax;
use Dancer::Plugin::DBIC;
use Dancer::Plugin::Auth::Extensible;
use App::Netdisco::Web::Plugin;
register_device_tab({ tag => 'details', label => 'Details' });
# device details table
ajax '/ajax/content/device/details' => require_login sub {
my $q = param('q');
my $device = schema(vars->{'tenant'})->resultset('Device')
->search_for_device($q) or send_error('Bad device', 400);
my @results
= schema(vars->{'tenant'})->resultset('Device')
->search({ 'me.ip' => $device->ip },
{
'+select' => ['snapshot.ip'],
'+as' => ['has_snapshot'],
join => 'snapshot',
},
)->with_times->with_custom_fields->hri->all;
my @power
= schema(vars->{'tenant'})->resultset('DevicePower')
->search( { 'me.ip' => $device->ip } )->with_poestats->hri->all;
my @interfaces = $device->device_ips->hri->all;
my @serials = $device->modules->search({
class => 'chassis',
-bool => 'fru',
-and => [
{ serial => { '!=' => '' } },
{ serial => { '!=' => undef } },
],
})->order_by('pos')->get_column('serial')->all;
content_type('text/html');
template 'ajax/device/details.tt', {
d => $results[0], p => \@power,
interfaces => \@interfaces,
serials => [sort keys %{ { map {($_ => $_)} (@serials, ($device->serial ? $device->serial : ())) } }],
}, { layout => undef };
};
1;