projects
/
kivitendo-erp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Richtig prüfen, ob Konten, die als Automatikkonten für andere Konten dienen, geändert...
[kivitendo-erp.git]
/
scripts
/
task_server.pl
diff --git
a/scripts/task_server.pl
b/scripts/task_server.pl
index
d84e811
..
eb407cb
100755
(executable)
--- a/
scripts/task_server.pl
+++ b/
scripts/task_server.pl
@@
-2,17
+2,17
@@
use strict;
use strict;
-BEGIN {
- require Cwd;
+my $exe_dir;
- my $dir = $0;
-
$dir = Cwd::getcwd() . '/' . $dir unless $dir =~ m|^/|
;
- $
dir =~ s|[^/]+$|..|
;
+BEGIN {
+
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
+21,7
@@
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 List::Util qw(first);
use POSIX qw(setuid setgid);
use SL::Auth;
@@
-32,6
+33,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;
@@
-114,6
+116,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;
}
@@
-139,15
+143,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 = first { -f } ("${cwd}/config/kivitendo.conf", "${cwd}/config/lx_office.conf", "${cwd}/config/kivitendo.conf.default");
newdaemon(configfile => $file,
progname => 'kivitendo-task-server',
newdaemon(configfile => $file,
progname => 'kivitendo-task-server',
- pidbase =>
"${pidbase}/"
,
+ pidbase =>
SL::System::TaskServer::PID_BASE() . '/'
,
);
1;
);
1;