Correcting the name of one of the developers. :)
[koha.git] / about.pl
index 32b2978..be5e0ab 100755 (executable)
--- a/about.pl
+++ b/about.pl
@@ -1,5 +1,5 @@
 #!/usr/bin/perl
+
 # This file is part of Koha.
 #
 # Koha is free software; you can redistribute it and/or modify it under the
 # Suite 330, Boston, MA  02111-1307 USA
 
 use strict;
-require Exporter;
+use warnings;
 
-use C4::Output;    # contains gettemplate
-use C4::Auth;
-use C4::Context;
 use CGI;
 use LWP::Simple;
 use XML::Simple;
+use Config;
+
+use C4::Output;    # contains gettemplate
+use C4::Auth;
+use C4::Context;
+use C4::Installer;
 
 my $query = new CGI;
 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
@@ -39,6 +42,10 @@ my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
 
 my $kohaVersion   = C4::Context::KOHAVERSION;
 my $osVersion     = `uname -a`;
+my $perl_path = $^X;
+if ($^O ne 'VMS') {
+    $perl_path .= $Config{_exe} unless $perl_path =~ m/$Config{_exe}$/i;
+}
 my $perlVersion   = $];
 my $mysqlVersion  = `mysql -V`;
 my $apacheVersion = `httpd -v`;
@@ -49,99 +56,52 @@ my $zebraVersion = `zebraidx -V`;
 $template->param(
     kohaVersion   => $kohaVersion,
     osVersion     => $osVersion,
+    perlPath      => $perl_path,
     perlVersion   => $perlVersion,
+    perlIncPath   => [ map { perlinc => $_ }, @INC ],
     mysqlVersion  => $mysqlVersion,
     apacheVersion => $apacheVersion,
     zebraVersion  => $zebraVersion,
 );
-my @component_names =
-    qw/
-Biblio::EndnoteStyle
-CGI
-CGI::Carp
-CGI::Session
-Class::Factory::Util
-Class::Accessor
-Compress::Zlib
-DBD::mysql
-DBI
-Data::Dumper
-Date::Calc
-Date::Manip
-Digest::MD5
-File::Temp
-GD::Barcode::UPCE
-Getopt::Long
-Getopt::Std
-HTML::Template::Pro
-HTTP::Cookies
-HTTP::Request::Common
-LWP::Simple
-LWP::UserAgent
-Lingua::Stem
-List::Util
-Locale::Language
-MARC::Crosswalk::DublinCore
-MARC::Charset
-MARC::File::XML
-MARC::Record
-MIME::Base64
-MIME::QuotedPrint
-Mail::Sendmail
-Net::Z3950::ZOOM
-PDF::API2
-PDF::API2::Page
-PDF::API2::Util
-PDF::Reuse
-PDF::Reuse::Barcode
-POSIX
-Schedule::At
-Term::ANSIColor
-Test
-Test::Harness
-Test::More
-Text::CSV
-Text::CSV_XS
-Text::Iconv
-Text::Wrap
-Time::HiRes
-Time::localtime
-Unicode::Normalize
-XML::Dumper
-XML::LibXML
-XML::LibXSLT
-XML::SAX::ParserFactory
-XML::Simple
-XML::RSS
-YAML::Syck
-      /;
 
 my @components = ();
 
-my $counter=0;
-foreach my $component ( sort @component_names ) {
-    my $version;
-    if ( eval "require $component" ) {
-        $version = $component->VERSION;
-        if ( $version eq '' ) {
-            $version = 'unknown';
-        }
+my $perl_modules = C4::Installer::PerlModules->new;
+$perl_modules->version_info;
+
+my @pm_types = qw(missing_pm upgrade_pm current_pm);
+
+foreach my $pm_type(@pm_types) {
+    my $modules = $perl_modules->get_attr($pm_type);
+    foreach (@$modules) {
+        my ($module, $stats) = each %$_;
+        push(
+            @components,
+            {
+                name    => $module,
+                version => $stats->{'cur_ver'},
+                missing => ($pm_type eq 'missing_pm' ? 1 : 0),
+                upgrade => ($pm_type eq 'upgrade_pm' ? 1 : 0),
+                current => ($pm_type eq 'current_pm' ? 1 : 0),
+                require => $stats->{'required'},
+            }
+        );
     }
-    else {
-        $version = 'module is missing';
+}
+
+@components = sort {$a->{'name'} cmp $b->{'name'}} @components;
+
+my $counter=0;
+my $row = [];
+my $table = [];
+foreach (@components) {
+    push (@$row, $_);
+    unless (++$counter % 4) {
+        push (@$table, {row => $row});
+        $row = [];
     }
-    $counter++;
-    $counter=0 if $counter >3;
-    push(
-        @components,
-        {
-            name    => $component,
-            version => $version,
-            counter => $counter,
-        }
-    );
 }
 
-$template->param( components => \@components );
+$template->param( table => $table );
 
 output_html_with_http_headers $query, $cookie, $template->output;