X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=svc%2Fnew_bib;h=435d8378313ccb94cca644e5dc5078e4ff15f927;hb=f7644ec91f2d151535f8f5125c4057a9213d766e;hp=ddcdb27d1d44954b19e12745135895926d6a0c72;hpb=7ee7effc89e5b17b72d27d38e1eaa6acc28b35d2;p=koha.git diff --git a/svc/new_bib b/svc/new_bib index ddcdb27d1d..435d837831 100755 --- a/svc/new_bib +++ b/svc/new_bib @@ -13,20 +13,25 @@ # 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, write to the Free Software Foundation, Inc., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# You should have received a copy of the GNU General Public License along +# with Koha; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. # use strict; +use warnings; + use CGI; use C4::Auth qw/check_api_auth/; use C4::Biblio; +use C4::Items; use XML::Simple; +use C4::Charset; my $query = new CGI; +binmode STDOUT, ':encoding(UTF-8)'; -my ($status, $cookie, $sessionID) = check_api_auth($query, { editcatalogue => 1} ); +my ($status, $cookie, $sessionID) = check_api_auth($query, { editcatalogue => 'edit_catalogue'} ); unless ($status eq "ok") { print $query->header(-type => 'text/xml', -status => '403 Forbidden'); print XMLout({ auth_status => $status }, NoAttr => 1, RootName => 'response', XMLDecl => 1); @@ -48,19 +53,39 @@ sub add_bib { my $inxml = $query->param('POSTDATA'); print $query->header(-type => 'text/xml'); - my $record = eval {MARC::Record::new_from_xml( $inxml, "utf8", C4::Context->preference('marcflavour'))}; + my $marcflavour = C4::Context->preference('marcflavour') || 'MARC21'; + my $record = eval {MARC::Record::new_from_xml( $inxml, "utf8", $marcflavour)}; my $do_not_escape = 0; if ($@) { $result->{'status'} = "failed"; $result->{'error'} = $@; } else { + # fix character set + if ($record->encoding() eq 'MARC-8') { + my ($guessed_charset, $charset_errors); + ($record, $guessed_charset, $charset_errors) = MarcToUTF8Record($record, $marcflavour); + } + + my $fullrecord = $record->clone(); + # delete any item tags - my ( $itemtag, $itemsubfield ) = GetMarcFromKohaField("items.itemnumber", ''); - foreach my $field ($record->field($itemtag)) { + my ( $itemtag, $itemsubfield ) = + GetMarcFromKohaField( "items.itemnumber", '' ); + foreach my $field ( $record->field($itemtag) ) { $record->delete_field($field); } - my ($biblionumber, $biblioitemnumber) = AddBiblio($record, ''); + my ( $biblionumber, $biblioitemnumber ) = AddBiblio( $record, '' ); my $new_record = GetMarcBiblio($biblionumber); + if ( $query->url_param('items') ) { + foreach my $field ( $fullrecord->field($itemtag) ) { + my $one_item_record = $new_record->clone(); + $one_item_record->add_fields($field); + AddItemFromMarc( $one_item_record, $biblionumber ); + } + } + + $new_record = + GetMarcBiblio( $biblionumber, $query->url_param('items') ); $result->{'status'} = "ok"; $result->{'biblionumber'} = $biblionumber; my $xml = $new_record->as_xml_record();