X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcust_main%2FPackages.pm;h=19ee63aa43f2588e81a74d9735be5abc77cd59f1;hb=9049947bceb63fd795aab13ee5a17b17f180a4aa;hp=41ef2289422a8d002fc57331ad962b03292f00ec;hpb=71c6403be78e91e34d4124da35c9d0d284ad197d;p=freeside.git diff --git a/FS/FS/cust_main/Packages.pm b/FS/FS/cust_main/Packages.pm index 41ef22894..19ee63aa4 100644 --- a/FS/FS/cust_main/Packages.pm +++ b/FS/FS/cust_main/Packages.pm @@ -59,6 +59,15 @@ jobs will have a dependancy on the supplied job (they will not run until the specific job completes). This can be used to defer provisioning until some action completes (such as running the customer's credit card successfully). +=item noexport + +This option is option is deprecated but still works for now (use +I instead for new code). If I is set true, no +provisioning jobs (exports) are scheduled. (You can schedule them later with +the B method for each cust_pkg object. Using the B method +on the cust_main object is not recommended, as existing services will also be +reexported.) + =item ticket_subject Optional subject for a ticket created and attached to this customer @@ -81,6 +90,8 @@ sub order_pkg { join(', ', map { "$_: $opt->{$_}" } keys %$opt ). "\n" if $DEBUG; + local $FS::svc_Common::noexport_hack = 1 if $opt->{'noexport'}; + my $cust_pkg = $opt->{'cust_pkg'}; my $svcs = $opt->{'svcs'} || []; @@ -130,13 +141,10 @@ sub order_pkg { } elsif ( $opt->{'cust_location'} ) { - if ( ! $opt->{'cust_location'}->locationnum ) { - # not inserted yet - my $error = $opt->{'cust_location'}->insert; - if ( $error ) { - $dbh->rollback if $oldAutoCommit; - return "inserting cust_location (transaction rolled back): $error"; - } + my $error = $opt->{'cust_location'}->find_or_insert; + if ( $error ) { + $dbh->rollback if $oldAutoCommit; + return "inserting cust_location (transaction rolled back): $error"; } $cust_pkg->locationnum($opt->{'cust_location'}->locationnum); @@ -186,20 +194,16 @@ sub order_pkg { 'pkglinknum' => $link->pkglinknum, 'custnum' => $self->custnum, 'main_pkgnum' => $cust_pkg->pkgnum, - 'locationnum' => $cust_pkg->locationnum, # try to prevent as many surprises as possible - 'pkgbatch' => $cust_pkg->pkgbatch, - 'start_date' => $cust_pkg->start_date, - 'order_date' => $cust_pkg->order_date, - 'expire' => $cust_pkg->expire, - 'adjourn' => $cust_pkg->adjourn, - 'contract_end' => $cust_pkg->contract_end, - 'refnum' => $cust_pkg->refnum, - 'discountnum' => $cust_pkg->discountnum, - 'waive_setup' => $cust_pkg->waive_setup, 'allow_pkgpart' => $opt->{'allow_pkgpart'}, + map { $_ => $cust_pkg->$_() } + qw( pkgbatch + start_date order_date expire adjourn contract_end + refnum discountnum waive_setup + ) }); - $error = $self->order_pkg('cust_pkg' => $pkg); + $error = $self->order_pkg('cust_pkg' => $pkg, + 'locationnum' => $cust_pkg->locationnum); if ( $error ) { $dbh->rollback if $oldAutoCommit; return "inserting supplemental package: $error"; @@ -238,7 +242,8 @@ on the supplied jobnum (they will not run until the specific job completes). This can be used to defer provisioning until some action completes (such as running the customer's credit card successfully). -The I option is deprecated. If I is set true, no +The I option is deprecated but still works for now (use +I instead for new code). If I is set true, no provisioning jobs (exports) are scheduled. (You can schedule them later with the B method for each cust_pkg object. Using the B method on the cust_main object is not recommended, as existing services will also be @@ -504,8 +509,9 @@ sub sort_packages { return 0 if !$a_num_cust_svc && !$b_num_cust_svc; return -1 if $a_num_cust_svc && !$b_num_cust_svc; return 1 if !$a_num_cust_svc && $b_num_cust_svc; - my @a_cust_svc = $a->cust_svc; - my @b_cust_svc = $b->cust_svc; + return 0 if $a_num_cust_svc + $b_num_cust_svc > 20; #for perf, just give up + my @a_cust_svc = $a->cust_svc_unsorted; + my @b_cust_svc = $b->cust_svc_unsorted; return 0 if !scalar(@a_cust_svc) && !scalar(@b_cust_svc); return -1 if scalar(@a_cust_svc) && !scalar(@b_cust_svc); return 1 if !scalar(@a_cust_svc) && scalar(@b_cust_svc);