diff options
Diffstat (limited to 'FS/bin')
| -rwxr-xr-x | FS/bin/freeside-bill | 6 | ||||
| -rwxr-xr-x | FS/bin/freeside-overdue | 85 | 
2 files changed, 65 insertions, 26 deletions
| diff --git a/FS/bin/freeside-bill b/FS/bin/freeside-bill index 7898936c5..49ec43c82 100755 --- a/FS/bin/freeside-bill +++ b/FS/bin/freeside-bill @@ -59,14 +59,14 @@ foreach $cust_main (    if ($opt_p) {      $cust_main->apply_payments; -    $error=$cust_main->apply_credits; +    $cust_main->apply_credits;    }    if ($opt_c) {      $error=$cust_main->collect('invoice_time'=>$time,                                 'batch_card' => $opt_i ? 'no' : 'yes',                                ); -    warn "Error collecting from customer #" . $cust_main->gcustnum.  ":$error" +    warn "Error collecting from customer #" . $cust_main->custnum.  ":$error"        if $error;      #sleep 1; @@ -123,7 +123,7 @@ customers.  Otherwise, bills all customers.  =head1 VERSION -$Id: freeside-bill,v 1.10 2001-11-05 14:04:56 ivan Exp $ +$Id: freeside-bill,v 1.11 2001-12-28 14:40:35 ivan Exp $  =head1 BUGS diff --git a/FS/bin/freeside-overdue b/FS/bin/freeside-overdue index 0c62b99c1..8f7f872c8 100755 --- a/FS/bin/freeside-overdue +++ b/FS/bin/freeside-overdue @@ -1,4 +1,4 @@ -#!/usr/bin/perl +#!/usr/bin/perl -w  use strict;  use vars qw( $days_to_pay $cust_main $cust_pkg  @@ -13,12 +13,12 @@ use FS::UID qw(adminsuidsetup);  &untaint_argv;  my %opt; -getopts('ed:qplsc', \%opt); +getopts('ed:qplscbyoi', \%opt);  my $user = shift or die &usage;  adminsuidsetup $user; -my $now = time; +my $now = time; #eventually take a time option like freeside-bill  my ($sec,$min,$hour,$mday,$mon,$year) =    (localtime($now) )[0,1,2,3,4,5];  $mon++; @@ -48,21 +48,23 @@ foreach $cust_main ( qsearch('cust_main',{} ) ) {              $cust_main->balance_date(time-$opt{d} * 86400);      } -#    if ( $opt{l} ) { -#      print "\n\tCharging late fee of \$$opt{l}" unless $opt{q}; -# -#    } +    if ( $opt{p} && ! grep { $_ eq 'POST' } $cust_main->invoicing_list ) { +      print "\n\tAdding postal invoicing" unless $opt{q}; +      my @invoicing_list = $cust_main->invoicing_list; +      push @invoicing_list, 'POST'; +      $cust_main->invoicing_list(\@invoicing_list); +    } + +    if ( $opt{l} ) { +      print "\n\tCharging late fee of \$$opt{l}" unless $opt{q}; +      my $error = $cust_main->charge($opt{l}, 'Late fee'); +      # comment or plandata with info so we don't redo the same late fee every +      # day +    }      foreach $cust_pkg ( qsearch( 'cust_pkg',                                    { 'custnum' => $cust_main->custnum } ) ) { -      if ( $opt{p} && ! grep { $_ eq 'POST' } $cust_main->invoicing_list ) { -        print "\n\tAdding postal invoicing" unless $opt{q}; -        my @invoicing_list = $cust_main->invoicing_list; -        push @invoicing_list, 'POST'; -        $cust_main->invoicing_list(\@invoicing_list); -      } -        if ($opt{s}) {          print "\n\tSuspending pkgnum " . $cust_pkg->pkgnum unless $opt{q};          $cust_pkg->suspend; @@ -72,7 +74,29 @@ foreach $cust_main ( qsearch('cust_main',{} ) ) {          print "\n\tCancelling pkgnum " . $cust_pkg->pkgnum unless $opt{q};          $cust_pkg->cancel;        } +       +    } + +    if ( $opt{b} ) { +      print "\n\tBilling" unless $opt{q}; +      my $error = $cust_main->bill('time'=>$now); +      warn "Error billing,  customer #" . $cust_main->custnum .  +        ":" . $error if $error; +    } +    if ( $opt{y} ) { +      print "\n\tApplying outstanding payments and credits" unless $opt{q}; +      $cust_main->apply_payments; +      $cust_main->apply_credits; +    } + +    if ( $opt{o} ) { +      print "\n\tCollecting" unless $opt{q}; +      my $error = $cust_main->collect( 'invoice_time'=>$now, +                                       'batch_card' => $opt{i} ? 'no' : 'yes', +                                     ); +      warn "Error collecting from customer #" . $cust_main->custnum.  ":$error" +        if $error;      }      print "\n" unless $opt{q}; @@ -99,7 +123,7 @@ freeside-overdue - Perform actions on overdue and/or expired accounts.  =head1 SYNOPSIS -  freeside-overdue [ -e ] [ -d days ] [ -q ] [ -p ] [ -l amount ] [ -s ] [ -c ] user +  freeside-overdue [ -e ] [ -d days ] [ -q ] [ -p ] [ -l amount ] [ -s ] [ -c ] [ -b ] [ -y ] [ -o [ -i ] ] user  =head1 DESCRIPTION @@ -107,22 +131,31 @@ Performs actions on overdue and/or expired accounts.  Selection options (at least one selection option is required): -  -d:	Customers with a balance due on invoices older than the supplied number -        of days.  Requires an integer argument. +  -d:  Customers with a balance due on invoices older than the supplied number +       of days.  Requires an integer argument. -  -e:   Customers with a billing expiration date in the past. +  -e:  Customers with a billing expiration date in the past.  Action options:  -  -q:   Be quiet (by default, selected accounts are printed). +  -q:  Be quiet (by default, selected accounts are printed). + +  -p:  Add postal invoicing to the relevant customers. + +  -l:  Add a charge of the given amount to the relevant customers. + +  -s:  Suspend accounts. -  -p:   Add postal invoicing to the relevant customers. +  -c:  Cancel accounts. -  -l:   Add a charge of the given amount to the relevant customers. +  -b:  Bill customers (create invoices) -  -s:	Suspend accounts. +  -y:  Apply unapplied payments and credits -  -c:   Cancel accounts. +  -o:  Collect from customers (charge cards, print invoices) + +    -i:  real-time billing (as opposed to batch billing).  only relevant +         for credit cards.    user: From the mapsecrets file - see config.html from the base documentation @@ -146,6 +179,12 @@ Example crontab entries:  Original disable-overdue version by mw/kwh: Mark W.? and Kristian Hoffmann ? +Ivan seems to be turning it into the "do-everything" CLI. + +=head1 BUGS + +Hell now that this is the do-everything CLI it should have --longoptions +  =cut  1; | 
