]> git.koha-community.org Git - koha.git/commit
Bug 11338: prevent deletion of items that are captured for holds
authorFridolyn SOMERS <fridolyn.somers@biblibre.com>
Wed, 4 Dec 2013 16:05:32 +0000 (17:05 +0100)
committerFridolin SOMERS <fridolin.somers@biblibre.com>
Fri, 3 Jan 2014 09:08:16 +0000 (10:08 +0100)
commit87cd69d35158869e27cfa310cf41d2f2f144f214
treec0795aa2afaf2627eefccbaaaf7b621680e01f42
parentc65a5d73a7678cb4757566181d566e903a264aee
Bug 11338: prevent deletion of items that are captured for holds

In C4::Items::DelItemCheck, there are two SQL queries: one to check
if item is on loan, the other if item is reserved.

Those two queries use "SELECT * FROM table", fetch the data with
"$var = $sth->fetchrow", and use "$var" as a boolean condition.

This is not correct, SQL query should be "SELECT COUNT(*) FROM table".

As a consequence, it was possible to delete an item without warning to
the operator even if it was waiting on the hold shelf or in transit to
fill a hold.

This patch corrects the SQL queries and sets my ($var) to show that
fetchrow returns an array.

Test plan :
- Set an item A onloan
- Set an item B reserved and the reserve waiting
- Go to items cataloguing : cgi-bin/koha/cataloguing/additem.pl?biblionumber=XXX
- Try to delete item A
=> You get an alert and item is not deleted
- Try to delete item B
=> You get an alert and item is not deleted

Signed-off-by: Chris Cormack <chrisc@catalyst.net.nz>
Works, and has the added bonus of being a tiny bit faster.

Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de>
Passes t, xt and QA script tests.
Also tried deleting via batch delete - correct warnings are displayed.

Signed-off-by: Galen Charlton <gmc@esilibrary.com>
(cherry picked from commit d000a716352fb61dc0dae7715eda15896b53b4e7)
Signed-off-by: Fridolin SOMERS <fridolin.somers@biblibre.com>
C4/Items.pm