X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/3ced230b9d35b6f2665162d6789af124431f23aa..8c7e44938a661e035f62840e1e177353240ace5d:/SL/InstallationCheck.pm diff --git a/SL/InstallationCheck.pm b/SL/InstallationCheck.pm index e82298ea8..a399e7902 100644 --- a/SL/InstallationCheck.pm +++ b/SL/InstallationCheck.pm @@ -1,5 +1,8 @@ package SL::InstallationCheck; +use English '-no_match_vars'; +use IO::File; + use vars qw(@required_modules); @required_modules = ( @@ -16,6 +19,7 @@ use vars qw(@required_modules); { "name" => "Text::CSV_XS", "url" => "http://search.cpan.org/~hmbrand/" }, { "name" => "List::Util", "url" => "http://search.cpan.org/~gbarr/" }, { "name" => "Template", "url" => "http://search.cpan.org/~abw/" }, + { "name" => "Digest::MD5", "url" => "http://search.cpan.org/~gaas/" }, ); sub module_available { @@ -28,6 +32,34 @@ sub module_available { } } +my %conditional_dependencies; + +sub check_for_conditional_dependencies { + if (!$conditional_dependencies{net_ldap}) { + $conditional_dependencies{net_ldap} = 1; + + my $in = IO::File->new('config/authentication.pl', 'r'); + if ($in) { + my $self = {}; + my $code; + + while (my $line = <$in>) { + $code .= $line; + } + $in->close(); + + eval $code; + + if (! $EVAL_ERROR) { + + if ($self->{module} && ($self->{module} eq 'LDAP')) { + push @required_modules, { 'name' => 'Net::LDAP', 'url' => 'http://search.cpan.org/~gbarr/' }; + } + } + } + } +} + sub test_all_modules { return grep { !module_available($_->{name}) } @required_modules; }