X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=opac%2Fopac-export.pl;h=fb8dee7a1eac1d793d8709d6c46ef7d7684c604a;hb=c82d114f1ef6dfc8abc289e01b104e1c4a5d290e;hp=4c53aff006eadcc0fe0362c89877235ce4a14932;hpb=d76216af0c03dbed1f78d999c27bb1e3af5a7bdc;p=koha_fer diff --git a/opac/opac-export.pl b/opac/opac-export.pl index 4c53aff006..fb8dee7a1e 100755 --- a/opac/opac-export.pl +++ b/opac/opac-export.pl @@ -1,5 +1,22 @@ #!/usr/bin/perl -use HTML::Template::Pro; + +# Parts Copyright Catalyst IT 2011 +# +# 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., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + use strict; use warnings; @@ -12,50 +29,61 @@ use C4::Auth; use C4::Ris; my $query = new CGI; -my $op=$query->param("op"); -my $format=$query->param("format"); -if ($op eq "export") { - my $biblionumber = $query->param("bib"); - my $dbh=C4::Context->dbh; - my $sth; - if ($biblionumber) { - $sth=$dbh->prepare("SELECT marc FROM biblioitems WHERE biblionumber =?"); - $sth->execute($biblionumber); - } - while (my ($marc) = $sth->fetchrow) { - if ($marc){ +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)= ('',''); - if ($format =~ /endnote/) { - $marc = marc2endnote($marc); - $format = 'endnote'; - } - elsif ($format =~ /marcxml/) { - $marc = marc2marcxml($marc); - } - elsif ($format=~ /mods/) { - $marc = marc2modsxml($marc); - } - elsif ($format =~ /ris/) { - $marc = marc2ris(MARC::Record->new_from_usmarc($marc)); - } - elsif ($format =~ /bibtex/) { - $marc = marc2bibtex(C4::Biblio::GetMarcBiblio($biblionumber),$biblionumber); - }elsif ($format =~ /dc/) { - my $error; - ($error,$marc) = marc2dcxml($marc,1); - $format = "dublin-core.xml"; - } - elsif ($format =~ /marc8/) { - $marc = changeEncoding($marc,"MARC","MARC21","MARC-8"); - $marc = $marc->as_usmarc(); - } - elsif ($format =~ /utf8/) { - #default - } - print $query->header( - -type => 'application/octet-stream', - -attachment=>"bib-$biblionumber.$format"); - print $marc; - } - } +$marc = GetMarcBiblio($biblionumber, 1) if $biblionumber; +if(!$marc) { + print $query->redirect("/cgi-bin/koha/errors/404.pl"); + exit; +} +elsif ($format =~ /endnote/) { + $marc = marc2endnote($marc); +} +elsif ($format =~ /marcxml/) { + $marc = marc2marcxml($marc); +} +elsif ($format=~ /mods/) { + $marc = marc2modsxml($marc); +} +elsif ($format =~ /ris/) { + $marc = marc2ris($marc); +} +elsif ($format =~ /bibtex/) { + $marc = marc2bibtex(C4::Biblio::GetMarcBiblio($biblionumber),$biblionumber); +} +elsif ($format =~ /dc/) { + ($error,$marc) = marc2dcxml($marc,1); + $format = "dublin-core.xml"; +} +elsif ($format =~ /marc8/) { + ($error,$marc) = changeEncoding($marc,"MARC","MARC21","MARC-8"); + $marc = $marc->as_usmarc() unless $error; +} +elsif ($format =~ /utf8/) { + C4::Charset::SetUTF8Flag($marc,1); + $marc = $marc->as_usmarc(); +} +elsif ($format =~ /marcstd/) { + C4::Charset::SetUTF8Flag($marc,1); + ($error,$marc) = marc2marc($marc, 'marcstd', C4::Context->preference('marcflavour')); +} +else { + $error= "Format $format is not supported."; +} + +if ($error){ + print $query->header(); + print $query->start_html(); + print "

An error occurred

"; + print $error; + print $query->end_html(); +} +else { + print $query->header( + -type => 'application/octet-stream', + -attachment=>"bib-$biblionumber.$format"); + print $marc; }