From 9b76bdcb028992f37b8d16823e63b0872172d8b2 Mon Sep 17 00:00:00 2001 From: erickson Date: Tue, 6 Oct 2009 15:08:00 +0000 Subject: [PATCH] added a batch version of the post-checkin backdate call: open-ils.circ.post_checkin_backdate.batch. It takes an array of circ IDs git-svn-id: svn://svn.open-ils.org/ILS/trunk@14280 dcc99617-32d9-48b4-a31d-7c20da2025e4 --- Open-ILS/src/perlmods/OpenILS/Application/Circ.pm | 36 +++++++++++++++++++++-- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/Open-ILS/src/perlmods/OpenILS/Application/Circ.pm b/Open-ILS/src/perlmods/OpenILS/Application/Circ.pm index 7497fc3a36..7415181090 100644 --- a/Open-ILS/src/perlmods/OpenILS/Application/Circ.pm +++ b/Open-ILS/src/perlmods/OpenILS/Application/Circ.pm @@ -375,11 +375,41 @@ __PACKAGE__->register_method( } ); +__PACKAGE__->register_method( + method => "post_checkin_backdate_circ", + api_name => "open-ils.circ.post_checkin_backdate.batch", + stream => 1, + signature => { + desc => q/@see open-ils.circ.post_checkin_backdate. Batch mode/, + params => [ + {desc => 'Authentication token', type => 'string'}, + {desc => 'List of Circ ID', type => 'array'}, + {desc => 'ISO8601 backdate', type => 'string'}, + ], + return => {desc => q/Set of: 1 on success, failure event on error/} + } +); + + sub post_checkin_backdate_circ { my( $self, $conn, $auth, $circ_id, $backdate ) = @_; - - my $e = new_editor(authtoken=>$auth, xact=>1); + my $e = new_editor(authtoken=>$auth); return $e->die_event unless $e->checkauth; + if($self->api_name =~ /batch/) { + $conn->respond(post_checkin_backdate_circ_impl($e, $_, $backdate)) for $circ_id; + } else { + $conn->respond_complete(post_checkin_backdate_circ_impl($e, $circ_id, $backdate)); + } + + $e->disconnect; + return undef; +} + + +sub post_checkin_backdate_circ_impl { + my($e, $circ_id, $backdate) = @_; + + $e->xact_begin; my $circ = $e->retrieve_action_circulation($circ_id) or return $e->die_event; @@ -404,7 +434,7 @@ sub post_checkin_backdate_circ { $evt = OpenILS::Application::Circ::CircCommon->reopen_xact($e, $circ->id); return $evt if $evt; - $e->commit; + $e->xact_commit; return 1; } -- 2.11.0