X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=about.pl;h=75635a694c95ebd4c5148a73e331356f48bbfa15;hb=e4172a4b844ac81b36ce303eb363fbe72ec2e210;hp=e4c1d7ce2e8df5e8d12b711ebadf96313237e57b;hpb=493d07e1c7ddf660157a17fc8f6717633e6a61c1;p=koha.git diff --git a/about.pl b/about.pl index e4c1d7ce2e..75635a694c 100755 --- a/about.pl +++ b/about.pl @@ -1,72 +1,169 @@ #!/usr/bin/perl -use HTML::Template; + +# This file is part of Koha. +# +# Koha is free software; you can redistribute it and/or modify it under the +# terms of the GNU General Public License as published by the Free Software +# Foundation; either version 2 of the License, or (at your option) any later +# version. +# +# Koha is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR +# A PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along with +# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, +# Suite 330, Boston, MA 02111-1307 USA + use strict; -require Exporter; -use C4::Database; -use C4::Output; # contains gettemplate -use C4::Interface::CGI::Output; + +use C4::Output; # contains gettemplate use C4::Auth; use C4::Context; use CGI; use LWP::Simple; use XML::Simple; +use Config; my $query = new CGI; -my ($template, $loggedinuser, $cookie) - = get_template_and_user({template_name => "about.tmpl", - query => $query, - type => "intranet", - authnotrequired => 0, - flagsrequired => {parameters => 1}, - debug => 1, - }); +my ( $template, $loggedinuser, $cookie ) = get_template_and_user( + { + template_name => "about.tmpl", + query => $query, + type => "intranet", + authnotrequired => 0, + flagsrequired => { catalogue => 1 }, + debug => 1, + } +); -my $kohaVersion = C4::Context->config("kohaversion"); -my $osVersion = `uname -a`; -my $perlVersion = $]; -my $mysqlVersion = `mysql -V`; -my $apacheVersion = `httpd -v`; -$apacheVersion = `httpd2 -v` unless $apacheVersion; +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`; +$apacheVersion = `httpd2 -v` unless $apacheVersion; +$apacheVersion = (`/usr/sbin/apache2 -V`)[0] unless $apacheVersion; my $zebraVersion = `zebraidx -V`; $template->param( - kohaVersion => $kohaVersion, - osVersion => $osVersion, - perlVersion => $perlVersion, - mysqlVersion => $mysqlVersion, - apacheVersion => $apacheVersion, - zebraVersion => $zebraVersion, - ); + kohaVersion => $kohaVersion, + osVersion => $osVersion, + perlPath => $perl_path, + perlVersion => $perlVersion, + perlIncPath => [ map { perlinc => $_ }, @INC ], + mysqlVersion => $mysqlVersion, + apacheVersion => $apacheVersion, + zebraVersion => $zebraVersion, +); +my @component_names = + qw/ +Algorithm::CheckDigits +Biblio::EndnoteStyle +CGI +CGI::Carp +CGI::Session +CGI::Session::Serialize::yaml +Class::Factory::Util +Class::Accessor +Compress::Zlib +DBD::mysql +DBI +Data::Dumper +Data::ICal +Date::Calc +Date::ICal +Date::Manip +Digest::MD5 +Email::Date +File::Temp +GD +GD::Barcode::UPCE +Getopt::Long +Getopt::Std +HTML::Template::Pro +HTTP::Cookies +HTTP::OAI +HTTP::Request::Common +HTML::Scrubber +IPC::Cmd +JSON +LWP::Simple +LWP::UserAgent +Lingua::Stem +List::Util +List::MoreUtils +Locale::Language +MARC::Crosswalk::DublinCore +MARC::Charset +MARC::File::XML +MARC::Record +MIME::Base64 +MIME::Lite +MIME::QuotedPrint +Mail::Sendmail +Net::LDAP +Net::LDAP::Filter +Net::Z3950::ZOOM +PDF::API2 +PDF::API2::Page +PDF::API2::Util +PDF::Reuse +PDF::Reuse::Barcode +POE +POSIX +Schedule::At +SMS::Send +Term::ANSIColor +Test +Test::Harness +Test::More +Text::CSV +Text::CSV_XS +Text::CSV::Encoded +Text::Iconv +Text::Wrap +Time::HiRes +Time::localtime +Unicode::Normalize +XML::Dumper +XML::LibXML +XML::LibXSLT +XML::SAX::ParserFactory +XML::SAX::Writer +XML::Simple +XML::RSS +YAML::Syck + /; my @components = (); -foreach my $component (qw/MARC::File::XML MARC::Charset Class::Accessor - LWP::Simple XML::Simple Net::Z3950 - Event Net::LDAP PDF::API2 - Mail::Sendmail MARC::Record Digest::MD5 - HTML::Template DBD::mysql Date::Manip - DBI Smart::Comments ZOOM - /) { +my $counter=0; +foreach my $component ( sort @component_names ) { my $version; - if (eval "require $component") { + if ( eval "require $component" ) { $version = $component->VERSION; - if ($version eq '' ) { + if ( $version eq '' ) { $version = 'unknown'; } } else { $version = 'module is missing'; } - - push @components, + push( + @components, { - name => $component, - version => $version, - }; + name => $component, + version => $version, + newrow => (++$counter % 4) ? 0 : 1, + } + ); } -$template->param( - components => \@components -); +$template->param( components => \@components ); output_html_with_http_headers $query, $cookie, $template->output;