- $primary->accountcode( $cdr->lastdata );
- #$primary->freesiderewritestatus( 'taqua-accountcode-primary' );
- my $error = $primary->replace;
- if ( $error ) {
- warn "WARNING: error rewriting primary CDR (will retry): $error\n";
- next;
+ my $cantfind = "can't find primary CDR with session ". $cdr->sessionnum.
+ ", src ". $cdr->subscriber;
+ if ( $cdr->calldate_unix + $sessionnum_giveup < time ) {
+ warn "ERROR: $cantfind; giving up\n";
+ push @status, 'taqua-sessionnum-NOTFOUND';
+ $cdr->status('done'); #so it doesn't try to rate
+ delete $sessionnum_unmatch{$cdr->acctid}; #so it doesn't suck mem
+ } else {
+ warn "WARNING: $cantfind; will keep trying\n";
+ $sessionnum_unmatch{$cdr->acctid} = time;
+ next;
+ }
+
+ } else {
+
+ if ( $cdr->lastapp eq 'acctcode' ) {
+ # lastdata contains the dialed account code
+ $primary->accountcode( $cdr->lastdata );
+ push @status, 'taqua-accountcode';
+ } elsif ( $cdr->lastapp eq 'CallerId' ) {
+ # lastdata contains "allowed" or "restricted"
+ # or case variants thereof
+ if ( lc($cdr->lastdata) eq 'restricted' ) {
+ $primary->clid( 'PRIVATE' );
+ }
+ push @status, 'taqua-callerid';
+ } else {
+ warn "unknown Taqua service name: ".$cdr->lastapp."\n";
+ }
+ #$primary->freesiderewritestatus( 'taqua-accountcode-primary' );
+ my $error = $primary->replace if $primary->modified;
+ if ( $error ) {
+ warn "WARNING: error rewriting primary CDR (will retry): $error\n";
+ next;
+ }
+ $skip{$primary->acctid} = 1;
+
+ $cdr->status('done'); #so it doesn't try to rate
+