X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Frate.pm;h=a471e2ea4904f5a3e82355fb8a7146930785cb05;hb=c934eb18a66126faab43459780940bfdb19b30ad;hp=b8a6940414f6ec62a163ce9389e7ea9c8bc09cf8;hpb=f7fd2a3e34da751cbc02bbf215e99c6dc89adc15;p=freeside.git diff --git a/FS/FS/rate.pm b/FS/FS/rate.pm index b8a694041..a471e2ea4 100644 --- a/FS/FS/rate.pm +++ b/FS/FS/rate.pm @@ -1,12 +1,14 @@ package FS::rate; use strict; -use vars qw( @ISA ); -use FS::Record qw( qsearch qsearchs dbh ); +use vars qw( @ISA $DEBUG ); +use FS::Record qw( qsearch qsearchs dbh fields ); use FS::rate_detail; @ISA = qw(FS::Record); +$DEBUG = 1; + =head1 NAME FS::rate - Object methods for rate records @@ -94,13 +96,32 @@ sub insert { } if ( $options{'rate_detail'} ) { + + my( $num, $last, $min_sec ) = (0, time, 5); #progressbar foo + foreach my $rate_detail ( @{$options{'rate_detail'}} ) { + $rate_detail->ratenum($self->ratenum); $error = $rate_detail->insert; if ( $error ) { $dbh->rollback if $oldAutoCommit; return $error; } + + if ( $options{'job'} ) { + $num++; + if ( time - $min_sec > $last ) { + my $error = $options{'job'}->update_statustext( + int( 100 * $num / scalar( @{$options{'rate_detail'}} ) ) + ); + if ( $error ) { + $dbh->rollback if $oldAutoCommit; + return $error; + } + $last = time; + } + } + } } @@ -148,8 +169,8 @@ sub replace { local $FS::UID::AutoCommit = 0; my $dbh = dbh; - my @old_rate_detail = (); - @old_rate_detail = $old->rate_detail if $options{'rate_detail'}; +# my @old_rate_detail = (); +# @old_rate_detail = $old->rate_detail if $options{'rate_detail'}; my $error = $new->SUPER::replace($old); if ($error) { @@ -157,21 +178,67 @@ sub replace { return $error; } - foreach my $old_rate_detail ( @old_rate_detail ) { - my $error = $old_rate_detail->delete; - if ($error) { +# foreach my $old_rate_detail ( @old_rate_detail ) { +# +# my $error = $old_rate_detail->delete; +# if ($error) { +# $dbh->rollback if $oldAutoCommit; +# return $error; +# } +# +# if ( $options{'job'} ) { +# $num++; +# if ( time - $min_sec > $last ) { +# my $error = $options{'job'}->update_statustext( +# int( 50 * $num / scalar( @old_rate_detail ) ) +# ); +# if ( $error ) { +# $dbh->rollback if $oldAutoCommit; +# return $error; +# } +# $last = time; +# } +# } +# +# } + if ( $options{'rate_detail'} ) { + my $sth = $dbh->prepare('DELETE FROM rate_detail WHERE ratenum = ?') or do { $dbh->rollback if $oldAutoCommit; - return $error; - } - } - - foreach my $rate_detail ( @{$options{'rate_detail'}} ) { - $rate_detail->ratenum($new->ratenum); - $error = $rate_detail->insert; - if ( $error ) { + return $dbh->errstr; + }; + + $sth->execute($old->ratenum) or do { $dbh->rollback if $oldAutoCommit; - return $error; + return $sth->errstr; + }; + + my( $num, $last, $min_sec ) = (0, time, 5); #progresbar foo +# $num = 0; + foreach my $rate_detail ( @{$options{'rate_detail'}} ) { + + $rate_detail->ratenum($new->ratenum); + $error = $rate_detail->insert; + if ( $error ) { + $dbh->rollback if $oldAutoCommit; + return $error; + } + + if ( $options{'job'} ) { + $num++; + if ( time - $min_sec > $last ) { + my $error = $options{'job'}->update_statustext( + int( 100 * $num / scalar( @{$options{'rate_detail'}} ) ) + ); + if ( $error ) { + $dbh->rollback if $oldAutoCommit; + return $error; + } + $last = time; + } + } + } + } $dbh->commit or die $dbh->errstr if $oldAutoCommit; @@ -230,6 +297,76 @@ sub rate_detail { =back +=head1 SUBROUTINES + +=over 4 + +=item process + +Experimental job-queue processor for web interface adds/edits + +=cut + +use Storable qw(thaw); +use Data::Dumper; +use MIME::Base64; +sub process { + my $job = shift; + + my $param = thaw(decode_base64(shift)); + warn Dumper($param) if $DEBUG; + + my $old = qsearchs('rate', { 'ratenum' => $param->{'ratenum'} } ) + if $param->{'ratenum'}; + + my @rate_detail = map { + + my $regionnum = $_->regionnum; + if ( $param->{"sec_granularity$regionnum"} ) { + + new FS::rate_detail { + 'dest_regionnum' => $regionnum, + map { $_ => $param->{"$_$regionnum"} } + qw( min_included min_charge sec_granularity ) + }; + + } else { + + new FS::rate_detail { + 'dest_regionnum' => $regionnum, + 'min_included' => 0, + 'min_charge' => 0, + 'sec_granularity' => '60' + }; + + } + + } qsearch('rate_region', {} ); + + my $rate = new FS::rate { + map { $_ => $param->{$_} } + fields('rate') + }; + + my $error = ''; + if ( $param->{'ratenum'} ) { + warn "$rate replacing $old (". $param->{'ratenum'}. ")\n" if $DEBUG; + $error = $rate->replace( $old, + 'rate_detail' => \@rate_detail, + 'job' => $job, + ); + } else { + warn "inserting $rate\n" if $DEBUG; + $error = $rate->insert( 'rate_detail' => \@rate_detail, + 'job' => $job, + ); + #$ratenum = $rate->getfield('ratenum'); + } + + die "$error\n" if $error; + +} + =head1 BUGS =head1 SEE ALSO