initial implementatin of new job queue with skip info per job
This commit is contained in:
@@ -8,6 +8,11 @@ use Dancer::Plugin::Auth::Extensible;
|
||||
use App::Netdisco::Web::Plugin;
|
||||
use App::Netdisco::JobQueue qw/jq_log jq_delete/;
|
||||
|
||||
use utf8;
|
||||
use Time::Piece;
|
||||
use Text::CSV_XS 'csv';
|
||||
use NetAddr::IP::Lite ':lower';
|
||||
|
||||
register_admin_task({
|
||||
tag => 'jobqueue',
|
||||
label => 'Job Queue',
|
||||
@@ -23,9 +28,61 @@ ajax '/ajax/control/admin/jobqueue/delall' => require_role admin => sub {
|
||||
};
|
||||
|
||||
ajax '/ajax/content/admin/jobqueue' => require_role admin => sub {
|
||||
my $filter = NetAddr::IP::Lite->new(param('q'));
|
||||
my @data = jq_log($filter);
|
||||
|
||||
foreach my $r (@data) {
|
||||
$r->{qstat}->{acl} = [];
|
||||
$r->{qstat}->{next} = [];
|
||||
$r->{qstat}->{fails} = [];
|
||||
next unless ($r->{status} eq 'queued');
|
||||
|
||||
foreach my $s (@{$r->{skips}}) {
|
||||
(my $row = $s) =~ s/(^\(|\)$)//g;
|
||||
next unless $row;
|
||||
my %skip = @{ [@{csv(in => \$row)}]->[0] };
|
||||
next unless scalar keys %skip;
|
||||
$skip{actionset} =~ s/(^{|}$)//g;
|
||||
$skip{actionset} = [@{ csv(in => \$skip{actionset}) }]->[0] || [];
|
||||
|
||||
if ($skip{deferrals}) {
|
||||
unshift @{$r->{qstat}->{fails}}, sprintf '%s connection failure%s from %s',
|
||||
$skip{deferrals}, ($skip{deferrals} > 1 ? 's' : ''), $skip{backend};
|
||||
}
|
||||
else {
|
||||
unshift @{$r->{qstat}->{fails}}, sprintf 'No connection failures from %s',
|
||||
$skip{backend};
|
||||
}
|
||||
|
||||
if (scalar @{$skip{actionset}}
|
||||
and scalar grep {$_ eq $r->{action}} @{$skip{actionset}}) {
|
||||
$r->{qstat}->{badacl} = true;
|
||||
unshift @{$r->{qstat}->{acl}}, sprintf 'Blocked by ACL on %s', $skip{backend};
|
||||
}
|
||||
else {
|
||||
push @{$r->{qstat}->{acl}}, sprintf '✔ on %s', $skip{backend};
|
||||
}
|
||||
|
||||
if ($skip{deferrals} >= setting('workers')->{'max_deferrals'}) {
|
||||
$r->{qstat}->{last_defer} = true;
|
||||
my $after = (localtime($skip{last_defer}) + setting('workers')->{'retry_after'});
|
||||
unshift @{$r->{qstat}->{next}}, sprintf 'Will retry after %s on %s',
|
||||
$after->cdate, $skip{backend};
|
||||
}
|
||||
elsif ($skip{deferrals} > 0) {
|
||||
$r->{qstat}->{last_defer} = true;
|
||||
unshift @{$r->{qstat}->{next}}, sprintf 'Connect failed at %s on %s',
|
||||
localtime($skip{last_defer})->cdate, $skip{backend};
|
||||
}
|
||||
else {
|
||||
push @{$r->{qstat}->{next}}, sprintf '✔ on %s', $skip{backend};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
content_type('text/html');
|
||||
template 'ajax/admintask/jobqueue.tt', {
|
||||
results => [ jq_log ],
|
||||
results => \@data,
|
||||
}, { layout => undef };
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user