#!/usr/bin/perl # Copyright 2009 BibLibre # # 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 3 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, see . use Modern::Perl; use CGI qw ( -utf8 ); use C4::Auth qw( get_template_and_user ); use C4::Biblio qw( GetFrameworkCode GetISBDView GetMarcBiblio ); use C4::Output qw( output_html_with_http_headers ); use C4::Record; use C4::Ris qw( marc2ris ); use Koha::CsvProfiles; use Koha::RecordProcessor; use Koha::Virtualshelves; use utf8; my $query = CGI->new; # if virtualshelves is disabled, leave immediately if ( ! C4::Context->preference('virtualshelves') ) { print $query->redirect("/cgi-bin/koha/errors/404.pl"); exit; } my ( $template, $borrowernumber, $cookie ) = get_template_and_user ( { template_name => "opac-downloadshelf.tt", query => $query, type => "opac", authnotrequired => ( C4::Context->preference("OpacPublic") ? 1 : 0 ), } ); my $borcat = q{}; if ( C4::Context->preference('OpacHiddenItemsExceptions') ) { # we need to fetch the borrower info here, so we can pass the category my $borrower = Koha::Patrons->find( { borrowernumber => $borrowernumber } ); $borcat = $borrower ? $borrower->categorycode : $borcat; } my $shelfnumber = $query->param('shelfnumber'); my $format = $query->param('format'); my $context = $query->param('context'); my $shelf = Koha::Virtualshelves->find( $shelfnumber ); if ( $shelf and $shelf->can_be_viewed( $borrowernumber ) ) { if ($shelfnumber && $format) { my $contents = $shelf->get_contents; my $marcflavour = C4::Context->preference('marcflavour'); my $output; my $extension; my $type; # CSV if ($format =~ /^\d+$/) { my $csv_profile = Koha::CsvProfiles->find($format); if ( not $csv_profile or $csv_profile->staff_only ) { print $query->redirect('/cgi-bin/koha/errors/404.pl'); exit; } my @biblios; while ( my $content = $contents->next ) { push @biblios, $content->biblionumber; } $output = marc2csv(\@biblios, $format); # Other formats } else { my $record_processor = Koha::RecordProcessor->new({ filters => 'ViewPolicy' }); while ( my $content = $contents->next ) { my $biblionumber = $content->biblionumber; my $record = GetMarcBiblio({ biblionumber => $biblionumber, embed_items => 1, opac => 1, borcat => $borcat }); my $framework = &GetFrameworkCode( $biblionumber ); $record_processor->options({ interface => 'opac', frameworkcode => $framework }); $record_processor->process($record); next unless $record; if ($format eq 'iso2709') { $output .= $record->as_usmarc(); } elsif ($format eq 'ris' ) { $output .= marc2ris($record); } elsif ($format eq 'bibtex') { $output .= marc2bibtex($record, $biblionumber); } elsif ( $format eq 'isbd' ) { $output .= GetISBDView({ 'record' => $record, 'template' => 'opac', 'framework' => $framework, }); $extension = "txt"; $type = "text/plain"; } } } # If it was a CSV export we change the format after the export so the file extension is fine $format = "csv" if ($format =~ m/^\d+$/); print $query->header( -type => ($type) ? $type : 'application/octet-stream', -'Content-Transfer-Encoding' => 'binary', -attachment => ($extension) ? "shelf.$format.$extension" : "shelf.$format" ); print $output; } else { # if modal context is passed set a variable so that page markup can be different if($context eq "modal"){ $template->param(modal => 1); } else { $template->param(fullpage => 1); } $template->param( csv_profiles => Koha::CsvProfiles->search( { type => 'marc', used_for => 'export_records', staff_only => 0 } ), shelf => $shelf, ); output_html_with_http_headers $query, $cookie, $template->output; } } else { $template->param(invalidlist => 1); output_html_with_http_headers $query, $cookie, $template->output; }