From: Lebbeous Fogle-Weekley Date: Wed, 19 Oct 2011 22:16:14 +0000 (-0400) Subject: TPAC: avoid problem with HOLD_EXISTS event in hold placement X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=80d5c4a4c7e81a7b5739befdd5a621a70d42d5f0;p=evergreen%2Fmasslnc.git TPAC: avoid problem with HOLD_EXISTS event in hold placement If you place a hold on something that generates a HOLD_EXISTS event (and no other events?) you get a 500 error from Apache and an error in the logs saying "not a hash reference" about $result in the lines I've changed here. Signed-off-by: Lebbeous Fogle-Weekley Signed-off-by: Bill Erickson --- diff --git a/Open-ILS/src/perlmods/lib/OpenILS/WWW/EGCatLoader/Account.pm b/Open-ILS/src/perlmods/lib/OpenILS/WWW/EGCatLoader/Account.pm index a532bffc91..59bc862dd5 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/WWW/EGCatLoader/Account.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/WWW/EGCatLoader/Account.pm @@ -695,7 +695,13 @@ sub load_place_hold { } else { # hold-specific failure event $hdata->{hold_failed} = 1; - $hdata->{hold_failed_event} = $result->{last_event}; + + if (ref $result eq 'HASH') { + $hdata->{hold_failed_event} = $result->{last_event}; + } elsif (ref $result eq 'ARRAY') { + $hdata->{hold_failed_event} = pop @$result; + } + $hdata->{could_override} = $self->test_could_override($hdata->{hold_failed_event}); } }