5 use lib '/openils/lib/perl5/';
8 use OpenSRF::EX qw/:try/;
9 use OpenSRF::AppSession;
10 use OpenSRF::Application;
11 use OpenSRF::MultiSession;
12 use OpenSRF::Utils::SettingsClient;
13 use OpenILS::Application::Ingest;
14 use OpenILS::Application::AppUtils;
15 use OpenILS::Utils::Fieldmapper;
16 use Digest::MD5 qw/md5_hex/;
21 use Time::HiRes qw/time/;
27 MARC::Charset->ignore_errors(1);
29 my ($workers, $config, $prefix) =
30 (1, '/openils/conf/bootstrap.conf', 'marc-out-');
33 'threads=i' => \$workers,
34 'config=s' => \$config,
35 'prefix=s' => \$prefix,
40 open NEWERR, ">&STDERR";
42 select NEWERR; $| = 1;
43 select STDERR; $| = 1;
44 select STDOUT; $| = 1;
52 $0 = "Local Ingest Worker $_";
57 $0 = "Local Ingest Master";
63 OpenSRF::System->bootstrap_client( config_file => $config );
64 Fieldmapper->import(IDL => OpenSRF::Utils::SettingsClient->new->config_value("IDL"));
66 OpenILS::Application::Ingest->use;
68 my $f = new FileHandle(">${prefix}$file");
69 while (my $rec = <$pipe>) {
71 my $bib = JSON->JSON2perl($rec);
75 ($data) = OpenILS::Application::Ingest
76 ->method_lookup( 'open-ils.ingest.full.biblio.object.readonly' )
80 warn "Couldn't process record: $e\n >>> $rec\n";
96 while ( my $rec = <> ) {
98 my $session_index = $count % $workers;
100 $ses[$session_index]->printflush( $rec );
102 if (!($count % 20)) {
103 print NEWERR "\r$count\t". $count / (time - $starttime);
113 my $bib = $data->{bib};
114 my $field_entries = $data->{worm_data}->{field_entries};
115 my $full_rec = $data->{worm_data}->{full_rec};
116 my $fp = $data->{worm_data}->{fingerprint};
117 my $rd = $data->{worm_data}->{descriptor};
119 $bib->fingerprint( $fp->{fingerprint} );
120 $bib->quality( $fp->{quality} );
122 $f->printflush( JSON->perl2JSON($bib)."\n" );
123 $f->printflush( JSON->perl2JSON($rd)."\n" );
124 $f->printflush( JSON->perl2JSON($_)."\n" ) for (@$field_entries);
125 $f->printflush( JSON->perl2JSON($_)."\n" ) for (@$full_rec);