Bug 19188: Self checkout missing currency symbol
[srvgit] / opac / opac-export.pl
index c4ab83a..1b0fdad 100755 (executable)
 # 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;
 
 use C4::Record;
 use C4::Auth;
 use C4::Output;
-use C4::Biblio;
+use C4::Biblio qw(
+    GetFrameworkCode
+    GetISBDView
+    GetMarcControlnumber
+);
 use CGI qw ( -utf8 );
 use C4::Auth;
-use C4::Ris;
+use C4::Ris qw( marc2ris );
+use Koha::Biblios;
+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;
 $biblionumber = int($biblionumber);
-my ($marc, $error)= ('','');
+my $error = q{};
+
+# Determine logged in user's patron category.
+# Blank if not logged in.
+my $userenv = C4::Context->userenv;
+my $patron;
+if ($userenv) {
+    my $borrowernumber = $userenv->{'number'};
+    if ($borrowernumber) {
+        $patron = Koha::Patrons->find( $borrowernumber );
+    }
+}
+
+my $include_items = ($format =~ /bibtex/) ? 0 : 1;
+my $biblio = Koha::Biblios->find($biblionumber);
+my $marc = $biblio
+  ? $biblio->metadata->record(
+    {
+        embed_items => 1,
+        opac        => 1,
+        patron      => $patron,
+    }
+  )
+  : 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-";
+    }
+}
+
+my $framework = $biblio->frameworkcode;
+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';
 }
@@ -57,11 +106,12 @@ elsif ($format =~ /ris/) {
     $format = 'ris';
 }
 elsif ($format =~ /bibtex/) {
-    $marc = marc2bibtex(C4::Biblio::GetMarcBiblio($biblionumber),$biblionumber);
+    $marc = marc2bibtex($marc,$biblionumber);
     $format = 'bibtex';
 }
-elsif ($format =~ /dc$/) {
-    $marc = marc2dcxml(undef, undef, $biblionumber, $format);
+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/) {
@@ -80,7 +130,11 @@ elsif ($format =~ /marcstd/) {
     $format = 'marcstd';
 }
 elsif ( $format =~ /isbd/ ) {
-    $marc   = GetISBDView($biblionumber, "opac");
+    $marc   = GetISBDView({
+        'record'    => $marc,
+        'template'  => 'opac',
+        'framework' => $framework,
+    });
     $format = 'isbd';
 }
 else {
@@ -99,19 +153,30 @@ else {
         print $query->header(
             -type => 'application/marc',
             -charset=>'ISO-2022',
-            -attachment=>"bib-$biblionumber.$format");
+            -attachment=>"$file_pre$file_id.$format");
     }
     elsif ( $format eq 'isbd' ) {
         print $query->header(
             -type       => 'text/plain',
             -charset    => 'utf-8',
-            -attachment =>  "bib-$biblionumber.txt"
+            -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{
+    } else {
+        binmode STDOUT, ':encoding(UTF-8)';
         print $query->header(
             -type => 'application/octet-stream',
-            -charset=>'utf-8',
-            -attachment=>"bib-$biblionumber.$format");
+            -charset => 'utf-8',
+            -attachment => "$file_pre$file_id.$format"
+        );
     }
     print $marc;
 }
+
+1;