diff options
| author | ivan <ivan> | 2002-12-22 08:53:25 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2002-12-22 08:53:25 +0000 | 
| commit | 1a7b34a94745208217187050c1daec5bb31b7eb7 (patch) | |
| tree | ffef7cd66f767ec8597b129826fab4dc7227738f | |
| parent | b3cf415f88878300916d3e85910693b7315ef7b3 (diff) | |
-p option for freeside-daily to only run for a particular payby
$disable_agentcheck option for cust_pkg for import optimization
| -rw-r--r-- | FS/FS/cust_pkg.pm | 15 | ||||
| -rwxr-xr-x | FS/bin/freeside-daily | 15 | 
2 files changed, 21 insertions, 9 deletions
| diff --git a/FS/FS/cust_pkg.pm b/FS/FS/cust_pkg.pm index e83b95156..c15e2fe9d 100644 --- a/FS/FS/cust_pkg.pm +++ b/FS/FS/cust_pkg.pm @@ -1,7 +1,7 @@  package FS::cust_pkg;  use strict; -use vars qw(@ISA); +use vars qw(@ISA $disable_agentcheck);  use FS::UID qw( getotaker dbh );  use FS::Record qw( qsearch qsearchs );  use FS::cust_svc; @@ -21,6 +21,8 @@ use FS::svc_forward;  @ISA = qw( FS::Record ); +$disable_agentcheck = 0; +  sub _cache {    my $self = shift;    my ( $hashref, $cache ) = @_; @@ -142,10 +144,13 @@ sub insert {    my $cust_main = $self->cust_main;    return "Unknown customer ". $self->custnum unless $cust_main; -  my $agent = qsearchs( 'agent', { 'agentnum' => $cust_main->agentnum } ); -  my $pkgpart_href = $agent->pkgpart_hashref; -  return "agent ". $agent->agentnum. " can't purchase pkgpart ". $self->pkgpart -    unless $pkgpart_href->{ $self->pkgpart }; +  unless ( $disable_agentcheck ) { +    my $agent = qsearchs( 'agent', { 'agentnum' => $cust_main->agentnum } ); +    my $pkgpart_href = $agent->pkgpart_hashref; +    return "agent ". $agent->agentnum. +           " can't purchase pkgpart ". $self->pkgpart +      unless $pkgpart_href->{ $self->pkgpart }; +  }    $self->SUPER::insert; diff --git a/FS/bin/freeside-daily b/FS/bin/freeside-daily index 1db786120..c82dc07a0 100755 --- a/FS/bin/freeside-daily +++ b/FS/bin/freeside-daily @@ -11,16 +11,19 @@ use FS::cust_main;  &untaint_argv;	#what it sounds like  (eww)  use vars qw($opt_d $opt_v); -getopts("d:v"); +getopts("p:d:v");  my $user = shift or die &usage;  adminsuidsetup $user;  $FS::cust_main::Debug = 1 if $opt_v; +my %search; +$search{'payby'} = $opt_p if $opt_p; +  my @cust_main = @ARGV -  ? map { qsearchs('cust_main', { custnum => $_ } ) } @ARGV -  : qsearch('cust_main', {} ) +  ? map { qsearchs('cust_main', { custnum => $_, %search } ) } @ARGV +  : qsearch('cust_main', \%search )  ;  #we're at now now (and later). @@ -95,7 +98,7 @@ freeside-daily - Run daily billing and invoice collection events.  =head1 SYNOPSIS -  freeside-daily [ -d 'date' ] user [ custnum custnum ... ] +  freeside-daily [ -d 'date' ] [ -p 'payby' ] [ -v ] user [ custnum custnum ... ]  =head1 DESCRIPTION @@ -110,6 +113,10 @@ the bill and collect methods of a cust_main object.  See L<FS::cust_main>.    -d: Pretend it's 'date'.  Date is in any format Date::Parse is happy with,        but be careful. +  -p: Only process customers with the specified payby (CARD, CHEK, BILL, COMP, LECB) + +  -v: enable debugging +  user: From the mapsecrets file - see config.html from the base documentation  custnum: if one or more customer numbers are specified, only bills those | 
