9 use lib "$FindBin::Bin/..";
11 use SL::System::Process;
12 $exe_dir = SL::System::Process::exe_dir;
14 unshift @INC, "${exe_dir}/modules/override"; # Use our own versions of various modules (e.g. YAML).
15 push @INC, "${exe_dir}/modules/fallback"; # Only use our own versions of modules if there's no system version.
16 unshift @INC, $exe_dir;
18 chdir($exe_dir) || die "Cannot change directory to ${exe_dir}\n";
21 use CGI qw( -no_xhtml);
26 use English qw(-no_match_vars);
28 use List::Util qw(first);
29 use POSIX qw(setuid setgid);
31 use SL::DB::BackgroundJob;
32 use SL::BackgroundJob::ALL;
34 use SL::Helper::DateTime;
35 use SL::InstanceConfiguration;
39 use SL::System::TaskServer;
44 my $login = $lx_office_conf{task_server}->{login};
48 $::lxdebug = LXDebug->new;
49 $::locale = Locale->new($::lx_office_conf{system}->{language});
51 $::auth = SL::Auth->new;
52 $::instance_conf = SL::InstanceConfiguration->new;
53 $::request = { cgi => CGI->new({}) };
55 die 'cannot reach auth db' unless $::auth->session_tables_present;
57 $::auth->restore_session;
59 require "bin/mozilla/common.pl";
61 die "cannot find user $login" unless %::myconfig = $::auth->read_user(login => $login);
62 die "cannot find locale for user $login" unless $::locale = Locale->new('de');
66 my $user = $lx_office_conf{task_server}->{run_as};
70 while (my @details = getpwent()) {
71 next unless $details[0] eq $user;
72 ($uid, $gid) = @details[2, 3];
78 print "Error: Cannot drop privileges to ${user}: user does not exist\n";
83 print "Error: Cannot drop group privileges to ${user} (group ID $gid): $!\n";
88 print "Error: Cannot drop user privileges to ${user} (user ID $uid): $!\n";
96 SL::LxOfficeConf->read($self->{configfile});
98 die "Missing section [task_server] in config file" unless $lx_office_conf{task_server};
99 die "Missing key 'login' in section [task_server] in config file" unless $lx_office_conf{task_server}->{login};
110 $::lxdebug->message(0, "Retrieving jobs") if $lx_office_conf{task_server}->{debug};
112 my $jobs = SL::DB::Manager::BackgroundJob->get_all_need_to_run;
114 $::lxdebug->message(0, " Found: " . join(' ', map { $_->package_name } @{ $jobs })) if $lx_office_conf{task_server}->{debug} && @{ $jobs };
116 foreach my $job (@{ $jobs }) {
117 # Provide fresh global variables in case legacy code modifies
119 $::locale = Locale->new($::lx_office_conf{system}->{language});
130 if ($lx_office_conf{task_server}->{debug}) {
131 $::lxdebug->message(0, "Exception during execution: ${EVAL_ERROR}") if !$ok;
132 $::lxdebug->message(0, "Sleeping");
135 my $seconds = 60 - (localtime)[0];
137 local $SIG{'ALRM'} = sub {
138 $::lxdebug->message(0, "Got woken up by SIGALRM") if $lx_office_conf{task_server}->{debug};
141 sleep($seconds < 30 ? $seconds + 60 : $seconds);
144 die $@ unless $@ eq "Alarm!\n";
151 mkdir SL::System::TaskServer::PID_BASE() if !-d SL::System::TaskServer::PID_BASE();
153 my $file = first { -f } ("${exe_dir}/config/kivitendo.conf", "${exe_dir}/config/lx_office.conf", "${exe_dir}/config/kivitendo.conf.default");
155 die "No configuration file found." unless $file;
157 $file = File::Spec->abs2rel(Cwd::abs_path($file), Cwd::abs_path($exe_dir));
159 newdaemon(configfile => $file,
160 progname => 'kivitendo-background-jobs',
161 pidbase => SL::System::TaskServer::PID_BASE() . '/',