77 lines
2.3 KiB
Perl
77 lines
2.3 KiB
Perl
package App::Netdisco::Web::Plugin::AdminTask::JobQueue;
|
|
|
|
use Dancer ':syntax';
|
|
use Dancer::Plugin::Ajax;
|
|
use Dancer::Plugin::DBIC;
|
|
use Dancer::Plugin::Auth::Extensible;
|
|
|
|
use App::Netdisco::Web::Plugin;
|
|
use App::Netdisco::JobQueue qw/jq_log jq_delete/;
|
|
|
|
register_admin_task({
|
|
tag => 'jobqueue',
|
|
label => 'Job Queue',
|
|
});
|
|
|
|
ajax '/ajax/control/admin/jobqueue/del' => require_role admin => sub {
|
|
send_error('Missing job', 400) unless param('job');
|
|
jq_delete( param('job') );
|
|
};
|
|
|
|
ajax '/ajax/control/admin/jobqueue/delall' => require_role admin => sub {
|
|
jq_delete();
|
|
};
|
|
|
|
sub commify {
|
|
my $text = reverse $_[0];
|
|
$text =~ s/(\d\d\d)(?=\d)(?!\d*\.)/$1,/g;
|
|
return scalar reverse $text;
|
|
}
|
|
|
|
ajax '/ajax/content/admin/jobqueue' => require_role admin => sub {
|
|
content_type('text/html');
|
|
|
|
my @backends = schema(vars->{'tenant'})->resultset('DeviceSkip')
|
|
->search({device => '255.255.255.255'})->hri->all;
|
|
|
|
my $num_backends = scalar keys @backends;
|
|
my $tot_workers = 0;
|
|
$tot_workers += $_->{deferrals} for @backends;
|
|
|
|
my $jq_locked = schema(vars->{'tenant'})->resultset('Admin')
|
|
->search({status => 'queued', backend => { '!=' => undef }})->count();
|
|
|
|
my $jq_backlog = schema(vars->{'tenant'})->resultset('Admin')
|
|
->search({status => 'queued', backend => undef })->count();
|
|
|
|
my $jq_done = schema(vars->{'tenant'})->resultset('Admin')
|
|
->search({status => 'done'})->count();
|
|
|
|
my $jq_errored = schema(vars->{'tenant'})->resultset('Admin')
|
|
->search({status => 'error'})->count();
|
|
|
|
my $jq_stale = schema(vars->{'tenant'})->resultset('Admin')->search({
|
|
status => 'queued',
|
|
backend => { '!=' => undef },
|
|
started => \[q/<= (LOCALTIMESTAMP - ?::interval)/, setting('jobs_stale_after')],
|
|
})->count();
|
|
|
|
my $jq_total = schema(vars->{'tenant'})->resultset('Admin')->count();
|
|
|
|
template 'ajax/admintask/jobqueue.tt', {
|
|
num_backends => commify($num_backends || '?'),
|
|
tot_workers => commify($tot_workers || '?'),
|
|
|
|
jq_running => commify($jq_locked - $jq_stale),
|
|
jq_backlog => commify($jq_backlog),
|
|
jq_done => commify($jq_done),
|
|
jq_errored => commify($jq_errored),
|
|
jq_stale => commify($jq_stale),
|
|
jq_total => commify($jq_total),
|
|
|
|
results => [ jq_log ],
|
|
}, { layout => undef };
|
|
};
|
|
|
|
true;
|