- my $biblionumber = $query->param("bib");
- if ($biblionumber){
-
- 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/) {
- 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/) {
- C4::Charset::SetUTF8Flag($marc, 1);
- $marc = $marc->as_usmarc();
- }
- 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 $marc = GetMarcBiblio({
+ biblionumber => $biblionumber,
+ 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;
+ }