[freeside-commits] freeside/FS/FS/part_pkg voip_cdr.pm, 1.129, 1.130
Mark Wells
mark at wavetail.420.am
Tue Dec 13 12:40:30 PST 2011
- Previous message: [freeside-commits] freeside/FS/FS cdr.pm, 1.76, 1.77 cust_bill_pkg.pm, 1.65, 1.66 part_pkg.pm, 1.127, 1.128 svc_pbx.pm, 1.12, 1.13 svc_phone.pm, 1.40, 1.41
- Next message: [freeside-commits] freeside/FS/FS cdr.pm, 1.74.2.2, 1.74.2.3 cust_bill_pkg.pm, 1.56.2.9, 1.56.2.10 part_pkg.pm, 1.123.2.3, 1.123.2.4 svc_pbx.pm, 1.12, 1.12.2.1 svc_phone.pm, 1.39.2.1, 1.39.2.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/cvsroot/freeside/FS/FS/part_pkg
In directory wavetail.420.am:/tmp/cvs-serv25338/FS/FS/part_pkg
Modified Files:
voip_cdr.pm
Log Message:
CDR type separation and summary formats, #15535
Index: voip_cdr.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/part_pkg/voip_cdr.pm,v
retrieving revision 1.129
retrieving revision 1.130
diff -u -w -d -r1.129 -r1.130
--- voip_cdr.pm 10 Dec 2011 22:20:37 -0000 1.129
+++ voip_cdr.pm 13 Dec 2011 20:40:28 -0000 1.130
@@ -403,6 +403,7 @@
my %options = (
'disable_src' => $self->option('disable_src'),
'default_prefix' => $self->option('default_prefix'),
+ 'cdrtypenum' => $self->option('use_cdrtypenum'),
'status' => '',
'for_update' => 1,
); # $last_bill, $$sdate )
@@ -434,6 +435,8 @@
if ( $rating_method eq 'prefix' ) {
my $da_rewrote = 0;
+ # this will result in those CDRs being marked as done... is that
+ # what we want?
if ( length($cdr->dst) && grep { $cdr->dst eq $_ } @dirass ){
$cdr->dst('411');
$da_rewrote = 1;
@@ -448,6 +451,8 @@
warn "not charging for CDR ($reason)\n" if $DEBUG;
$charge = 0;
+ # this will result in those CDRs being marked as done... is that
+ # what we want?
} else {
@@ -767,6 +772,7 @@
warn "Incrementing \$charges by $charge. Now $charges\n" if $DEBUG;
$charges += $charge;
+ if ( !$self->sum_usage ) {
@call_details = (
$cdr->downstream_csv( 'format' => $output_format,
'granularity' => $rate_detail->sec_granularity,
@@ -778,6 +784,7 @@
'dst_regionname' => $regionname,
)
);
+ }
} #if(there is a rate_detail)
@@ -799,6 +806,7 @@
regionname => $regionname,
};
} else { #only used for $rating_method eq 'upstream' now
+ # and for sum_ formats
$csv->combine(@call_details);
$call_details =
{ format => 'C',
@@ -812,9 +820,6 @@
regionname => $regionname,
};
}
- #warn " adding details on charge to invoice: [ ".
- # join(', ', @{$call_details} ). " ]"
- # if ( $DEBUG && ref($call_details) );
push @invoice_details_sort, [ $call_details, $cdr->calldate_unix ];
}
@@ -834,10 +839,43 @@
} # $cdr
- my @sorted_invoice_details = sort { @{$a}[1] <=> @{$b}[1] } @invoice_details_sort;
+ if ( !$self->sum_usage ) {
+ #sort them
+ my @sorted_invoice_details =
+ sort { @{$a}[1] <=> @{$b}[1] } @invoice_details_sort;
foreach my $sorted_call_detail ( @sorted_invoice_details ) {
push @$details, @{$sorted_call_detail}[0];
}
+ }
+ else { #$self->sum_usage
+ my $sum_detail = {
+ amount => 0,
+ format => 'C',
+ classnum => '', #XXX
+ duration => 0,
+ phonenum => $svc_x->phonenum,
+ accountcode => '', #XXX
+ startdate => '', #XXX
+ regionnam => '',
+ };
+ # combine the entire set of CDRs
+ foreach ( @invoice_details_sort ) {
+ $sum_detail->{amount} += $_->[0]{amount};
+ $sum_detail->{duration} += $_->[0]{duration};
+ }
+ my $total_cdr = FS::cdr->new({
+ 'billsec' => $sum_detail->{duration},
+ 'src' => $sum_detail->{phonenum},
+ });
+ $sum_detail->{detail} = $total_cdr->downstream_csv(
+ format => $output_format,
+ seconds => $sum_detail->{duration},
+ charge => sprintf('%.2f',$sum_detail->{amount}),
+ phonenum => $sum_detail->{phonenum},
+ count => scalar(@invoice_details_sort),
+ );
+ push @$details, $sum_detail;
+ } #if $self->sum_usage
} # $cust_svc
@@ -924,6 +962,7 @@
&& $cdr->carrierid ne $opt{'use_carrierid'} #ne otherwise 0 matches ''
&& ! $flags{'da_rewrote'};
+ # unlike everything else, use_cdrtypenum is applied in FS::svc_x::get_cdrs.
return "cdrtypenum != $opt{'use_cdrtypenum'}"
if length($opt{'use_cdrtypenum'})
&& $cdr->cdrtypenum ne $opt{'use_cdrtypenum'}; #ne otherwise 0 matches ''
@@ -1000,5 +1039,20 @@
$count;
}
+# tells whether cust_bill_pkg_detail should return a single line for
+# each phonenum
+sub sum_usage {
+ my $self = shift;
+ $self->option('output_format') =~ /^sum_/;
+}
+
+# and whether cust_bill should show a detail line for the service label
+# (separate from usage details)
+sub hide_svc_detail {
+ my $self = shift;
+ $self->option('output_format') =~ /^sum_/;
+}
+
+
1;
- Previous message: [freeside-commits] freeside/FS/FS cdr.pm, 1.76, 1.77 cust_bill_pkg.pm, 1.65, 1.66 part_pkg.pm, 1.127, 1.128 svc_pbx.pm, 1.12, 1.13 svc_phone.pm, 1.40, 1.41
- Next message: [freeside-commits] freeside/FS/FS cdr.pm, 1.74.2.2, 1.74.2.3 cust_bill_pkg.pm, 1.56.2.9, 1.56.2.10 part_pkg.pm, 1.123.2.3, 1.123.2.4 svc_pbx.pm, 1.12, 1.12.2.1 svc_phone.pm, 1.39.2.1, 1.39.2.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the freeside-commits
mailing list