X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcust_location.pm;h=fee77a8b106b3eb730f9d6fc88e026cedb089e9a;hb=e2ee874843b19f6c5221f5ce0af90979dba34e57;hp=a9660d86cef558e313b2f0fbfae23c2f759883e3;hpb=c53b9ea5e995de0388c4e1973b1929626fdc29a6;p=freeside.git diff --git a/FS/FS/cust_location.pm b/FS/FS/cust_location.pm index a9660d86c..fee77a8b1 100644 --- a/FS/FS/cust_location.pm +++ b/FS/FS/cust_location.pm @@ -518,17 +518,51 @@ sub disable_if_unused { } -=item move_to +=item move_pkgs + +Returns array of cust_pkg objects that would have their location +updated by L (all packages that have this location as +their service address, and aren't canceled, and aren't supplemental +to another package, and aren't one-time charges that have already been charged.) + +=cut + +sub move_pkgs { + my $self = shift; + my @pkgs = (); + # find all packages that have the old location as their service address, + # and aren't canceled, + # and aren't supplemental to another package + # and aren't one-time charges that have already been charged + foreach my $cust_pkg ( + qsearch('cust_pkg', { + 'locationnum' => $self->locationnum, + 'cancel' => '', + 'main_pkgnum' => '', + }) + ) { + next if $cust_pkg->part_pkg->freq eq '0' + and ($cust_pkg->setup || 0) > 0; + push @pkgs, $cust_pkg; + } + return @pkgs; +} + +=item move_to NEW [ move_pkgs => \@move_pkgs ] Takes a new L object. Moves all packages that use the existing location to the new one, then sets the "disabled" flag on the old location. Returns nothing on success, an error message on error. +Use option I to override the list of packages to update +(see L.) + =cut sub move_to { my $old = shift; my $new = shift; + my %opt = @_; warn "move_to:\nFROM:".Dumper($old)."\nTO:".Dumper($new) if $DEBUG; @@ -560,19 +594,32 @@ sub move_to { return ''; } - # find all packages that have the old location as their service address, - # and aren't canceled, - # and aren't supplemental to another package. - my @pkgs = qsearch('cust_pkg', { - 'locationnum' => $old->locationnum, - 'cancel' => '', - 'main_pkgnum' => '', - }); - foreach my $cust_pkg (@pkgs) { - # don't move one-time charges that have already been charged - next if $cust_pkg->part_pkg->freq eq '0' - and ($cust_pkg->setup || 0) > 0; + my @pkgs; + if ($opt{'move_pkgs'}) { + @pkgs = @{$opt{'move_pkgs'}}; + my $pkgerr; + foreach my $pkg (@pkgs) { + my $pkgnum = $pkg->pkgnum; + $pkgerr = "cust_pkg $pkgnum has already been charged" + if $pkg->part_pkg->freq eq '0' + and ($pkg->setup || 0) > 0; + $pkgerr = "cust_pkg $pkgnum is supplemental" + if $pkg->main_pkgnum; + $pkgerr = "cust_pkg $pkgnum already cancelled" + if $pkg->cancel; + $pkgerr = "cust_pkg $pkgnum does not use this location" + unless $pkg->locationnum eq $old->locationnum; + last if $pkgerr; + } + if ($pkgerr) { + $dbh->rollback if $oldAutoCommit; + return "Cannot update package location: $pkgerr"; + } + } else { + @pkgs = $old->move_pkgs; + } + foreach my $cust_pkg (@pkgs) { $error = $cust_pkg->change( 'locationnum' => $new->locationnum, 'keep_dates' => 1 @@ -937,7 +984,7 @@ sub _upgrade_data { next if $field eq 'disabled'; foreach my $location (qsearch({ table => 'cust_location', - extra_sql => " WHERE $field LIKE ' %' OR $field LIKE '% '" + extra_sql => " WHERE disabled IS NULL AND ($field LIKE ' %' OR $field LIKE '% ')" })) { my $error = $location->replace; die "$error (fixing whitespace in $field, locationnum ".$location->locationnum.')'