1 package OpenILS::Application::Storage::Publisher;
2 use base qw/OpenILS::Application::Storage/;
4 my $pg = 'OpenILS::Application::Storage::Driver::Pg';
6 use OpenSRF::EX qw/:try/;;
7 use OpenSRF::Utils::Logger;
8 my $log = 'OpenSRF::Utils::Logger';
10 use OpenILS::Utils::Fieldmapper;
11 use OpenILS::Application::Storage::CDBI;
13 #use OpenILS::Application::Storage::CDBI::actor;
14 #use OpenILS::Application::Storage::CDBI::asset;
15 #use OpenILS::Application::Storage::CDBI::biblio;
16 #use OpenILS::Application::Storage::CDBI::config;
17 #use OpenILS::Application::Storage::CDBI::metabib;
19 use OpenILS::Application::Storage::Publisher::actor;
20 #use OpenILS::Application::Storage::Publisher::asset;
21 use OpenILS::Application::Storage::Publisher::biblio;
22 use OpenILS::Application::Storage::Publisher::config;
23 use OpenILS::Application::Storage::Publisher::metabib;
30 my $cdbi = $self->{cdbi};
35 my ($rec) = $cdbi->fast_fieldmapper($id);
36 $client->respond( $rec ) if ($rec);
38 last if ($self->api_name !~ /batch/o);
48 my $cdbi = $self->{cdbi};
50 $log->debug("Searching $cdbi for { ".join(',', map { "$_ => $$searches{$_}" } keys %$searches).' }',DEBUG);
52 for my $obj ($cdbi->search($searches)) {
53 $client->respond( $obj->to_fieldmapper );
58 sub search_one_field {
63 (my $search_type = $self->api_name) =~ s/.*\.(search[^.]*).*/$1/o;
64 (my $col = $self->api_name) =~ s/.*\.$search_type\.([^.]+).*/$1/;
65 my $cdbi = $self->{cdbi};
68 $like = 1 if ($search_type =~ /like$/o);
70 for my $term (@terms) {
71 $log->debug("Searching $cdbi for $col using type $search_type, value '$term'",DEBUG);
72 $client->respond( [ $cdbi->fast_fieldmapper($term,$col,$like) ] );
83 my $cdbi = $self->{cdbi};
87 my $rec = $cdbi->create($node);
88 $success = $rec->id if ($rec);
101 my $cdbi = $self->{cdbi};
103 return $cdbi->update($node);
111 my $where = 'WHERE ';
113 my $cdbi = $self->{cdbi};
114 my $table = $cdbi->table;
116 my @keys = sort keys %$search;
119 for my $col ( @keys ) {
120 push @wheres, "$col = ?";
122 $where .= join ' AND ', @wheres;
124 my $delete = "DELETE FROM $table $where";
126 $log->debug("Performing MASS deletion : $delete",DEBUG);
128 my $dbh = $cdbi->db_Main;
131 my $sth = $dbh->prepare($delete);
132 $sth->execute( map { "$_" } @$search{@keys} );
134 $log->debug("MASS Delete succeeded",DEBUG);
136 $log->debug("MASS Delete FAILED : ".shift(),DEBUG);
147 my $cdbi = $self->{cdbi};
151 $success = $cdbi->delete($node);
163 my $cdbi = $self->{cdbi};
164 my $api_name = $self->api_name;
165 (my $single_call_api_name = $api_name) =~ s/batch\.//o;
167 $log->debug("Default $api_name looking up $single_call_api_name...",INTERNAL);
168 my $method = $self->method_lookup($single_call_api_name);
171 while ( my $node = shift(@nodes) ) {
172 my ($res) = $method->run( $node );
173 push(@success, 1) if ($res >= 0);
176 my $insert_total = 0;
177 $insert_total += $_ for (@success);
179 return $insert_total;
182 for my $fmclass ( Fieldmapper->classes ) {
183 (my $cdbi = $fmclass) =~ s/^Fieldmapper:://o;
184 (my $class = $cdbi) =~ s/::.*//o;
185 (my $api_class = $cdbi) =~ s/::/./go;
186 my $registration_class = __PACKAGE__ . "::$class";
187 my $api_prefix = 'open-ils.storage.'.$api_class;
189 # Create the search method
190 unless ( __PACKAGE__->is_registered( $api_prefix.'.search' ) ) {
191 __PACKAGE__->register_method(
192 api_name => $api_prefix.'.search',
200 # Create the retrieve method
201 unless ( __PACKAGE__->is_registered( $api_prefix.'.retrieve' ) ) {
202 __PACKAGE__->register_method(
203 api_name => $api_prefix.'.retrieve',
204 method => 'retrieve_node',
210 # Create the batch retrieve method
211 unless ( __PACKAGE__->is_registered( $api_prefix.'.batch.retrieve' ) ) {
212 __PACKAGE__->register_method(
213 api_name => $api_prefix.'.batch.retrieve',
214 method => 'retrieve_node',
221 for my $field ($fmclass->real_fields) {
222 unless ( __PACKAGE__->is_registered( $api_prefix.'.search.'.$field ) ) {
223 __PACKAGE__->register_method(
224 api_name => $api_prefix.'.search.'.$field,
225 method => 'search_one_field',
230 unless ( __PACKAGE__->is_registered( $api_prefix.'.search_like.'.$field ) ) {
231 __PACKAGE__->register_method(
232 api_name => $api_prefix.'.search_like.'.$field,
233 method => 'search_one_field',
241 # Create the create method
242 unless ( __PACKAGE__->is_registered( $api_prefix.'.create' ) ) {
243 __PACKAGE__->register_method(
244 api_name => $api_prefix.'.create',
245 method => 'create_node',
251 # Create the batch create method
252 unless ( __PACKAGE__->is_registered( $api_prefix.'.batch.create' ) ) {
253 __PACKAGE__->register_method(
254 api_name => $api_prefix.'.batch.create',
255 method => 'batch_call',
261 # Create the update method
262 unless ( __PACKAGE__->is_registered( $api_prefix.'.update' ) ) {
263 __PACKAGE__->register_method(
264 api_name => $api_prefix.'.update',
265 method => 'update_node',
271 # Create the batch update method
272 unless ( __PACKAGE__->is_registered( $api_prefix.'.batch.update' ) ) {
273 __PACKAGE__->register_method(
274 api_name => $api_prefix.'.batch.update',
275 method => 'batch_call',
281 # Create the delete method
282 unless ( __PACKAGE__->is_registered( $api_prefix.'.delete' ) ) {
283 __PACKAGE__->register_method(
284 api_name => $api_prefix.'.delete',
285 method => 'delete_node',
291 # Create the batch delete method
292 unless ( __PACKAGE__->is_registered( $api_prefix.'.batch.delete' ) ) {
293 __PACKAGE__->register_method(
294 api_name => $api_prefix.'.batch.delete',
295 method => 'batch_call',
301 # Create the search-based mass delete method
302 unless ( __PACKAGE__->is_registered( $api_prefix.'.mass_delete' ) ) {
303 __PACKAGE__->register_method(
304 api_name => $api_prefix.'.mass_delete',
305 method => 'mass_delete',