Bug 32336: (QA follow-up) Use $metadata->schema
[srvgit] / catalogue / export.pl
index 11ec6d5..ff02cea 100755 (executable)
@@ -1,54 +1,89 @@
 #!/usr/bin/perl
-use HTML::Template;
-use strict;
-require Exporter;
+use Modern::Perl;
+
 use C4::Record;
-use C4::Auth;
+use C4::Auth qw( get_template_and_user );
 use C4::Output;
-use C4::Biblio;
-use CGI;
-use C4::Auth;
+use C4::Biblio qw( GetMarcControlnumber );
+use CGI qw ( -utf8 );
+use C4::Ris qw( marc2ris );
+
+
+
+my $query = CGI->new;
+my ( $template, $loggedinuser, $cookie ) = get_template_and_user({
+    template_name   => "tools/export.tt",
+    query           => $query,
+    type            => "intranet",
+    flagsrequired   => { catalogue => 1 },
+    });
 
-my $query = new CGI;
 my $op=$query->param("op");
 my $format=$query->param("format");
+my $error = '';
 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){
-
-                       if ($format =~ /endnote/) {
-                               $marc = marc2endnote($marc);
-                               $format = 'endnote';
-                       }
-                       elsif ($format =~ /marcxml/) {
-                               $marc = marc2marcxml($marc);
-                       }
-                       elsif ($format=~ /mods/) {
-                               $marc = marc2modsxml($marc);
-                       }
-                       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;
-               }
-       }
+    my $biblionumber = $query->param("bib");
+        if ($biblionumber){
+            my $file_id = $biblionumber;
+            my $file_pre = "bib-";
+
+            my $biblio = Koha::Biblios->find($biblionumber);
+            my $marc   = $biblio->metadata->record({ embed_items => 1 });
+
+            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-";
+                }
+            }
+
+            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$/) {
+                $marc = marc2dcxml(undef, undef, $biblionumber, $format);
+                $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";
+            }
+            if ( $format =~ /utf8/ or $format =~ /marcstd/ ) {
+                binmode STDOUT, ':encoding(UTF-8)';
+            }
+            print $query->header(
+                -type => 'application/octet-stream',
+                -attachment=>"$file_pre$file_id.$format");
+            print $marc;
+        }
 }