summaryrefslogtreecommitdiff
path: root/FS
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2015-11-22 19:44:54 -0800
committerIvan Kohler <ivan@freeside.biz>2015-11-22 19:44:54 -0800
commit17b113019aee969742c3b6de47f36d785931bc91 (patch)
tree92765f0315172d290660d2c3a94b7e5b6c8999ce /FS
parent5bc19ba554e29029e7963e40012e43432892306b (diff)
package import w/bulk phone number ranges, RT#39127
Diffstat (limited to 'FS')
-rw-r--r--FS/FS/cust_pkg/Import.pm46
1 files changed, 46 insertions, 0 deletions
diff --git a/FS/FS/cust_pkg/Import.pm b/FS/FS/cust_pkg/Import.pm
index dfe62fb84..26f62f241 100644
--- a/FS/FS/cust_pkg/Import.pm
+++ b/FS/FS/cust_pkg/Import.pm
@@ -214,6 +214,52 @@ sub batch_import {
push @fields, 'locationnum';
}
+ if ( $format =~ /^bulk_(.*)$/ ) {
+
+ $format = $1;
+
+ $opt->{'postinsert_callback'} = sub {
+ my( $record, $param ) = @_;
+
+ my $formatfields = _formatfields;
+ foreach my $svc_x ( grep /^svc/, keys %$formatfields ) {
+
+ my $ff = $formatfields->{$svc_x};
+
+ if ( grep $param->{"$svc_x.$_"}, @$ff ) {
+
+ $param->{'svc_phone.phonenum'} =~ /^\s*(\d+)\s*\-\s*(\d+)\s*$/
+ or return 'Enter a phone number range, with dash as the separator';
+ my($start, $end) = ($1, $2);
+ if ( length($end) < length($start) ) {
+ $end = substr($start, 0, length($start) - length($end) ). $end;
+ }
+
+ foreach my $phonenum ( "$start" .. "$end" ) {
+
+ my $svc = "FS::$svc_x"->new( {
+ 'pkgnum' => $record->pkgnum,
+ 'svcpart' => $record->part_pkg->svcpart($svc_x),
+ map { $_ => $param->{"$svc_x.$_"} } @$ff
+ } );
+
+ $svc->phonenum($phonenum);
+ #$svc->set_default_and_fixed;
+ my $error = $svc->insert;
+ return "error inserting service: $error" if $error;
+
+ }
+
+ }
+
+ }
+
+ return ''; #no error
+
+ };
+
+ }
+
push @fields, ( 'pkgpart', 'discountnum' );
my @date_fields = ();