From d96c88c4b987aebb1d762357247dcb15d6ba9ed6 Mon Sep 17 00:00:00 2001 From: Bill Erickson Date: Thu, 16 Feb 2023 11:02:49 -0500 Subject: [PATCH] LP2007591 Allow Last-Copy Delete to Create Hold Notices Fixes an issue where attempting to create A/T events for recently canceled holds fails becuase the cancel_time on the hold is the pre-insert value of "now" instead of a valid date string. Resolve the issue by fetching the post-insert copy of the hold, so it has all of the correct in-database values, before passing the hold to A/T for processing. Signed-off-by: Bill Erickson Signed-off-by: Mike Rylander --- Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/AssetCommon.pm | 4 ++++ Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/BibCommon.pm | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/AssetCommon.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/AssetCommon.pm index 079fed631e..42e0451357 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/AssetCommon.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/AssetCommon.pm @@ -575,6 +575,10 @@ sub cancel_hold_list { $hold->cancel_cause(1); # un-targeted expiration. Do we need an alternate "target deleted" cause? $editor->update_action_hold_request($hold) or return $editor->die_event; + # Update our copy of the hold to pick up the cancel_time + # before we pass it off to A/T. + $hold = $editor->retrieve_action_hold_request($hold->id); + # tell A/T the hold was cancelled. Don't wait for a response.. my $at_ses = OpenSRF::AppSession->create('open-ils.trigger'); $at_ses->request( diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/BibCommon.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/BibCommon.pm index 5f48f7d97c..d10cfd1f1d 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/BibCommon.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Cat/BibCommon.pm @@ -364,6 +364,10 @@ sub delete_rec { $hold->cancel_cause(1); # un-targeted expiration. $editor->update_action_hold_request($hold) or return $editor->die_event; + # Update our copy of the hold to pick up the cancel_time + # before we pass it off to A/T. + $hold = $editor->retrieve_action_hold_request($hold->id); + my $at_ses = OpenSRF::AppSession->create('open-ils.trigger'); $at_ses->request( 'open-ils.trigger.event.autocreate', -- 2.11.0