diff options
author | levinse <levinse> | 2011-06-22 22:25:35 +0000 |
---|---|---|
committer | levinse <levinse> | 2011-06-22 22:25:35 +0000 |
commit | eed7932c6d70767a8b4ae3d04ec19312ad81d885 (patch) | |
tree | 5a476ba423bd589903e5bcdf399dea182434a830 | |
parent | 5c8f344ba6f4a64502d84feb40d6beafbdb7f047 (diff) |
cdr/kannel.pm: change row parse format, RT10991
-rw-r--r-- | FS/FS/cdr/kannel.pm | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/FS/FS/cdr/kannel.pm b/FS/FS/cdr/kannel.pm index 60802ab7b..e9267c169 100644 --- a/FS/FS/cdr/kannel.pm +++ b/FS/FS/cdr/kannel.pm @@ -14,16 +14,30 @@ use FS::cdr qw( _cdr_date_parser_maker ); 'row_callback' => sub { my $row = shift; return ' ' if $row =~ /.*Log (begins|ends)$/; die "invalid row format for '$row'" unless - $row =~ /^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) ([A-Za-z ]+) (\[SMSC:\w+\] \[SVC:\w*\] \[ACT:\w*\] \[BINF:\w*\] \[FID:\w*\]) \[from:(\s|)(|\+)(\d+)\] \[to:(|\+)(\d+)\] (\[flags:.*?\]) \[msg:(\d+):(.*?)\] (\[udh:.*?\])$/; - $row = "$1,$2,$3,$6,$8,$9,$10,$12"; + $row =~ /^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) ([A-Za-z ]+) (\[SMSC:\w+\] \[SVC:\w*\] \[ACT:\w*\] \[BINF:\w*\] \[FID:\w*\]) \[from:(.*?)\] \[to:(.*?)\] (\[flags:.*?\]) \[msg:(\d+):.*?\] (\[udh:.*?\])$/; + $row = "$1,$2,$3,$4,$5,$6,$7,$8"; $row; }, 'import_fields' => [ _cdr_date_parser_maker('startdate'), 'disposition', 'userfield', # [SMSC: ... FID...], five fields - 'src', - 'dst', + + sub { + my($cdr, $src) = @_; + $src =~ s/[^\+\d]//g; + $src =~ /^(\+|)(\d+)$/ + or die "unparsable number: $src"; #maybe we shouldn't die... + $cdr->src("$1$2"); + }, + + sub { + my($cdr, $dst) = @_; + $dst =~ s/[^\+\d]//g; + $dst =~ /^(\+|)(\d+)$/ + or die "unparsable number: $dst"; #maybe we shouldn't die... + $cdr->dst("$1$2"); + }, sub { my($cdr, $flags) = @_; $cdr->userfield($cdr->userfield." $flags"); |