add macsuck and arpnip hooks, add debug on hook queue

This commit is contained in:
Oliver Gorwits
2020-12-29 18:15:58 +00:00
parent dae4a1d1f6
commit 28349eb489
3 changed files with 70 additions and 4 deletions

View File

@@ -0,0 +1,31 @@
package App::Netdisco::Worker::Plugin::Arpnip::Hooks;
use Dancer ':syntax';
use App::Netdisco::Worker::Plugin;
use aliased 'App::Netdisco::Worker::Status';
use App::Netdisco::Util::Worker;
use App::Netdisco::Util::Permission qw/check_acl_no check_acl_only/;
register_worker({ phase => 'late' }, sub {
my ($job, $workerconf) = @_;
my $count = 0;
foreach my $conf (@{ setting('hooks') }) {
my $no = ($conf->{'filter'}->{'no'} || []);
my $only = ($conf->{'filter'}->{'only'} || []);
next if check_acl_no( $job->device, $no );
next unless check_acl_only( $job->device, $only);
if ($conf->{'event'} eq 'arpnip') {
$count += queue_hook('arpnip', $conf);
sprintf ' [%s] hooks - %s queued', 'arpnip', $job->device;
}
}
return Status
->info(sprintf ' [%s] hooks - %d queued', $job->device, $count);
});
true;

View File

@@ -18,11 +18,15 @@ register_worker({ phase => 'late' }, sub {
next if check_acl_no( $job->device, $no );
next unless check_acl_only( $job->device, $only);
$count += queue_hook('new_device', $conf)
if vars->{'new_device'} and $conf->{'event'} eq 'new_device';
if (vars->{'new_device'} and $conf->{'event'} eq 'new_device') {
$count += queue_hook('new_device', $conf);
debug sprintf ' [%s] hooks - %s queued', 'new_device', $job->device;
}
$count += queue_hook('discover', $conf)
if $conf->{'event'} eq 'discover';
if ($conf->{'event'} eq 'discover') {
$count += queue_hook('discover', $conf);
debug sprintf ' [%s] hooks - %s queued', 'discover', $job->device;
}
}
return Status

View File

@@ -0,0 +1,31 @@
package App::Netdisco::Worker::Plugin::Macsuck::Hooks;
use Dancer ':syntax';
use App::Netdisco::Worker::Plugin;
use aliased 'App::Netdisco::Worker::Status';
use App::Netdisco::Util::Worker;
use App::Netdisco::Util::Permission qw/check_acl_no check_acl_only/;
register_worker({ phase => 'late' }, sub {
my ($job, $workerconf) = @_;
my $count = 0;
foreach my $conf (@{ setting('hooks') }) {
my $no = ($conf->{'filter'}->{'no'} || []);
my $only = ($conf->{'filter'}->{'only'} || []);
next if check_acl_no( $job->device, $no );
next unless check_acl_only( $job->device, $only);
if ($conf->{'event'} eq 'macsuck') {
$count += queue_hook('macsuck', $conf);
sprintf ' [%s] hooks - %s queued', 'macsuck', $job->device;
}
}
return Status
->info(sprintf ' [%s] hooks - %d queued', $job->device, $count);
});
true;