summaryrefslogtreecommitdiff
path: root/FS/FS/cust_bill_pkg.pm
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2020-09-29 14:27:44 -0700
committerIvan Kohler <ivan@freeside.biz>2020-09-29 14:27:44 -0700
commit4ad2efca4dd06a0d3cab96dd4e5a22b9aad2421d (patch)
treeefa53b7c744e2b6f166685c6e38c21076e24694d /FS/FS/cust_bill_pkg.pm
parent7be809e90534e82380f6bab190514c7e10a87972 (diff)
fix rare FP rounding errors on void, RT#84904
Diffstat (limited to 'FS/FS/cust_bill_pkg.pm')
-rw-r--r--FS/FS/cust_bill_pkg.pm28
1 files changed, 20 insertions, 8 deletions
diff --git a/FS/FS/cust_bill_pkg.pm b/FS/FS/cust_bill_pkg.pm
index 6f9c74a..f0d7105 100644
--- a/FS/FS/cust_bill_pkg.pm
+++ b/FS/FS/cust_bill_pkg.pm
@@ -392,7 +392,7 @@ sub void {
}
- $error = $self->delete;
+ $error = $self->delete( skip_update_cust_bill_charged=>1 );
if ( $error ) {
$dbh->rollback if $oldAutoCommit;
return $error;
@@ -448,6 +448,7 @@ Not recommended.
sub delete {
my $self = shift;
+ my %opt = @_;
local $SIG{HUP} = 'IGNORE';
local $SIG{INT} = 'IGNORE';
@@ -493,16 +494,27 @@ sub delete {
}
}
- #fix the invoice amount
+ unless ( $opt{skip_update_cust_bill_charged} ) {
+
+ #fix the invoice amount
+
+ my $cust_bill = $self->cust_bill;
+ my $charged = $cust_bill->charged - $self->setup - $self->recur;
+ $charged = sprintf('%.2f', $charged + 0.00000001 );
+ $cust_bill->charged( $charged );
- my $cust_bill = $self->cust_bill;
- $cust_bill->charged( $cust_bill->charged - $self->setup - $self->recur );
+ #not adding a cc surcharge, but this override lets us modify charged
+ $cust_bill->{'Hash'}{'cc_surcharge_replace_hack'} = 1;
- #not adding a cc surcharge, but this override lets us modify charged
- $cust_bill->{'Hash'}{'cc_surcharge_replace_hack'} = 1;
+ my $error = $cust_bill->replace;
+ if ( $error ) {
+ $dbh->rollback if $oldAutoCommit;
+ return $error;
+ }
+
+ }
- my $error = $cust_bill->replace
- || $self->SUPER::delete(@_);
+ my $error = $self->SUPER::delete(@_);
if ( $error ) {
$dbh->rollback if $oldAutoCommit;
return $error;