* initial work * initial work * initial work * some fixes for time and Layer3 weird spec * store again the snapshot after update for specific * resolve the enums * monkeypatch SNMP::translateObj to avoid hardware exception on macOS * only save cache to db in the late phase worker * no need to check for cache on transport, can just go ahead and try * use database only for oidmap instead of netdisco-mibs * rewrite device snapshot to gather loaded mib leafs only * remove old walker code from snapshot worker * allow snmp browser to work without snapshot * only store snapshot leafs which the device responded on * refactor to separate snapshot work from snmp transport work * refactor to separate snapshot work from snmp transport work * allow typeahead on MIB qualified leafs * fixes for snmpwalk input after previous refactor * add the extra stuff SNMP::Info device class uses into snapshot * better width for snmp search box * fix css for snmp options * add spinner while snmp loading * add spinner while snmp loading * add spinner while snmp loading * support SNMP::Info device class or named MIBs as extra on snapshot * add final tidy and bug fix
35 lines
979 B
Perl
35 lines
979 B
Perl
package App::Netdisco::Worker::Plugin::Discover::Snapshot;
|
|
|
|
use Dancer ':syntax';
|
|
use Dancer::Plugin::DBIC 'schema';
|
|
|
|
use App::Netdisco::Worker::Plugin;
|
|
use App::Netdisco::Transport::SNMP ();
|
|
use App::Netdisco::Util::Snapshot 'dump_cache_to_browserdata';
|
|
|
|
use Storable 'nfreeze';
|
|
use MIME::Base64 'encode_base64';
|
|
|
|
use aliased 'App::Netdisco::Worker::Status';
|
|
|
|
register_worker({ phase => 'late' }, sub {
|
|
my ($job, $workerconf) = @_;
|
|
my $device = $job->device;
|
|
|
|
my $snmp = App::Netdisco::Transport::SNMP->reader_for($device)
|
|
or return Status->defer("discover failed: could not SNMP connect to $device");
|
|
|
|
return unless $device->in_storage
|
|
and not $device->oids->count and $snmp->offline;
|
|
|
|
dump_cache_to_browserdata( $device, $snmp );
|
|
|
|
my $frozen = encode_base64( nfreeze( $snmp->cache ) );
|
|
$device->update_or_create_related('snapshot', { cache => $frozen });
|
|
|
|
return Status
|
|
->info(sprintf ' [%s] discover - oids and cache stored', $device);
|
|
});
|
|
|
|
true;
|