From: mark Date: Thu, 1 Dec 2011 05:27:54 +0000 (+0000) Subject: improve "billing day" event condition, #10813 X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=commitdiff_plain;h=b57cbdae3927018370534aa0ea5492d13a1ded9b improve "billing day" event condition, #10813 --- diff --git a/FS/FS/part_event/Condition/billday.pm b/FS/FS/part_event/Condition/billday.pm index 7cd74a1f9..fa0c0a9a2 100644 --- a/FS/FS/part_event/Condition/billday.pm +++ b/FS/FS/part_event/Condition/billday.pm @@ -13,33 +13,42 @@ sub option_fields { ( 'delay' => { label => 'Delay additional days', type => 'text', - value => '1', + value => '0', }, ); } - sub condition { - my( $self, $object ) = @_; + my( $self, $object, %opt ) = @_; my $cust_main = $self->cust_main($object); - my($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time); - - my $delay = $self->option('delay'); - $delay = 0 unless length($delay); + my $delay = $self->option('delay') || 0; + my $as_of = $opt{'time'} - $delay * 86400; # $opt{'time'}, not time() - (!$cust_main->billday) || ($mday >= $cust_main->billday + $delay); + my ($mday) = (localtime($as_of))[3]; # what day it was $delay days before now + + (!$cust_main->billday) || ($mday >= $cust_main->billday); } sub condition_sql { my( $class, $table, %opt ) = @_; - - my($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time); - - my $delay = $class->condition_sql_option_integer('delay', $opt{'driver_name'}); + # ick + my $delay = $class->condition_sql_option_integer('delay', + $opt{'driver_name'}); # returns 0 for null + my $as_of = $opt{'time'} . " - ($delay * 86400)"; # in seconds + my $mday; + if ( $opt{'driver_name'} eq 'Pg' ) { + $mday = "EXTRACT( DAY FROM TO_TIMESTAMP($as_of) )"; + } + elsif ( $opt{'driver_name'} eq 'mysql' ) { + $mday = "DAY( FROM_UNIXTIME($as_of) )"; + } + else { + return 'true' + } - "cust_main.billday is null or $mday >= (cust_main.billday + $delay)"; + "cust_main.billday is null or $mday >= cust_main.billday"; } 1;