diff options
Diffstat (limited to 'FS/FS/part_event/Action/suspend_unless_pkgpart.pm')
-rw-r--r-- | FS/FS/part_event/Action/suspend_unless_pkgpart.pm | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/FS/FS/part_event/Action/suspend_unless_pkgpart.pm b/FS/FS/part_event/Action/suspend_unless_pkgpart.pm new file mode 100644 index 0000000..efc7a2d --- /dev/null +++ b/FS/FS/part_event/Action/suspend_unless_pkgpart.pm @@ -0,0 +1,40 @@ +package FS::part_event::Action::suspend_unless_pkgpart; + +use strict; +use base qw( FS::part_event::Action ); + +sub description { 'Suspend packages except'; } + +#i should be deprecated in favor of using the unless_pkgpart condition + +sub option_fields { + ( + 'unless_pkgpart' => { 'label' => 'Suspend packages except:', + 'type' => 'select-part_pkg', + 'multiple' => 1, + }, + 'reasonnum' => { 'label' => 'Reason', + 'type' => 'select-reason', + 'reason_class' => 'S', + }, + ); +} + +sub default_weight { 10; } + +sub do_action { + my( $self, $cust_object ) = @_; + + my $cust_main = $self->cust_main($cust_object); + + my @err = $cust_main->suspend_unless_pkgpart( { + 'pkgparts' => [ split(/\s*,\s*/, $self->option('unless_pkgpart') ) ], + 'reason' => $self->option('reasonnum'), + } ); + + die join(' / ', @err) if scalar(@err); + + ''; +} + +1; |