summaryrefslogtreecommitdiff
path: root/FS
diff options
context:
space:
mode:
authorMark Wells <mark@freeside.biz>2015-02-27 12:12:59 -0800
committerMark Wells <mark@freeside.biz>2015-02-27 12:12:59 -0800
commitca9f1e88e00736efff1deff396d25165e67094cd (patch)
tree7887e3a50edf6ab875f18287ba95759ad1753426 /FS
parent5393c4b8db83bb2196336b9e919e8ec1dc609aa8 (diff)
change part_pkg_link cleanup to be smarter about its cancel reason, #33245
Diffstat (limited to 'FS')
-rw-r--r--FS/FS/part_pkg_link.pm30
1 files changed, 13 insertions, 17 deletions
diff --git a/FS/FS/part_pkg_link.pm b/FS/FS/part_pkg_link.pm
index aee0131d2..8e43d155e 100644
--- a/FS/FS/part_pkg_link.pm
+++ b/FS/FS/part_pkg_link.pm
@@ -170,6 +170,14 @@ sub delete {
return;
}
+=item remove_linked
+
+Removes any supplemental packages that were created by this link, by canceling
+them and setting their pkglinknum to null. This should be done in preparation
+for removing the link itself.
+
+=cut
+
sub remove_linked {
my $self = shift;
my $pkglinknum = $self->pkglinknum;
@@ -180,23 +188,11 @@ sub remove_linked {
warn "expiring ".scalar(@pkgs).
" linked packages from part_pkg_link #$pkglinknum\n";
- my $reason = qsearchs('reason', { reason => $cancel_reason_text });
- if (!$reason) {
- # upgrade/FS::Setup created this one automatically
- my $reason_type = qsearchs('reason_type',
- { type => $cancel_reason_type }
- ) or die "default cancel reason type does not exist";
-
- $reason = FS::reason->new({
- reason_type => $reason_type->typenum,
- reason => $cancel_reason_text,
- disabled => 'Y',
- });
- $error = $reason->insert;
- if ( $error ) {
- return "$error (creating package cancel reason)";
- }
- }
+ my $reason = FS::reason->new_or_existing(
+ class => 'C',
+ type => $cancel_reason_type,
+ reason => $cancel_reason_text
+ );
foreach my $pkg (@pkgs) {
$pkg->set('pkglinknum' => '');