use strict;
use vars qw( @ISA @EXPORT_OK $DEBUG $me
$conf $cdr_prerate %cdr_prerate_cdrtypenums
- $use_lrn $support_key
+ $use_lrn $support_key $max_duration
);
use Exporter;
use List::Util qw(first min);
use LWP::UserAgent;
use HTTP::Request::Common qw(POST);
use IO::Socket::SSL;
-use JSON::XS qw(decode_json);
+use Cpanel::JSON::XS;
@ISA = qw(FS::Record);
-@EXPORT_OK = qw( _cdr_date_parser_maker _cdr_min_parser_maker );
+@EXPORT_OK = qw( _cdr_date_parser_maker _cdr_min_parser_maker _cdr_date_parse );
$DEBUG = 0;
$me = '[FS::cdr]';
$support_key = $conf->config('support-key');
$use_lrn = $conf->exists('cdr-lrn_lookup');
+ $max_duration = $conf->config('cdr-max_duration') || 0;
+
});
=head1 NAME
my $part_pkg = $opt{'part_pkg'} or return "No part_pkg specified";
my $cust_pkg = $opt{'cust_pkg'};
+ ###
+ # (Directory assistance) rewriting
+ ###
+
my $da_rewrote = 0;
# this will result in those CDRs being marked as done... is that
# what we want?
$da_rewrote = 1;
}
+ ###
+ # Checks to see if the CDR is chargeable
+ ###
+
my $reason = $part_pkg->check_chargable( $self,
'da_rewrote' => $da_rewrote,
);
}
}
+ my $rated_seconds = $part_pkg->option_cacheable('use_duration')
+ ? $self->duration
+ : $self->billsec;
+ if ( $max_duration > 0 && $rated_seconds > $max_duration ) {
+ return $self->set_status_and_rated_price(
+ 'failed',
+ '',
+ $opt{'svcnum'},
+ );
+ }
+
###
# look up rate details based on called station id
# (or calling station id for toll free calls)
# We don't round _anything_ (except granularizing)
# until the final $charge = sprintf("%.2f"...).
- my $rated_seconds = $part_pkg->option_cacheable('use_duration')
- ? $self->duration
- : $self->billsec;
my $seconds_left = $rated_seconds;
#no, do this later so it respects (group) included minutes
#
# Used by FS::Upgrade to migrate to a new database.
+use FS::upgrade_journal;
sub _upgrade_data {
my ($class, %opts) = @_;
+ return if FS::upgrade_journal->is_done('cdr_cdrbatchnum');
+
warn "$me upgrading $class\n" if $DEBUG;
my $sth = dbh->prepare(
$sth->execute($cdrbatchnum{$cdrbatch}, $cdrbatch) or die $sth->errstr;
}
+ FS::upgrade_journal->set_done('cdr_cdrbatchnum');
+
}
=item ip_addr_sql FIELD RANGE