X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=opac%2Fopac-export.pl;h=d816ded995d8b6b945ca17768accc9fedc36e081;hb=9d6d641d1f8b77271800f43bc027b651f9aea52b;hp=41bf81ac443b7e9a4f191c969fe68b00fc89def7;hpb=481f620455d40f93a3cb37136ef2c3964497751e;p=srvgit diff --git a/opac/opac-export.pl b/opac/opac-export.pl index 41bf81ac44..d816ded995 100755 --- a/opac/opac-export.pl +++ b/opac/opac-export.pl @@ -4,68 +4,137 @@ # # 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. -# -# 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 +# 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, see . -use strict; -use warnings; +use Modern::Perl; use C4::Record; use C4::Auth; use C4::Output; -use C4::Biblio; -use CGI; +use C4::Biblio qw( + GetFrameworkCode + GetISBDView + GetMarcBiblio + GetMarcControlnumber +); +use CGI qw ( -utf8 ); use C4::Auth; -use C4::Ris; +use C4::Ris qw( marc2ris ); +use Koha::RecordProcessor; -my $query = new CGI; +my $query = CGI->new; my $op=$query->param("op")||''; #op=export is currently the only use my $format=$query->param("format")||'utf8'; my $biblionumber = $query->param("bib")||0; -my ($marc, $error)= ('',''); +$biblionumber = int($biblionumber); +my $error = q{}; + +# Determine logged in user's patron category. +# Blank if not logged in. +my $userenv = C4::Context->userenv; +my $borcat = q{}; +if ($userenv) { + my $borrowernumber = $userenv->{'number'}; + if ($borrowernumber) { + my $borrower = Koha::Patrons->find( { borrowernumber => $borrowernumber } ); + $borcat = $borrower ? $borrower->categorycode : $borcat; + } +} + +my $include_items = ($format =~ /bibtex/) ? 0 : 1; +my $marc = $biblionumber + ? GetMarcBiblio({ + biblionumber => $biblionumber, + embed_items => $include_items, + opac => 1, + borcat => $borcat }) + : undef; -$marc = GetMarcBiblio($biblionumber, 1) if $biblionumber; if(!$marc) { print $query->redirect("/cgi-bin/koha/errors/404.pl"); exit; } -elsif ($format =~ /endnote/) { + +my $file_id = $biblionumber; +my $file_pre = "bib-"; +if( C4::Context->preference('DefaultSaveRecordFileID') eq 'controlnumber' ){ + my $marcflavour = C4::Context->preference('marcflavour'); #FIXME This option is required but does not change control num behaviour + my $control_num = GetMarcControlnumber( $marc, $marcflavour ); + if( $control_num ){ + $file_id = $control_num; + $file_pre = "record-"; + } +} + +# ASSERT: There is a biblionumber, because GetMarcBiblio returned something. +my $framework = GetFrameworkCode( $biblionumber ); +my $record_processor = Koha::RecordProcessor->new({ + filters => 'ViewPolicy', + options => { + interface => 'opac', + frameworkcode => $framework + } +}); +$record_processor->process($marc); + +if ($format =~ /endnote/) { $marc = marc2endnote($marc); + $format = 'endnote'; } elsif ($format =~ /marcxml/) { $marc = marc2marcxml($marc); + $format = 'marcxml'; } elsif ($format=~ /mods/) { $marc = marc2modsxml($marc); + $format = 'mods'; } elsif ($format =~ /ris/) { $marc = marc2ris($marc); + $format = 'ris'; } elsif ($format =~ /bibtex/) { - $marc = marc2bibtex(C4::Biblio::GetMarcBiblio($biblionumber),$biblionumber); + $marc = marc2bibtex($marc,$biblionumber); + $format = 'bibtex'; } -elsif ($format =~ /dc/) { - ($error,$marc) = marc2dcxml($marc,1); +elsif ($format =~ /^(dc|oaidc|srwdc|rdfdc)$/i ) { + # TODO: Dublin Core leaks fields marked hidden by framework. + $marc = marc2dcxml($marc, undef, $biblionumber, $format); $format = "dublin-core.xml"; } elsif ($format =~ /marc8/) { ($error,$marc) = changeEncoding($marc,"MARC","MARC21","MARC-8"); $marc = $marc->as_usmarc() unless $error; + $format = 'marc8'; } elsif ($format =~ /utf8/) { C4::Charset::SetUTF8Flag($marc,1); $marc = $marc->as_usmarc(); + $format = 'utf8'; +} +elsif ($format =~ /marcstd/) { + C4::Charset::SetUTF8Flag($marc,1); + ($error,$marc) = marc2marc($marc, 'marcstd', C4::Context->preference('marcflavour')); + $format = 'marcstd'; +} +elsif ( $format =~ /isbd/ ) { + $marc = GetISBDView({ + 'record' => $marc, + 'template' => 'opac', + 'framework' => $framework, + }); + $format = 'isbd'; } else { $error= "Format $format is not supported."; @@ -75,12 +144,38 @@ if ($error){ print $query->header(); print $query->start_html(); print "

An error occurred

"; - print $error; + print $query->escapeHTML("$error"); print $query->end_html(); } else { - print $query->header( - -type => 'application/octet-stream', - -attachment=>"bib-$biblionumber.$format"); + if ($format eq 'marc8'){ + print $query->header( + -type => 'application/marc', + -charset=>'ISO-2022', + -attachment=>"$file_pre$file_id.$format"); + } + elsif ( $format eq 'isbd' ) { + print $query->header( + -type => 'text/plain', + -charset => 'utf-8', + -attachment => "$file_pre$file_id.txt" + ); + } + elsif ( $format eq 'ris' ) { + print $query->header( + -type => 'text/plain', + -charset => 'utf-8', + -attachment => "$file_pre$file_id.$format" + ); + } else { + binmode STDOUT, ':encoding(UTF-8)'; + print $query->header( + -type => 'application/octet-stream', + -charset => 'utf-8', + -attachment => "$file_pre$file_id.$format" + ); + } print $marc; } + +1;