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:56:47 +0000 (16:56 -0400)
commitc90a3066bf5eb4e41e028431daeb1dc390bc38c9
treec8b1a59821aa3fee7d7aea64bd9e56358be12ba4
parenta6ae2226e4f314375bc398e3ebbc98b76b125b6f
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