From 1b8a2cc3b3697f3921e26a31691acfabacc1efd6 Mon Sep 17 00:00:00 2001 From: ivan Date: Fri, 17 Jul 2009 22:26:38 +0000 Subject: [PATCH] commit pkgpart exclusion for billing run, RT#5495 --- FS/FS/Cron/bill.pm | 7 +++++++ FS/FS/cust_main.pm | 15 +++++++++++++-- FS/bin/freeside-daily | 10 +++++++--- 3 files changed, 27 insertions(+), 5 deletions(-) diff --git a/FS/FS/Cron/bill.pm b/FS/FS/Cron/bill.pm index 61b47355a..1feba7948 100644 --- a/FS/FS/Cron/bill.pm +++ b/FS/FS/Cron/bill.pm @@ -21,6 +21,7 @@ use FS::part_event_condition; # -l: debugging level # -m: Experimental multi-process mode uses the job queue for multi-process and/or multi-machine billing. # -r: Multi-process mode dry run option +# -g: Don't bill these pkgparts sub bill { my %opt = @_; @@ -39,6 +40,9 @@ sub bill { $opt{'invoice_time'} = $opt{'n'} ? $^T : $opt{'time'}; + my $not_pkgpart = $opt{g} ? { map { $_=>1 } split(/,\s*/, $opt{g}) } + : {}; + ### # get a list of custnums ### @@ -74,6 +78,7 @@ sub bill { #(not, when using -m, freeside-queued) 'check_freq' => $check_freq, 'resetup' => ( $opt{'s'} ? $opt{'s'} : 0 ), + 'not_pkgpart' => $not_pkgpart, ); if ( $opt{'m'} ) { @@ -152,6 +157,8 @@ sub bill_where { push @search, "cust_main.agentnum = ". $opt{'a'} if $opt{'a'}; + #it would be useful if i recognized $opt{g} / $not_pkgpart... + if ( @ARGV ) { push @search, "( ". join(' OR ', map "cust_main.custnum = $_", @ARGV ). diff --git a/FS/FS/cust_main.pm b/FS/FS/cust_main.pm index 1f063d950..2957579d7 100644 --- a/FS/FS/cust_main.pm +++ b/FS/FS/cust_main.pm @@ -2331,6 +2331,9 @@ Debugging level. Default is 0 (no debugging), or can be set to 1 (passed-in opt =back +Options are passed to the B and B methods verbatim, so all +options of those methods are also available. + =cut sub bill_and_collect { @@ -2448,6 +2451,10 @@ An array ref of specific packages (objects) to attempt billing, instead trying a $cust_main->bill( pkg_list => [$pkg1, $pkg2] ); +=item not_pkgpart + +A hashref of pkgparts to exclude from this billing run. + =item invoice_time Used in conjunction with the I