kivitendo/scripts/task_server.pl @ 54d656bd
149d2f33 | Moritz Bunkus | #!/usr/bin/perl
|
||
use strict;
|
||||
BEGIN {
|
||||
88e5a86e | Moritz Bunkus | require Cwd;
|
||
my $dir = $0;
|
||||
$dir = Cwd::getcwd() . '/' . $dir unless $dir =~ m|^/|;
|
||||
$dir =~ s|[^/]+$|..|;
|
||||
chdir($dir) || die "Cannot change directory to ${dir}\n";
|
||||
149d2f33 | Moritz Bunkus | unshift @INC, "modules/override"; # Use our own versions of various modules (e.g. YAML).
|
||
push @INC, "modules/fallback"; # Only use our own versions of modules if there's no system version.
|
||||
}
|
||||
use CGI qw( -no_xhtml);
|
||||
use Config::Std;
|
||||
use Cwd;
|
||||
use Daemon::Generic;
|
||||
use Data::Dumper;
|
||||
use DateTime;
|
||||
use English qw(-no_match_vars);
|
||||
7056eb31 | Moritz Bunkus | use POSIX qw(setuid setgid);
|
||
149d2f33 | Moritz Bunkus | use SL::Auth;
|
||
use SL::DB::BackgroundJob;
|
||||
use SL::BackgroundJob::ALL;
|
||||
use SL::Form;
|
||||
use SL::Helper::DateTime;
|
||||
use SL::LXDebug;
|
||||
use SL::Locale;
|
||||
my %config;
|
||||
# this is a cleaned up version of am.pl
|
||||
# it lacks redirection, some html setup and most of the authentication process.
|
||||
# it is assumed that anyone with physical access and execution rights on this script
|
||||
# won't be hindered by authentication anyway.
|
||||
sub lxinit {
|
||||
my $login = $config{task_server}->{login};
|
||||
package main;
|
||||
{ no warnings 'once';
|
||||
$::userspath = "users";
|
||||
$::templates = "templates";
|
||||
$::sendmail = "| /usr/sbin/sendmail -t";
|
||||
}
|
||||
eval { require "config/lx-erp.conf"; 1; } or die $EVAL_ERROR;
|
||||
eval { require "config/lx-erp-local.conf"; 1; } or die $EVAL_ERROR if -f "config/lx-erp-local.conf";
|
||||
$::lxdebug = LXDebug->new;
|
||||
$::locale = Locale->new($::language);
|
||||
$::cgi = CGI->new qw();
|
||||
$::form = Form->new;
|
||||
$::auth = SL::Auth->new;
|
||||
die 'cannot reach auth db' unless $::auth->session_tables_present;
|
||||
$::auth->restore_session;
|
||||
require "bin/mozilla/common.pl";
|
||||
die "cannot find user $login" unless %::myconfig = $::auth->read_user($login);
|
||||
die "cannot find locale for user $login" unless $::locale = Locale->new('de');
|
||||
}
|
||||
7056eb31 | Moritz Bunkus | sub drop_privileges {
|
||
my $user = $::emmvee_conf{task_server}->{run_as};
|
||||
return unless $user;
|
||||
my ($uid, $gid);
|
||||
while (my @details = getpwent()) {
|
||||
next unless $details[0] eq $user;
|
||||
($uid, $gid) = @details[2, 3];
|
||||
last;
|
||||
}
|
||||
endpwent();
|
||||
if (!$uid) {
|
||||
print "Error: Cannot drop privileges to ${user}: user does not exist\n";
|
||||
exit 1;
|
||||
}
|
||||
if (!setgid($gid)) {
|
||||
print "Error: Cannot drop group privileges to ${user} (group ID $gid): $!\n";
|
||||
exit 1;
|
||||
}
|
||||
if (!setuid($uid)) {
|
||||
print "Error: Cannot drop user privileges to ${user} (user ID $uid): $!\n";
|
||||
exit 1;
|
||||
}
|
||||
}
|
||||
149d2f33 | Moritz Bunkus | sub gd_preconfig {
|
||
my $self = shift;
|
||||
read_config $self->{configfile} => %config;
|
||||
die "Missing section [task_server] in config file" unless $config{task_server};
|
||||
die "Missing key 'login' in section [task_server] in config file" unless $config{task_server}->{login};
|
||||
7056eb31 | Moritz Bunkus | drop_privileges();
|
||
149d2f33 | Moritz Bunkus | lxinit();
|
||
return ();
|
||||
}
|
||||
sub gd_run {
|
||||
while (1) {
|
||||
my $ok = eval {
|
||||
$::lxdebug->message(0, "Retrieving jobs") if $config{task_server}->{debug};
|
||||
my $jobs = SL::DB::Manager::BackgroundJob->get_all_need_to_run;
|
||||
$::lxdebug->message(0, " Found: " . join(' ', map { $_->package_name } @{ $jobs })) if $config{task_server}->{debug} && @{ $jobs };
|
||||
f6669610 | Moritz Bunkus | foreach my $job (@{ $jobs }) {
|
||
# Provide fresh global variables in case legacy code modifies
|
||||
# them somehow.
|
||||
$::locale = Locale->new($::language);
|
||||
$::form = Form->new;
|
||||
$job->run;
|
||||
}
|
||||
149d2f33 | Moritz Bunkus | |||
1;
|
||||
};
|
||||
if ($config{task_server}->{debug}) {
|
||||
$::lxdebug->message(0, "Exception during execution: ${EVAL_ERROR}") if !$ok;
|
||||
$::lxdebug->message(0, "Sleeping");
|
||||
}
|
||||
my $seconds = 60 - (localtime)[0];
|
||||
sleep($seconds < 30 ? $seconds + 60 : $seconds);
|
||||
}
|
||||
}
|
||||
my $cwd = getcwd();
|
||||
my $pidbase = "${cwd}/users/pid";
|
||||
mkdir($pidbase) if !-d $pidbase;
|
||||
f04a7950 | Moritz Bunkus | newdaemon(configfile => "${cwd}/config/lx_office.conf",
|
||
149d2f33 | Moritz Bunkus | progname => 'lx-office-task-server',
|
||
pidbase => "${pidbase}/",
|
||||
);
|
||||
1;
|