projects
/
kivitendo-erp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Revert "DB-Upgrade: Fehlendes "@charset" ergänzt"
[kivitendo-erp.git]
/
scripts
/
task_server.pl
diff --git
a/scripts/task_server.pl
b/scripts/task_server.pl
index
8c17ca7
..
3a45dd1
100755
(executable)
--- a/
scripts/task_server.pl
+++ b/
scripts/task_server.pl
@@
-2,17
+2,20
@@
use strict;
use strict;
+my $exe_dir;
+
BEGIN {
BEGIN {
- require Cwd;
+ use FindBin;
+ use lib "$FindBin::Bin/..";
- my $dir = $0;
- $dir = Cwd::getcwd() . '/' . $dir unless $dir =~ m|^/|;
- $dir =~ s|[^/]+$|..|;
+ use SL::System::Process;
+ $exe_dir = SL::System::Process::exe_dir;
- chdir($dir) || die "Cannot change directory to ${dir}\n";
+ unshift @INC, "${exe_dir}/modules/override"; # Use our own versions of various modules (e.g. YAML).
+ push @INC, "${exe_dir}/modules/fallback"; # Only use our own versions of modules if there's no system version.
+ unshift @INC, $exe_dir;
- 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.
+ chdir($exe_dir) || die "Cannot change directory to ${exe_dir}\n";
}
use CGI qw( -no_xhtml);
}
use CGI qw( -no_xhtml);
@@
-21,6
+24,8
@@
use Daemon::Generic;
use Data::Dumper;
use DateTime;
use English qw(-no_match_vars);
use Data::Dumper;
use DateTime;
use English qw(-no_match_vars);
+use File::Spec;
+use List::Util qw(first);
use POSIX qw(setuid setgid);
use SL::Auth;
use SL::DB::BackgroundJob;
use POSIX qw(setuid setgid);
use SL::Auth;
use SL::DB::BackgroundJob;
@@
-31,6
+36,7
@@
use SL::InstanceConfiguration;
use SL::LXDebug;
use SL::LxOfficeConf;
use SL::Locale;
use SL::LXDebug;
use SL::LxOfficeConf;
use SL::Locale;
+use SL::System::TaskServer;
our %lx_office_conf;
our %lx_office_conf;
@@
-113,6
+119,8
@@
sub gd_run {
$::locale = Locale->new($::lx_office_conf{system}->{language});
$::form = Form->new;
$::locale = Locale->new($::lx_office_conf{system}->{language});
$::form = Form->new;
+ chdir $exe_dir;
+
$job->run;
}
$job->run;
}
@@
-138,15
+146,19
@@
sub gd_run {
}
}
}
}
-my $cwd = getcwd();
-my $pidbase = "${cwd}/users/pid";
+chdir $exe_dir;
+
+mkdir SL::System::TaskServer::PID_BASE() if !-d SL::System::TaskServer::PID_BASE();
+
+my $file = first { -f } ("${exe_dir}/config/kivitendo.conf", "${exe_dir}/config/lx_office.conf", "${exe_dir}/config/kivitendo.conf.default");
+
+die "No configuration file found." unless $file;
-
mkdir($pidbase) if !-d $pidbase
;
+
$file = File::Spec->abs2rel(Cwd::abs_path($file), Cwd::abs_path($exe_dir))
;
-my $file = -f "${cwd}/config/lx_office.conf" ? "${cwd}/config/lx_office.conf" : "${cwd}/config/lx_office.conf.default";
newdaemon(configfile => $file,
newdaemon(configfile => $file,
- progname => 'kivitendo-
task-server
',
- pidbase =>
"${pidbase}/"
,
+ progname => 'kivitendo-
background-jobs
',
+ pidbase =>
SL::System::TaskServer::PID_BASE() . '/'
,
);
1;
);
1;