X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fpart_pkg%2Fvoip_cdr.pm;h=cf9dd7bea933eaa04260f9e94fb7ebb2958ad0b2;hb=57678e05855b1a1c18bdc012a8f9e101fe2e7c2e;hp=150c064757a428506f6cfea7ac7d9e35a13c2aa3;hpb=52c71fabeef58419f20c7d4659592103e35dd48d;p=freeside.git diff --git a/FS/FS/part_pkg/voip_cdr.pm b/FS/FS/part_pkg/voip_cdr.pm index 150c06475..cf9dd7bea 100644 --- a/FS/FS/part_pkg/voip_cdr.pm +++ b/FS/FS/part_pkg/voip_cdr.pm @@ -254,15 +254,15 @@ sub calc_recur { my @call_details = (); if ( $rating_method eq 'prefix' ) { - my $da_rewrite = 0; - if ( scalar(@dirass) && $cdr->dst && grep $cdr->dst eq $_, @dirass ) { + my $da_rewrote = 0; + if ( length($cdr->dst) && grep { $cdr->dst eq $_ } @dirass ){ $cdr->dst('411'); - $da_rewrite = 1; + $da_rewrote = 1; } my $reason = $self->check_chargable( $cdr, - '411_rewrite' => $da_rewrite, - 'option_cache' => %opt_cache, + 'da_rewrote' => $da_rewrote, + 'option_cache' => \%opt_cache, ); if ( $reason ) { @@ -335,11 +335,11 @@ sub calc_recur { if ( $rate_detail ) { + $rate_region = $rate_detail->dest_region; + $regionnum = $rate_region->regionnum; warn " found rate for regionnum $regionnum ". "and rate detail $rate_detail\n" if $DEBUG; - $rate_region = $rate_detail->dest_region; - $regionnum = $rate_region->regionnum; } elsif ( $ignore_unrateable ) { @@ -562,13 +562,13 @@ sub check_chargable { if $opt{'use_disposition_taqua'} && $cdr->disposition != 100; return "carrierid != $opt{'use_carrierid'}" - if $opt{'use_carrierid'} - && $cdr->carrierid != $opt{'use_carrierid'} - && ! $flags{'411_rewrite'}; + if length($opt{'use_carrierid'}) + && $cdr->carrierid ne $opt{'use_carrierid'} #ne otherwise 0 matches '' + && ! $flags{'da_rewrote'}; return "cdrtypenum != $opt{'use_cdrtypenum'}" - if $opt{'use_cdrtypenum'} - && $cdr->cdrtypenum != $opt{'use_cdrtypenum'}; + if length($opt{'use_cdrtypenum'}) + && $cdr->cdrtypenum ne $opt{'use_cdrtypenum'}; #ne otherwise 0 matches '' #all right then, rate it '';