node search by mac implementation
This commit is contained in:
26
Netdisco/lib/Netdisco/DB/ResultSet/Node.pm
Normal file
26
Netdisco/lib/Netdisco/DB/ResultSet/Node.pm
Normal file
@@ -0,0 +1,26 @@
|
||||
package Netdisco::DB::ResultSet::Node;
|
||||
use base 'DBIx::Class::ResultSet';
|
||||
|
||||
sub by_mac {
|
||||
my ($set, $archive, $mac) = @_;
|
||||
return $set unless $mac;
|
||||
|
||||
return $set->search(
|
||||
{
|
||||
'me.mac' => $mac,
|
||||
($archive ? () : (active => 1)),
|
||||
},
|
||||
{
|
||||
order_by => {'-desc' => 'time_last'},
|
||||
columns => [qw/ mac switch port oui active device.dns /],
|
||||
'+select' => [
|
||||
\"to_char(time_first, 'YYYY-MM-DD HH24:MI')",
|
||||
\"to_char(time_last, 'YYYY-MM-DD HH24:MI')",
|
||||
],
|
||||
'+as' => [qw/ time_first time_last /],
|
||||
join => 'device',
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
1;
|
||||
@@ -57,4 +57,20 @@ sub by_name {
|
||||
);
|
||||
}
|
||||
|
||||
sub by_mac {
|
||||
my ($set, $archive, $mac) = @_;
|
||||
return $set unless $mac;
|
||||
|
||||
return $set->search(
|
||||
{
|
||||
mac => $mac,
|
||||
($archive ? () : (active => 1)),
|
||||
},
|
||||
{
|
||||
%$search_attr,
|
||||
( $set->has_dns_col ? ('+columns' => 'dns') : () ),
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
Reference in New Issue
Block a user