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/;
17 use OpenSRF::Utils::JSON;
21 use Time::HiRes qw/time/;
27 MARC::Charset->ignore_errors(1);
29 my ($max_uri, $max_cn, $auth, $config, $quiet) =
30 (0, 0, 0, '/openils/conf/opensrf_core.xml');
33 'config=s' => \$config,
34 'authority' => \$auth,
36 'max_uri=i' => \$max_uri,
37 'max_cn=i' => \$max_cn,
42 open NEWERR, ">&STDERR";
44 select NEWERR; $| = 1;
45 select STDERR; $| = 1;
46 select STDOUT; $| = 1;
48 OpenSRF::System->bootstrap_client( config_file => $config );
49 Fieldmapper->import(IDL => OpenSRF::Utils::SettingsClient->new->config_value("IDL"));
51 OpenILS::Application::Ingest->use;
54 die "We have no more use for biblio ingest ... just insert the bre objects and you're done!\n";
57 my $meth = 'open-ils.ingest.full.biblio.object.readonly';
58 $meth = 'open-ils.ingest.full.authority.object.readonly' if ($auth);
60 $meth = OpenILS::Application::Ingest->method_lookup( $meth );
64 while (my $rec = <>) {
67 my $bib = OpenSRF::Utils::JSON->JSON2perl($rec);
71 ($data) = $meth->run( $bib => $max_cn => $max_uri );
74 warn "Couldn't process record: $e\n >>> $rec\n";
79 postprocess( { bib => $bib, ingest_data => $data } );
81 if (!$quiet && !($count % 20)) {
82 print NEWERR "\r$count\t". $count / (time - $starttime);
91 my ($field_entries, $fp, $rd, $uri);
93 my $bib = $data->{bib};
94 my $full_rec = $data->{ingest_data}->{full_rec};
97 $field_entries = $data->{ingest_data}->{field_entries};
98 $fp = $data->{ingest_data}->{fingerprint};
99 $rd = $data->{ingest_data}->{descriptor};
100 $uri = $data->{ingest_data}->{uri};
102 $bib->fingerprint( $fp->{fingerprint} );
103 $bib->quality( $fp->{quality} );
106 print( OpenSRF::Utils::JSON->perl2JSON($bib)."\n" );
108 print( OpenSRF::Utils::JSON->perl2JSON($rd)."\n" );
109 print( OpenSRF::Utils::JSON->perl2JSON($_)."\n" ) for (@$field_entries);
111 print( OpenSRF::Utils::JSON->perl2JSON($u->{call_number})."\n" ) if $u->{call_number}->isnew;
112 print( OpenSRF::Utils::JSON->perl2JSON($u->{uri})."\n" ) if $u->{uri}->isnew;
114 my $umap = Fieldmapper::asset::uri_call_number_map->new;
115 $umap->uri($u->{uri}->id);
116 $umap->call_number($u->{call_number}->id);
117 print( OpenSRF::Utils::JSON->perl2JSON($umap)."\n" );
119 $max_cn = $u->{call_number}->id + 1 if $u->{call_number}->isnew;
120 $max_uri = $u->{uri}->id + 1 if $u->{uri}->isnew;
124 print( OpenSRF::Utils::JSON->perl2JSON($_)."\n" ) for (@$full_rec);