HEX
Server: Apache/2.4.29 (Ubuntu)
System: Linux bareserver 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64
User: root (0)
PHP: 7.2.24-0ubuntu0.18.04.17
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: //usr/share/webmin/cluster-cron/exec.cgi
#!/usr/bin/perl
# exec.cgi
# Run the cron job on all configured servers

require './cluster-cron-lib.pl';
&ReadParse();

&ui_print_unbuffered_header(undef, $text{'exec_title'}, "");

# Run on all servers and show output
@jobs = &list_cluster_jobs();
($job) = grep { $_->{'cluster_id'} eq $in{'id'} } @jobs;
$job || &error($text{'edit_emissing'});
print &text('exec_cmd', "<tt>$job->{'cluster_command'}</tt>"),"<p>\n";
@run = &run_cluster_job($job, \&callback);
if (!@run) {
	print "$text{'exec_nohosts'}<p>\n";
	}

$job->{'run'} = [ map { $_->{'host'} } @run ];	# for logging
&webmin_log("exec", "cron", $job->{'cluster_user'}, $job);

&ui_print_footer("edit.cgi?id=$in{'id'}", $cron::text{'edit_return'},
	"", $text{'index_return'});

# callback(error, &server, message)
sub callback
{
local $d = ($_[1]->{'host'} || &get_system_hostname()).
	   ($_[1]->{'desc'} ? " ($_[1]->{'desc'})" : "");
if (!$_[0]) {
	# Failed - show error
	print "<b>",&text('exec_failed', $d, $_[2]),"</b><p>\n";
	}
else {
	# Show output if any
	print "<b>",&text('exec_success', $d),"</b>\n";
	if ($_[2]) {
		print "<ul><pre>$_[2]</pre></ul><p>\n";
		}
	else {
		print "<br><ul><i>$cron::text{'exec_none'}</i></ul><p>\n";
		}
	}
}