4 use vars qw( $days_to_pay $cust_main $cust_pkg
11 use FS::Record qw(qsearch qsearchs);
12 use FS::UID qw(adminsuidsetup);
16 getopts('ed:qpsc', \%opt);
17 my $user = shift or die &usage;
22 my ($sec,$min,$hour,$mday,$mon,$year) =
23 (localtime($now) )[0,1,2,3,4,5];
27 foreach $cust_main ( qsearch('cust_main',{} ) ) {
29 my ( $eyear, $emon, $eday ) = ( 2037, 12, 31 );
30 if ( $cust_main->paydate =~ /^(\d{4})\-(\d{1,2})\-(\d{1,2})$/
31 && $cust_main->payby eq 'BILL') {
32 ( $eyear, $emon, $eday ) = ( $1, $2, $3 );
36 && $cust_main->balance_date(time - $opt{d} * 86400) > 0
37 && qsearchs( 'cust_pkg', { 'custnum' => $cust_main->custnum,
40 && $cust_main->payby eq 'BILL'
42 || ( $eyear == $year && $emon < $mon ) ) )
46 print $cust_main->custnum, "\t",
47 $cust_main->last, "\t", $cust_main->first, "\t",
48 $cust_main->balance_date(time-$opt{d} * 86400);
51 foreach $cust_pkg ( qsearch( 'cust_pkg',
52 { 'custnum' => $cust_main->custnum } ) ) {
54 if ($opt{p} && ! grep { $_ eq 'POST' } $cust_main->invoicing_list ) {
55 print "\n\tAdding postal invoicing" unless $opt{q};
56 my @invoicing_list = $cust_main->invoicing_list;
57 push @invoicing_list, 'POST';
58 $cust_main->invoicing_list(\@invoicing_list);
62 print "\n\tSuspending pkgnum " . $cust_pkg->pkgnum unless $opt{q};
67 print "\n\tCancelling pkgnum " . $cust_pkg->pkgnum unless $opt{q};
73 print "\n" unless $opt{q};
80 foreach $_ ( $[ .. $#ARGV ) {
81 $ARGV[$_] =~ /^([\w\-\/]*)$/ || die "Illegal arguement \"$ARGV[$_]\"";
87 die "Usage:\n\n freeside-overdue [ -e ] [ -d days ] [ -q ] [ -p ] [ -s ] [ -c ] user\n";
93 freeside-overdue - Perform actions on overdue and/or expired accounts.
97 freeside-overdue [ -e ] [ -d days ] [ -q ] [ -p ] [ -s ] [ -c ] user
101 Performs actions on overdue and/or expired accounts.
103 Selection options (at least one selection option is required):
105 -d: Customers with a balance due on invoices older than the supplied number
106 of days. Requires an integer argument.
108 -e: Customers with a billing expiration date in the past.
112 -q: Be quiet (by default, suspended accounts are printed).
114 -p: Add postal invoicing to the relevant customers.
116 -s: Suspend accounts.
120 user: From the mapsecrets file - see config.html from the base documentation
124 Example crontab entries:
126 20 4 * * * freeside-overdue -e -s user
127 20 4 * * * freeside-overdue -d 30 -p -q user
128 20 4 * * * freeside-overdue -d 60 user
129 20 4 * * * freeside-overdue -d 90 -s user
130 20 4 * * * freeside-overdue -d 120 -c user
132 =head1 ORIGINAL AUTHORS
134 Original disable-overdue version by mw/kwh: Mark W.? and Kristian Hoffmann ?