use CGI qw ( -utf8 );
use C4::Auth;
use C4::Ris;
+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 $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/) {
+
+# 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';
}
$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/) {
$format = 'marcstd';
}
elsif ( $format =~ /isbd/ ) {
- $marc = GetISBDView($biblionumber, "opac");
+ $marc = GetISBDView({
+ 'record' => $marc,
+ 'template' => 'opac',
+ 'framework' => $framework,
+ });
$format = 'isbd';
}
else {