LP#1508208: Only look at holds that age protection allows
authorMike Rylander <mrylander@gmail.com>
Tue, 10 Dec 2019 22:17:38 +0000 (17:17 -0500)
committerChris Sharp <csharp@georgialibraries.org>
Wed, 28 Oct 2020 20:29:44 +0000 (16:29 -0400)
commitc166c9ec500f94612553e9be96a689eb057d2906
tree1b84298438dcf1927a45eb9b4740a835aaf5e8de
parent69bf2f251df60da4186fd50b909e9332ddb977b5
LP#1508208: Only look at holds that age protection allows

When hold capture is attempted, we look at (currently) the first 100
holds ordered by Best Hold Sort Selection Order.  If a very long list
of holds are targetting an age-protected item then op capture may not
have a chance to see a viable hold for that copy.

This commit attempts to take into account the age protection currently
set for the copy by restricting the holds to just those where the
hold-copy-map proximity is less than or equal to the maximum proximity
allowed by the age protection.  This works now because we store the
hold proximity in the hold copy map, where we did not before.

Being based on the hold-copy-map proximity, which is calculated
proximity, means this is an approximation and the final hold capture
logic may still reject some holds for the copy.  Likewise, this does
not entirely eliminate the possibility that there may be a better hold
to capture the copy for if the in-range set of holds is very, very
long, but this should allow hold capture to proceed if even
imperfectly.

If no age protection is set for the copy, the current behavior
(looking at all holds) is maintained.

Signed-off-by: Mike Rylander <mrylander@gmail.com>
Signed-off-by: Jason Etheridge <jason@EquinoxInitiative.org>
Signed-off-by: Chris Sharp <csharp@georgialibraries.org>
Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Publisher/action.pm