LP#1823983: repeat_delay check removes event definition id filter
authorMike Rylander <mrylander@gmail.com>
Tue, 9 Apr 2019 15:30:15 +0000 (11:30 -0400)
committerGalen Charlton <gmc@equinoxOLI.org>
Wed, 8 Sep 2021 16:28:56 +0000 (12:28 -0400)
This bug has existed since the repeat_delay feature was added, but likely only
rarely was triggered because most events don't have a repeat_delay, and those
that do don't interact with the same target.  However, as more repeatable event
definitions are created, inappropriate interaction becomes more likely.

In this commit we avoid overwriting the whole join condition clause, which
already contains an event definition id filter and needs to retain it.

Included is an unrelated change that uses the new-ish form of
interval_to_seconds that avoids DST boundary shifting issues by passing a
context DateTime object as the second parameter.

Signed-off-by: Mike Rylander <mrylander@gmail.com>
Signed-off-by: Galen Charlton <gmc@equinoxOLI.org>
Open-ILS/src/perlmods/lib/OpenILS/Application/Trigger.pm

index 9027beb..0d9586e 100644 (file)
@@ -479,9 +479,9 @@ sub create_batch_events {
             }
         }};
         if ($def->repeat_delay) {
-            $join->{'join'}{atev}{filter} = { start_time => {
-                '>' => DateTime->now->subtract( seconds => interval_to_seconds($def->repeat_delay) )->strftime( '%F %T%z' )
-            } };
+            $join->{'join'}{atev}{filter}{start_time} = {
+                '>' => DateTime->now->subtract( seconds => interval_to_seconds($def->repeat_delay, DateTime->now) )->strftime( '%F %T%z' )
+            };
         }
 
         push @{ $filter->{'-and'} }, { '+atev' => { id => undef } };