[freeside-commits] freeside/FS/FS/Cron set_lata_have_usage.pm, NONE, 1.1

Erik Levinson levinse at wavetail.420.am
Wed Jun 22 11:32:23 PDT 2011


Update of /home/cvs/cvsroot/freeside/FS/FS/Cron
In directory wavetail.420.am:/tmp/cvs-serv25824/FS/FS/Cron

Added Files:
	set_lata_have_usage.pm 
Log Message:
improve performance of DID provisioning status report, RT10988

--- NEW FILE: set_lata_have_usage.pm ---
package FS::Cron::set_lata_have_usage;

use strict;
use warnings;
use vars qw( @ISA @EXPORT_OK $me $DEBUG );
use Exporter;
use FS::UID qw(adminsuidsetup);
use FS::Record qw(qsearch qsearchs dbh);
use FS::lata;
use FS::phone_avail;
use FS::svc_phone;
use Data::Dumper;

@ISA = qw( Exporter );
@EXPORT_OK = qw ( set_lata_have_usage );
$DEBUG = 0;
$me = '[FS::Cron::set_lata_have_usage]';

sub set_lata_have_usage {
    my %opt = @_;
    
    my $debug = 0;
    $debug = 1 if $opt{'v'};
    $debug = $opt{'l'} if $opt{'l'};
  
    local $DEBUG = $debug if $debug;
  
    warn "$me set_lata_have_usage called time=".time."\n" if $DEBUG;

    local $SIG{HUP} = 'IGNORE';
    local $SIG{INT} = 'IGNORE';
    local $SIG{QUIT} = 'IGNORE';
    local $SIG{TERM} = 'IGNORE';
    local $SIG{TSTP} = 'IGNORE';
    local $SIG{PIPE} = 'IGNORE';

    my $oldAutoCommit = $FS::UID::AutoCommit;
    local $FS::UID::AutoCommit = 0;
    my $dbh = dbh;

    my %latas = map { $_->latanum => $_ } qsearch('lata', {});

    foreach my $lata ( keys %latas ) {
            next unless $latas{$lata}->have_usage > 0;
            $latas{$lata}->have_usage(0);
            my $error = $latas{$lata}->replace;
            if ( $error ) {
                $dbh->rollback if $oldAutoCommit;
                die "error replacing LATA $lata: $error";
            }
    }
    warn "$me cleared have_usage for all LATAs time=".time."\n" if $DEBUG;

    my @dids = qsearch({     'table'     => 'svc_phone',
                                    'hashref'   => 
                                        { 'latanum' =>
                                            { 'op'      => '>',
                                              'value'   => '0',
                                            },
                                        },
                                    'addl_from' => 'join phone_avail using (svcnum)',
                                      });
    warn "$me DID query finished time=".time."\n" if $DEBUG;

    my $count = 0;
    foreach my $did ( @dids ) {
        warn "$me count=$count time=".time."\n" if $DEBUG && ($count % 1000 == 0);
        my @cdrs = $did->get_cdrs;
        my $lata = $latas{$did->latanum};
        $count++;
        if ( scalar(@cdrs) ) {
            if ( !$lata->have_usage ) {
                $lata->have_usage(1);
            }
            else {
                $lata->have_usage($lata->have_usage+1);
            }
        }
    }

    warn "$me Set have_usage finished time=".time."\n" if $DEBUG;

    foreach my $lata ( keys %latas ) {
        if ( $latas{$lata}->modified ) {
            print "$lata ".$latas{$lata}->have_usage."\n";
            my $error = $latas{$lata}->replace;
            if ( $error ) {
                $dbh->rollback if $oldAutoCommit;
                die "error replacing LATA $lata: $error";
            }
        }
    }

    $dbh->commit or die $dbh->errstr if $oldAutoCommit;
    warn "$me done time=".time."\n" if $DEBUG;
}

1;



More information about the freeside-commits mailing list