From 9d123b7d42dfd95cc7fdc1c726dff792b22913b8 Mon Sep 17 00:00:00 2001 From: Jacek Ablewicz Date: Wed, 16 Oct 2013 17:31:04 +0200 Subject: [PATCH] Bug 9224: Make acqui/finishreceive.pl Plack-compatible Under Plack/mod_perl wrapping, sub update_item() will become a closure, so after the 1st run it will retain its own private instances of the following variables: $booksellerid, $datereceived, $unitprice, $rrp, $biblionumber. I.e., in case update_item() gets invoked 2nd+ time (inside the same process, but for different-subsequent receives) it may incorrectly flag the (old, wrong) biblionumber for Zebra reindexing, and erronously modify the current item[s] with the previously used (wrong) values. This simple patch should make acqui/finishreceive.pl Plack-compatible. Test plan: Test patched acqui/finishreceive.pl script (create and receive some orders w/ items, etc.). Ensure items are gettting added and/or modified correctly during receiving process. Signed-off-by: Jonathan Druart Signed-off-by: Kyle M Hall Passes koha-qa.pl, works as advertised, no regressions found. Signed-off-by: Galen Charlton (cherry picked from commit 6dcc34c1b44f72a8602c4ee95540836e6cd1e7bd) Signed-off-by: Fridolin SOMERS (cherry picked from commit 2a38ac7259bbe88d1d531bfd9d93d9edee64a4c4) Signed-off-by: Tomas Cohen Arazi --- acqui/finishreceive.pl | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/acqui/finishreceive.pl b/acqui/finishreceive.pl index 5ca2c98c33..71180e1cf0 100755 --- a/acqui/finishreceive.pl +++ b/acqui/finishreceive.pl @@ -139,20 +139,16 @@ if ($quantityrec > $origquantityrec ) { } -update_item( $_ ) foreach GetItemnumbersFromOrder( $ordernumber ); - -print $input->redirect("/cgi-bin/koha/acqui/parcel.pl?invoiceid=$invoiceid"); - -################################ End of script ################################ - -sub update_item { - my ( $itemnumber ) = @_; - - ModItem( { +ModItem( + { booksellerid => $booksellerid, dateaccessioned => $datereceived, price => $unitprice, replacementprice => $rrp, replacementpricedate => $datereceived, - }, $biblionumber, $itemnumber ); -} + }, + $biblionumber, + $_ +) foreach GetItemnumbersFromOrder($ordernumber); + +print $input->redirect("/cgi-bin/koha/acqui/parcel.pl?invoiceid=$invoiceid"); -- 2.39.5