summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlevinse <levinse>2011-06-22 22:25:35 +0000
committerlevinse <levinse>2011-06-22 22:25:35 +0000
commiteed7932c6d70767a8b4ae3d04ec19312ad81d885 (patch)
tree5a476ba423bd589903e5bcdf399dea182434a830
parent5c8f344ba6f4a64502d84feb40d6beafbdb7f047 (diff)
cdr/kannel.pm: change row parse format, RT10991
-rw-r--r--FS/FS/cdr/kannel.pm22
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");