use strict;
use base qw( FS::cdr );
-use vars qw( %info );
+use vars qw( %info %cdrtypes);
use DateTime;
+use FS::Record qw( qsearch );
+use FS::cdr_type;
my ($tmp_mday, $tmp_mon, $tmp_year);
'type' => 'csv',
'sep_char' => ',',
'disabled' => 0,
+ 'header_buffer' => sub {
+
+ %cdrtypes = ( map { $_->cdrtypename => $_->cdrtypenum }
+ qsearch('cdr_type', {})
+ );
+ },
#listref of what to do with each field from the CDR, in order
'import_fields' => [
my ($cdr, $field, $conf, $hashref) = @_;
$hashref->{skiprow} = 1 unless $field eq 'DCR';
},
- '', # 2. BWGroupID (centrex group)
- '', # 3. BWGroupNumber
+ 'accountcode',# 2. BWGroupID (centrex group)
+ sub { # 3. BWGroupNumber
+ my ($cdr, $field) = @_; #, $conf, $hashref) = @_;
+
+ if ($cdr->accountcode eq '' && $field =~ /^(1800|1300)/){
+ $cdr->charged_party($field);
+ $cdr->accountcode($field);
+ }
+ },
'uniqueid', # 4. Record ID
- 'dcontext', # 5. Call Category (LOCAL, NATIONAL, FREECALL, MOBILE)
+ sub { # 5. Call Category (LOCAL, NATIONAL, FREECALL, MOBILE)
+ my ($cdr, $data) = @_;
+ $data ||= 'none';
+ $cdr->cdrtypenum($cdrtypes{$data} || '');
+ $cdr->set('dcontext', $data);
+ },
sub { # 6. Start Date (DDMMYYYY
my ($cdr, $date) = @_;
$date =~ /^(\d{2})(\d{2})(\d{4})$/