#
# 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 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 3 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.
+# 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.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
-use strict;
-use warnings;
+use Modern::Perl;
=head1 NAME
=cut
-use CGI;
+use CGI qw ( -utf8 );
use C4::Context;
use C4::Biblio;
-use XML::LibXML;
-use XML::LibXSLT;
+use Koha::XSLT_Handler;
my $cgi = CGI->new();
binmode(STDOUT, ":encoding(UTF-8)"); #output as utf8
'marcxml' => 'identity.xsl',
'marcxml-full' => 'identity.xsl',
'oai_dc' => 'UNIMARCslim2OAIDC.xsl',
+ 'rdfdc', => 'UNIMARCslim2RDFDC.xsl',
+ 'srw_dc' => 'UNIMARCslim2SRWDC.xsl',
},
};
my $biblionumber = $1;
my $content;
- eval {
- my $marcxml = GetXmlBiblio($biblionumber);
- unless (defined $marcxml) {
- # no bib, so 404
- print $cgi->header( -status => '404 record not found');
- exit 0;
- }
-
- my $transformer = get_transformer($format, $format_to_stylesheet_map, $format_info);
- unless (defined $transformer) {
- print $cgi->header( -status => '406 invalid format requested' );
- exit 0;
- }
- my $parser = XML::LibXML->new();
- my $record_dom = $parser->parse_string( $marcxml );
- $record_dom = $transformer->transform( $record_dom );
- $content = $record_dom->toString();
- };
- if ($@) {
- print $cgi->header( -status => '500 internal error ' . $@->code() . ": " . $@->message() );
+
+ my $marcxml = GetXmlBiblio($biblionumber);
+ unless (defined $marcxml) {
+ # no bib, so 404
+ print $cgi->header( -status => '404 record not found');
exit 0;
}
- print $cgi->header( -type =>'application/xml' );
+ my $xslt_file = get_xslt_file( $format, $format_to_stylesheet_map, $format_info );
+ unless( defined $xslt_file ) {
+ print $cgi->header( -status => '406 invalid format requested' );
+ exit 0;
+ }
+ my $xslt_engine = Koha::XSLT_Handler->new;
+ $content = $xslt_engine->transform({
+ xml => $marcxml,
+ file => $xslt_file,
+ });
+
+ if( !defined $content || $xslt_engine->err ) {
+ print $cgi->header( -status => '500 internal error' );
+ exit 0;
+ }
+
+ print $cgi->header( -type =>'application/xml', -charset => 'UTF-8' );
print $content;
} else {
# ID is obviously wrong, so 404
if (defined $id) {
print $cgi->header( -type =>'application/xml', -status => '300 multiple choices' );
} else {
- print $cgi->header( -type =>'application/xml' );
+ print $cgi->header( -type =>'application/xml', -status => '200 Ok' );
}
print "<?xml version='1.0' encoding='utf-8' ?>\n";
}
-sub get_transformer {
+sub get_xslt_file {
my ($format, $format_to_stylesheet_map, $format_info) = @_;
$format = lc $format;
my $marcflavour = uc(C4::Context->preference('marcflavour'));
return unless $format_to_stylesheet_map->{$marcflavour}->{$format};
- my $xslt_file = C4::Context->config('intranetdir') .
- "/koha-tmpl/intranet-tmpl/prog/en/xslt/" .
+ my $xslt_file = C4::Context->config('intrahtdocs') .
+ "/prog/en/xslt/" .
$format_to_stylesheet_map->{$marcflavour}->{$format};
- my $parser = XML::LibXML->new();
- my $xslt = XML::LibXSLT->new();
- my $style_doc = $parser->parse_file( $xslt_file );
- my $stylesheet = $xslt->parse_stylesheet( $style_doc );
-
- return $stylesheet;
+ return $xslt_file;
}
=head1 AUTHOR