kivitendo/scripts/task_server.pl @ 2c1c6a9a
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;
|
||||
e08abae0 | Moritz Bunkus | our %lx_office_conf;
|
||
149d2f33 | Moritz Bunkus | |||
# 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 {
|
||||
e08abae0 | Moritz Bunkus | my $login = $lx_office_conf{task_server}->{login};
|
||
149d2f33 | Moritz Bunkus | |||
package main;
|
||||
$::lxdebug = LXDebug->new;
|
||||
be6f6cfd | Moritz Bunkus | $::locale = Locale->new($::lx_office_conf{system}->{language});
|
||
149d2f33 | Moritz Bunkus | $::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 {
|
||
e08abae0 | Moritz Bunkus | my $user = $lx_office_conf{task_server}->{run_as};
|
||
7056eb31 | Moritz Bunkus | 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;
|
||||
e08abae0 | Moritz Bunkus | read_config $self->{configfile} => %lx_office_conf;
|
||
149d2f33 | Moritz Bunkus | |||
e08abae0 | Moritz Bunkus | die "Missing section [task_server] in config file" unless $lx_office_conf{task_server};
|
||
die "Missing key 'login' in section [task_server] in config file" unless $lx_office_conf{task_server}->{login};
|
||||
149d2f33 | Moritz Bunkus | |||
7056eb31 | Moritz Bunkus | drop_privileges();
|
||
149d2f33 | Moritz Bunkus | lxinit();
|
||
return ();
|
||||
}
|
||||
sub gd_run {
|
||||
while (1) {
|
||||
my $ok = eval {
|
||||
e08abae0 | Moritz Bunkus | $::lxdebug->message(0, "Retrieving jobs") if $lx_office_conf{task_server}->{debug};
|
||
149d2f33 | Moritz Bunkus | |||
my $jobs = SL::DB::Manager::BackgroundJob->get_all_need_to_run;
|
||||
e08abae0 | Moritz Bunkus | $::lxdebug->message(0, " Found: " . join(' ', map { $_->package_name } @{ $jobs })) if $lx_office_conf{task_server}->{debug} && @{ $jobs };
|
||
149d2f33 | Moritz Bunkus | |||
f6669610 | Moritz Bunkus | foreach my $job (@{ $jobs }) {
|
||
# Provide fresh global variables in case legacy code modifies
|
||||
# them somehow.
|
||||
be6f6cfd | Moritz Bunkus | $::locale = Locale->new($::lx_office_conf{system}->{language});
|
||
f6669610 | Moritz Bunkus | $::form = Form->new;
|
||
$job->run;
|
||||
}
|
||||
149d2f33 | Moritz Bunkus | |||
1;
|
||||
};
|
||||
e08abae0 | Moritz Bunkus | if ($lx_office_conf{task_server}->{debug}) {
|
||
149d2f33 | Moritz Bunkus | $::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;
|