}
-#this is incomplete wrt checking referring customer balances, but that's okay.
-# false positives are acceptable here, its just an optimizaiton
sub condition_sql {
- my( $class, $table ) = @_;
+ my( $class, $table, %opt ) = @_;
+
+ my $age = $class->condition_sql_option_age_from('age', $opt{'time'});
+ my $balance_sql = FS::cust_main->balance_sql( $age );
+ my $balance_date_sql = FS::cust_main->balance_date_sql;
+ my $active_sql = FS::cust_main->active_sql;
+ $balance_sql =~ s/cust_main.custnum/cust_main.referral_custnum/;
+ $balance_date_sql =~ s/cust_main.custnum/cust_main.referral_custnum/;
+ $active_sql =~ s/cust_main.custnum/cust_main.referral_custnum/;
+
+ my $sql = "cust_main.referral_custnum IS NOT NULL".
+ " AND (".$class->condition_sql_option('active')." IS NULL OR $active_sql)".
+ " AND ($balance_date_sql <= $balance_sql)";
- my $sql = FS::cust_main->active_sql;
- $sql =~ s/cust_main.custnum/cust_main.referral_custnum/;
- $sql = 'cust_main.referral_custnum IS NOT NULL AND ('.
- $class->condition_sql_option('active') . ' IS NULL OR '.$sql.')';
return $sql;
}