- $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 + $accountcode_giveup < time ) {
+ push @status, 'taqua-accountcode-NOTFOUND';
+ $cdr->status('done'); #so it doesn't try to rate
+ } else {
+ warn "WARNING: $cantfind; will keep trying\n";
+ $accountcode_unmatch{$cdr->sessionnum.','.$cdr->subscriber} = time;
+ next;
+ }
+
+ } else {
+
+ $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;
+ }
+
+ push @status, 'taqua-accountcode';
+ $cdr->status('done'); #so it doesn't try to rate
+