gather lldp remote capabilities and info
This commit is contained in:
@@ -13,6 +13,18 @@ __PACKAGE__->add_columns(
|
|||||||
{ data_type => "text", is_nullable => 0 },
|
{ data_type => "text", is_nullable => 0 },
|
||||||
"error_disable_cause",
|
"error_disable_cause",
|
||||||
{ data_type => "text", is_nullable => 1 },
|
{ data_type => "text", is_nullable => 1 },
|
||||||
|
"remote_is_wap",
|
||||||
|
{ data_type => "boolean", is_nullable => 1 },
|
||||||
|
"remote_is_phone",
|
||||||
|
{ data_type => "boolean", is_nullable => 1 },
|
||||||
|
"remote_vendor",
|
||||||
|
{ data_type => "text", is_nullable => 1 },
|
||||||
|
"remote_os_ver",
|
||||||
|
{ data_type => "text", is_nullable => 1 },
|
||||||
|
"remote_model",
|
||||||
|
{ data_type => "text", is_nullable => 1 },
|
||||||
|
"remote_serial",
|
||||||
|
{ data_type => "text", is_nullable => 1 },
|
||||||
);
|
);
|
||||||
__PACKAGE__->set_primary_key("port", "ip");
|
__PACKAGE__->set_primary_key("port", "ip");
|
||||||
|
|
||||||
|
|||||||
@@ -15,33 +15,54 @@ register_worker({ phase => 'main', driver => 'snmp' }, sub {
|
|||||||
my $snmp = App::Netdisco::Transport::SNMP->reader_for($device)
|
my $snmp = App::Netdisco::Transport::SNMP->reader_for($device)
|
||||||
or return Status->defer("discover failed: could not SNMP connect to $device");
|
or return Status->defer("discover failed: could not SNMP connect to $device");
|
||||||
|
|
||||||
my $interfaces = $snmp->interfaces;
|
my $interfaces = $snmp->interfaces || {};
|
||||||
my $err_cause = $snmp->i_err_disable_cause;
|
my $err_cause = $snmp->i_err_disable_cause || {};
|
||||||
|
|
||||||
if (!defined $err_cause or !defined $interfaces) {
|
my %properties = ();
|
||||||
return Status->info(sprintf ' [%s] props - 0 errored ports', $device->ip);
|
foreach my $idx (keys %$err_cause) {
|
||||||
}
|
my $port = $interfaces->{$idx};
|
||||||
|
|
||||||
# build device port properties info suitable for DBIC
|
|
||||||
my @portproperties;
|
|
||||||
foreach my $entry (keys %$err_cause) {
|
|
||||||
my $port = $interfaces->{$entry};
|
|
||||||
next unless $port;
|
next unless $port;
|
||||||
|
|
||||||
push @portproperties, {
|
$properties{ $port }->{error_disable_cause} = $err_cause->{$idx};
|
||||||
port => $port,
|
|
||||||
error_disable_cause => $err_cause->{$entry},
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $lldp_if = $snmp->lldp_if || {};
|
||||||
|
my $lldp_cap = $snmp->lldp_cap || {};
|
||||||
|
my $rem_media_cap = $snmp->lldp_media_cap || {};
|
||||||
|
my $rem_vendor = $snmp->lldp_rem_vendor || {};
|
||||||
|
my $rem_model = $snmp->lldp_rem_model || {};
|
||||||
|
my $rem_os_ver = $snmp->lldp_rem_sw_rev || {};
|
||||||
|
my $rem_serial = $snmp->lldp_rem_serial || {};
|
||||||
|
|
||||||
|
foreach my $idx (keys %$lldp_if) {
|
||||||
|
my $port = $interfaces->{ $lldp_if->{$idx} };
|
||||||
|
next unless $port;
|
||||||
|
|
||||||
|
$properties{ $port }->{remote_is_wap} = 'true'
|
||||||
|
if scalar grep {defined && m/^wlanAccessPoint$/} @{ $lldp_cap->{$idx} };
|
||||||
|
$properties{ $port }->{remote_is_phone} = 'true'
|
||||||
|
if scalar grep {defined && m/^telephone$/} @{ $lldp_cap->{$idx} };
|
||||||
|
|
||||||
|
next unless scalar grep {defined && m/^inventory$/} @{ $rem_media_cap->{$idx} };
|
||||||
|
|
||||||
|
$properties{ $port }->{remote_vendor} = $rem_vendor->{ $idx };
|
||||||
|
$properties{ $port }->{remote_model} = $rem_model->{ $idx };
|
||||||
|
$properties{ $port }->{remote_os_ver} = $rem_os_ver->{ $idx };
|
||||||
|
$properties{ $port }->{remote_serial} = $rem_serial->{ $idx };
|
||||||
|
}
|
||||||
|
|
||||||
|
return Status->info(" [$device] no port properties to record")
|
||||||
|
unless scalar keys %properties;
|
||||||
|
|
||||||
schema('netdisco')->txn_do(sub {
|
schema('netdisco')->txn_do(sub {
|
||||||
my $gone = $device->properties_ports->delete;
|
my $gone = $device->properties_ports->delete;
|
||||||
debug sprintf ' [%s] props - removed %d ports with properties',
|
debug sprintf ' [%s] props - removed %d ports with properties',
|
||||||
$device->ip, $gone;
|
$device->ip, $gone;
|
||||||
$device->properties_ports->populate(\@portproperties);
|
$device->properties_ports->populate(
|
||||||
|
[map {{ port => $_, %{ $properties{$_} } }} keys %properties] );
|
||||||
|
|
||||||
return Status->info(sprintf ' [%s] props - added %d new port properties',
|
return Status->info(sprintf ' [%s] props - added %d new port properties',
|
||||||
$device->ip, scalar @portproperties);
|
$device->ip, scalar keys %properties);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
BEGIN;
|
BEGIN;
|
||||||
|
|
||||||
ALTER TABLE device_port_properties ADD COLUMN "remote_is_wap" bool DEFAULT false NOT NULL;
|
ALTER TABLE device_port_properties ADD COLUMN "remote_is_wap" bool DEFAULT false;
|
||||||
ALTER TABLE device_port_properties ADD COLUMN "remote_is_phone" bool DEFAULT false NOT NULL;
|
ALTER TABLE device_port_properties ADD COLUMN "remote_is_phone" bool DEFAULT false;
|
||||||
ALTER TABLE device_port_properties ADD COLUMN "remote_vendor" text;
|
ALTER TABLE device_port_properties ADD COLUMN "remote_vendor" text;
|
||||||
ALTER TABLE device_port_properties ADD COLUMN "remote_model" text;
|
ALTER TABLE device_port_properties ADD COLUMN "remote_model" text;
|
||||||
ALTER TABLE device_port_properties ADD COLUMN "remote_os_ver" text;
|
ALTER TABLE device_port_properties ADD COLUMN "remote_os_ver" text;
|
||||||
|
|||||||
Reference in New Issue
Block a user