X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=catalogue%2Fexport.pl;h=efdf0eec2a67d2bd5299992566c6df6e51111729;hb=17ac5d01a3ae2d9fef68bc19d7baa01274ee8d53;hp=3a760844d7b00e39665d10a2465e42f690b80410;hpb=367c4fb8815bfe4a01869a25bcd8222989c15dcd;p=koha.git diff --git a/catalogue/export.pl b/catalogue/export.pl index 3a760844d7..efdf0eec2a 100755 --- a/catalogue/export.pl +++ b/catalogue/export.pl @@ -7,57 +7,71 @@ use C4::Auth; use C4::Output; use C4::Biblio; use CGI; +use C4::Ris; my $query = new CGI; my ( $template, $loggedinuser, $cookie ) = get_template_and_user({ - template_name => "tools/export.tt", - query => $query, - type => "intranet", - authnotrequired => 0, - flagsrequired => { tools => 'export_catalog' }, - debug => 1, - }); + template_name => "tools/export.tt", + query => $query, + type => "intranet", + authnotrequired => 0, + flagsrequired => { catalogue => 1 }, + debug => 1, + }); my $op=$query->param("op"); my $format=$query->param("format"); my $error = ''; if ($op eq "export") { - my $biblionumber = $query->param("bib"); - if ($biblionumber){ + my $biblionumber = $query->param("bib"); + if ($biblionumber){ - my $marc = GetMarcBiblio($biblionumber, 1); + my $marc = GetMarcBiblio($biblionumber, 1); - if ($format =~ /endnote/) { - $marc = marc2endnote($marc); - $format = 'endnote'; - } - elsif ($format =~ /marcxml/) { - $marc = marc2marcxml($marc); - } - elsif ($format=~ /mods/) { - $marc = marc2modsxml($marc); - } - elsif ($format =~ /dc/) { - ($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/) { - C4::Charset::SetUTF8Flag($marc, 1); - $marc = $marc->as_usmarc(); - } + 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($marc); + $format = "bibtex"; + } + elsif ($format =~ /dc/) { + ($error,$marc) = marc2dcxml($marc,1); + $format = "dublin-core.xml"; + } + elsif ($format =~ /marc8/) { + $marc = changeEncoding($marc,"MARC","MARC21","MARC-8"); + $marc = $marc->as_usmarc(); + $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"; } - print $query->header( - -type => 'application/octet-stream', + print $query->header( + -type => 'application/octet-stream', -attachment=>"bib-$biblionumber.$format"); - print $marc; - } + print $marc; + } }