1 package WebPAC::Input::Koha;
8 use base qw/WebPAC::Common/;
10 use Data::Dump qw/dump/;
14 WebPAC::Input::Koha - read MARC records from Koha
18 our $VERSION = '0.02';
24 my $input = new WebPAC::Input::Koha(
25 dsn => 'dbi:mysql:database=koha',
26 user => $ENV{KOHA_USER},
27 passwd => $ENV{KOHA_PASSWD},
39 my $log = $self->_get_logger();
40 $log->debug( 'arg = ', dump($arg) );
42 if ( -e $arg->{path} ) {
43 $log->info("Koha marc dump ", $arg->{path}, " exists");
44 $self->{_koha_size} = 0;
47 $arg->{dsn} ||= 'dbi:mysql:database=koha';
48 $arg->{user} ||= $ENV{KOHA_USER};
49 $arg->{passwd} ||= $ENV{KOHA_PASSWD},
50 $arg->{sql} ||= 'select biblionumber, marc from biblioitems order by biblionumber asc';
51 $arg->{sql} .= ' limit ' . $arg->{limit} if $arg->{limit};
52 $arg->{sql} .= ' offset ' . $arg->{offset} if $arg->{offset};
54 $log->info("opening Koha database '$arg->{dsn}'");
56 $self->{_dbh} = DBI->connect( $arg->{dsn}, $arg->{user}, $arg->{passwd}, {
58 #mysql_enable_utf8 => 1, # not really needed
60 $self->{_sth} = $self->{_dbh}->prepare( $arg->{sql} );
61 $self->{_sth}->execute;
62 $self->{_koha_size} = $self->{_sth}->rows;
64 warn "got ", $self->{_koha_size}, " rows for ", $arg->{sql};
66 open( $self->{_koha_fh}, '>', $arg->{path} ) || die "can't create $arg->{path}: $!";
70 $self ? return $self : return undef;
75 Return record with ID C<$mfn> from database
77 my $rec = $input->fetch_rec( $mfn );
86 my $row = $self->{_sth}->fetchrow_hashref;
89 my ( $mfn, $error, $row ) = @_;
90 $self->_get_logger()->error( "MFN $mfn $error ", dump($row) );
93 if ( my $fh = $self->{_koha_fh} ) {
94 if ( my $marc = $row->{marc} ) {
95 if ( length($marc) != substr( $marc, 0, 5 ) ) {
96 _error $mfn => "wrong length " . length($marc), $row;
97 } elsif ( $marc !~ /\x1E\x1D$/ ) {
98 _error $mfn => "wrong end", $row;
103 _error $mfn => "no marc",$row;
107 push @{$row->{'000'}}, $mfn;
113 Return number of records in database
115 my $size = $isis->size;
121 return $self->{_koha_size} + $self->{offset};
127 Dobrica Pavlinusic, C<< <dpavlin@rot13.org> >>
129 =head1 COPYRIGHT & LICENSE
131 Copyright 2009 Dobrica Pavlinusic, All Rights Reserved.
133 This program is free software; you can redistribute it and/or modify it
134 under the same terms as Perl itself.