update undiscovered neighbors and port properties discovery to use remote_is_discoverable
This commit is contained in:
		| @@ -15,7 +15,7 @@ __PACKAGE__->result_source_instance->view_definition(<<'ENDSQL'); | |||||||
|     d.ip, d.name, d.dns, |     d.ip, d.name, d.dns, | ||||||
|     p.port, p.name AS port_description, |     p.port, p.name AS port_description, | ||||||
|     p.remote_ip, p.remote_id, p.remote_type, p.remote_port, |     p.remote_ip, p.remote_id, p.remote_type, p.remote_port, | ||||||
|     dpp.remote_is_wap, dpp.remote_is_phone, |     dpp.remote_is_discoverable, dpp.remote_is_wap, dpp.remote_is_phone, | ||||||
|     l.log AS comment, |     l.log AS comment, | ||||||
|     a.log, a.finished |     a.log, a.finished | ||||||
|  |  | ||||||
| @@ -31,6 +31,7 @@ __PACKAGE__->result_source_instance->view_definition(<<'ENDSQL'); | |||||||
|  |  | ||||||
|   WHERE |   WHERE | ||||||
|     ds.device IS NULL |     ds.device IS NULL | ||||||
|  |     AND dpp.remote_is_discoverable | ||||||
|     AND ((p.remote_ip NOT IN (SELECT alias FROM device_ip)) |     AND ((p.remote_ip NOT IN (SELECT alias FROM device_ip)) | ||||||
|          OR ((p.remote_ip IS NULL) AND p.is_uplink)) |          OR ((p.remote_ip IS NULL) AND p.is_uplink)) | ||||||
|  |  | ||||||
| @@ -60,6 +61,8 @@ __PACKAGE__->add_columns( | |||||||
|   { data_type => "text", is_nullable => 1 }, |   { data_type => "text", is_nullable => 1 }, | ||||||
|   "remote_id", |   "remote_id", | ||||||
|   { data_type => "text", is_nullable => 1 }, |   { data_type => "text", is_nullable => 1 }, | ||||||
|  |   "remote_is_discoverable", | ||||||
|  |   { data_type => "boolean", is_nullable => 1 }, | ||||||
|   "remote_is_wap", |   "remote_is_wap", | ||||||
|   { data_type => "boolean", is_nullable => 1 }, |   { data_type => "boolean", is_nullable => 1 }, | ||||||
|   "remote_is_phone", |   "remote_is_phone", | ||||||
|   | |||||||
| @@ -21,27 +21,15 @@ get '/ajax/content/admin/undiscoveredneighbors' => require_role admin => sub { | |||||||
|         = schema('netdisco')->resultset('Virtual::UndiscoveredNeighbors')->hri->all; |         = schema('netdisco')->resultset('Virtual::UndiscoveredNeighbors')->hri->all; | ||||||
|     return unless scalar @results; |     return unless scalar @results; | ||||||
|  |  | ||||||
|     # Don't include devices excluded from discovery by config |  | ||||||
|     my @discoverable_results = (); |  | ||||||
|     foreach my $r (@results) { |  | ||||||
|       # create a new row object to avoid hitting the DB in get_device() |  | ||||||
|       my $dev = schema('netdisco')->resultset('Device')->new({ip => $r->{remote_ip}}); |  | ||||||
|       next unless is_discoverable( $dev, $r->{remote_type} ); |  | ||||||
|       next if (not setting('discover_waps')) and $r->{remote_is_wap}; |  | ||||||
|       next if (not setting('discover_phones')) and $r->{remote_is_phone}; |  | ||||||
|       push @discoverable_results, $r; |  | ||||||
|     } |  | ||||||
|     return unless scalar @discoverable_results; |  | ||||||
|  |  | ||||||
|     if ( request->is_ajax ) { |     if ( request->is_ajax ) { | ||||||
|         template 'ajax/admintask/undiscoveredneighbors.tt', |         template 'ajax/admintask/undiscoveredneighbors.tt', | ||||||
|             { results => \@discoverable_results, }, |             { results => \@results, }, | ||||||
|             { layout  => undef }; |             { layout  => undef }; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         header( 'Content-Type' => 'text/comma-separated-values' ); |         header( 'Content-Type' => 'text/comma-separated-values' ); | ||||||
|         template 'ajax/admintask/undiscoveredneighbors_csv.tt', |         template 'ajax/admintask/undiscoveredneighbors_csv.tt', | ||||||
|             { results => \@discoverable_results, }, |             { results => \@results, }, | ||||||
|             { layout  => undef }; |             { layout  => undef }; | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ use App::Netdisco::Transport::SNMP (); | |||||||
| use Dancer::Plugin::DBIC 'schema'; | use Dancer::Plugin::DBIC 'schema'; | ||||||
|  |  | ||||||
| use Encode; | use Encode; | ||||||
| use App::Netdisco::Util::Device 'match_to_setting'; | use App::Netdisco::Util::Device qw/is_discoverable match_to_setting/; | ||||||
|  |  | ||||||
| register_worker({ phase => 'main', driver => 'snmp' }, sub { | register_worker({ phase => 'main', driver => 'snmp' }, sub { | ||||||
|   my ($job, $workerconf) = @_; |   my ($job, $workerconf) = @_; | ||||||
| @@ -93,6 +93,9 @@ register_worker({ phase => 'main', driver => 'snmp' }, sub { | |||||||
|       if scalar grep {match_to_setting($_, 'phone_capabilities')} @$remote_cap |       if scalar grep {match_to_setting($_, 'phone_capabilities')} @$remote_cap | ||||||
|          or match_to_setting($remote_type, 'phone_platforms'); |          or match_to_setting($remote_type, 'phone_platforms'); | ||||||
|  |  | ||||||
|  |     $properties{ $port }->{remote_is_discoverable} = 'false' | ||||||
|  |       unless is_discoverable($device_ports->{$port}->remote_ip, $remote_type, $remote_cap); | ||||||
|  |  | ||||||
|     next unless scalar grep {defined && m/^inventory$/} @{ $rem_media_cap->{$idx} }; |     next unless scalar grep {defined && m/^inventory$/} @{ $rem_media_cap->{$idx} }; | ||||||
|  |  | ||||||
|     $properties{ $port }->{remote_vendor} = $rem_vendor->{ $idx }; |     $properties{ $port }->{remote_vendor} = $rem_vendor->{ $idx }; | ||||||
|   | |||||||
| @@ -2,4 +2,6 @@ BEGIN; | |||||||
|  |  | ||||||
| ALTER TABLE device_port_properties ADD COLUMN "remote_is_discoverable" bool DEFAULT true; | ALTER TABLE device_port_properties ADD COLUMN "remote_is_discoverable" bool DEFAULT true; | ||||||
|  |  | ||||||
|  | UPDATE device_port_properties SET remote_is_discoverable = true; | ||||||
|  |  | ||||||
| COMMIT; | COMMIT; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user