8 use SL::System::Process;
9 $exe_dir = SL::System::Process::exe_dir;
11 unshift @INC, "${exe_dir}/modules/override"; # Use our own versions of various modules (e.g. YAML).
12 push @INC, "${exe_dir}/modules/fallback"; # Only use our own versions of modules if there's no system version.
13 unshift @INC, $exe_dir;
15 chdir($exe_dir) || die "Cannot change directory to ${exe_dir}\n";
18 use CGI qw( -no_xhtml);
23 use English qw(-no_match_vars);
25 use List::Util qw(first);
26 use POSIX qw(setuid setgid);
28 use SL::DB::BackgroundJob;
29 use SL::BackgroundJob::ALL;
31 use SL::Helper::DateTime;
32 use SL::InstanceConfiguration;
36 use SL::System::TaskServer;
41 my $login = $lx_office_conf{task_server}->{login};
45 $::lxdebug = LXDebug->new;
46 $::locale = Locale->new($::lx_office_conf{system}->{language});
48 $::auth = SL::Auth->new;
49 $::instance_conf = SL::InstanceConfiguration->new;
50 $::request = { cgi => CGI->new({}) };
52 die 'cannot reach auth db' unless $::auth->session_tables_present;
54 $::auth->restore_session;
56 require "bin/mozilla/common.pl";
58 die "cannot find user $login" unless %::myconfig = $::auth->read_user(login => $login);
59 die "cannot find locale for user $login" unless $::locale = Locale->new('de');
63 my $user = $lx_office_conf{task_server}->{run_as};
67 while (my @details = getpwent()) {
68 next unless $details[0] eq $user;
69 ($uid, $gid) = @details[2, 3];
75 print "Error: Cannot drop privileges to ${user}: user does not exist\n";
80 print "Error: Cannot drop group privileges to ${user} (group ID $gid): $!\n";
85 print "Error: Cannot drop user privileges to ${user} (user ID $uid): $!\n";
93 SL::LxOfficeConf->read($self->{configfile});
95 die "Missing section [task_server] in config file" unless $lx_office_conf{task_server};
96 die "Missing key 'login' in section [task_server] in config file" unless $lx_office_conf{task_server}->{login};
107 $::lxdebug->message(0, "Retrieving jobs") if $lx_office_conf{task_server}->{debug};
109 my $jobs = SL::DB::Manager::BackgroundJob->get_all_need_to_run;
111 $::lxdebug->message(0, " Found: " . join(' ', map { $_->package_name } @{ $jobs })) if $lx_office_conf{task_server}->{debug} && @{ $jobs };
113 foreach my $job (@{ $jobs }) {
114 # Provide fresh global variables in case legacy code modifies
116 $::locale = Locale->new($::lx_office_conf{system}->{language});
127 if ($lx_office_conf{task_server}->{debug}) {
128 $::lxdebug->message(0, "Exception during execution: ${EVAL_ERROR}") if !$ok;
129 $::lxdebug->message(0, "Sleeping");
132 my $seconds = 60 - (localtime)[0];
134 local $SIG{'ALRM'} = sub {
135 $::lxdebug->message(0, "Got woken up by SIGALRM") if $lx_office_conf{task_server}->{debug};
138 sleep($seconds < 30 ? $seconds + 60 : $seconds);
141 die $@ unless $@ eq "Alarm!\n";
148 mkdir SL::System::TaskServer::PID_BASE() if !-d SL::System::TaskServer::PID_BASE();
150 my $file = first { -f } ("${exe_dir}/config/kivitendo.conf", "${exe_dir}/config/lx_office.conf", "${exe_dir}/config/kivitendo.conf.default");
152 die "No configuration file found." unless $file;
154 $file = File::Spec->abs2rel(Cwd::abs_path($file), Cwd::abs_path($exe_dir));
156 newdaemon(configfile => $file,
157 progname => 'kivitendo-task-server',
158 pidbase => SL::System::TaskServer::PID_BASE() . '/',