[freeside-commits] freeside/FS/FS/Cron backup.pm, NONE,
1.1 vacuum.pm, NONE, 1.1 bill.pm, NONE, 1.1
Ivan,,,
ivan at wavetail.420.am
Wed Feb 1 15:13:50 PST 2006
- Previous message: [freeside-commits] freeside/FS/bin freeside-daily, 1.21,
1.22 freeside-monthly, NONE, 1.1
- Next message: [freeside-commits] freeside/FS/t Cron-backup.t, NONE,
1.1 Cron-bill.t, NONE, 1.1 Cron-vacuum.t, NONE, 1.1
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/cvsroot/freeside/FS/FS/Cron
In directory wavetail:/tmp/cvs-serv19329/FS/FS/Cron
Added Files:
backup.pm vacuum.pm bill.pm
Log Message:
finish adding freeside-monthly and monthly events
--- NEW FILE: bill.pm ---
package FS::Cron::bill;
use strict;
use vars qw( @ISA @EXPORT_OK );
use Exporter;
use Date::Parse;
use FS::Record qw(qsearch qsearchs);
use FS::cust_main;
@ISA = qw( Exporter );
@EXPORT_OK = qw ( bill );
sub bill {
my %opt = @_;
$FS::cust_main::DEBUG = 1 if $opt{'v'};
my %search = ();
$search{'payby'} = $opt{'p'} if $opt{'p'};
$search{'agentnum'} = $opt{'a'} if $opt{'a'};
#we're at now now (and later).
my($time)= $opt{'d'} ? str2time($opt{'d'}) : $^T;
$time += $opt{'y'} * 86400 if $opt{'y'};
# select * from cust_main where
my $where_pkg = <<"END";
0 < ( select count(*) from cust_pkg
where cust_main.custnum = cust_pkg.custnum
and ( cancel is null or cancel = 0 )
and ( setup is null or setup = 0
or bill is null or bill <= $time
or ( expire is not null and expire <= $^T )
)
)
END
# or
my $where_bill_event = <<"END";
0 < ( select count(*) from cust_bill
where cust_main.custnum = cust_bill.custnum
and 0 < charged
- coalesce(
( select sum(amount) from cust_bill_pay
where cust_bill.invnum = cust_bill_pay.invnum )
,0
)
- coalesce(
( select sum(amount) from cust_credit_bill
where cust_bill.invnum = cust_credit_bill.invnum )
,0
)
and 0 < ( select count(*) from part_bill_event
where payby = cust_main.payby
and ( disabled is null or disabled = '' )
and seconds <= $time - cust_bill._date
and 0 = ( select count(*) from cust_bill_event
where cust_bill.invnum = cust_bill_event.invnum
and part_bill_event.eventpart = cust_bill_event.eventpart
and status = 'done'
)
)
)
END
my $extra_sql = ( scalar(%search) ? ' AND ' : ' WHERE ' ). "( $where_pkg OR $where_bill_event )";
my @cust_main;
if ( @ARGV ) {
@cust_main = map { qsearchs('cust_main', { custnum => $_, %search } ) } @ARGV
} else {
@cust_main = qsearch('cust_main', \%search, '', $extra_sql );
}
;
my($cust_main,%saw);
foreach $cust_main ( @cust_main ) {
# $^T not $time because -d is for pre-printing invoices
foreach my $cust_pkg (
grep { $_->expire && $_->expire <= $^T } $cust_main->ncancelled_pkgs
) {
my $error = $cust_pkg->cancel;
warn "Error cancelling expired pkg ". $cust_pkg->pkgnum. " for custnum ".
$cust_main->custnum. ": $error"
if $error;
}
# $^T not $time because -d is for pre-printing invoices
foreach my $cust_pkg (
grep { $_->part_pkg->is_prepaid
&& $_->bill && $_->bill < $^T && ! $_->susp
}
$cust_main->ncancelled_pkgs
) {
my $error = $cust_pkg->suspend;
warn "Error suspending package ". $cust_pkg->pkgnum.
" for custnum ". $cust_main->custnum.
": $error"
if $error;
}
my $error = $cust_main->bill( 'time' => $time,
'resetup' => $opt{'s'},
);
warn "Error billing, custnum ". $cust_main->custnum. ": $error" if $error;
$cust_main->apply_payments;
$cust_main->apply_credits;
$error = $cust_main->collect( 'invoice_time' => $time,
'freq' => $opt{'freq'},
);
warn "Error collecting, custnum". $cust_main->custnum. ": $error" if $error;
}
}
--- NEW FILE: backup.pm ---
package FS::Cron::backup;
use strict;
use vars qw( @ISA @EXPORT_OK );
use Exporter;
use FS::UID qw(driver_name datasrc);
@ISA = qw( Exporter );
@EXPORT_OK = qw( backup_scp );
sub backup_scp {
my $conf = new FS::Conf;
my $dest = $conf->config('dump-scpdest');
if ( $dest ) {
datasrc =~ /dbname=([\w\.]+)$/ or die "unparsable datasrc ". datasrc;
my $database = $1;
eval "use Net::SCP qw(scp);";
die $@ if $@;
if ( driver_name eq 'Pg' ) {
system("pg_dump $database >/var/tmp/$database.sql")
} else {
die "database dumps not yet supported for ". driver_name;
}
if ( $conf->config('dump-pgpid') ) {
eval 'use GnuPG;';
die $@ if $@;
my $gpg = new GnuPG;
$gpg->encrypt( plaintext => "/var/tmp/$database.sql",
output => "/var/tmp/$database.gpg",
recipient => $conf->config('dump-pgpid'),
);
chmod 0600, '/var/tmp/$database.gpg';
scp("/var/tmp/$database.gpg", $dest);
unlink "/var/tmp/$database.gpg" or die $!;
} else {
chmod 0600, '/var/tmp/$database.sql';
scp("/var/tmp/$database.sql", $dest);
}
unlink "/var/tmp/$database.sql" or die $!;
}
}
1;
--- NEW FILE: vacuum.pm ---
package FS::Cron::vacuum;
use vars qw( @ISA @EXPORT_OK);
use Exporter;
use FS::UID qw(driver_name dbh);
use FS::Schema qw(dbdef);
@ISA = qw( Exporter );
@EXPORT_OK = qw( vacuum );
sub vacuum {
if ( driver_name eq 'Pg' ) {
dbh->{AutoCommit} = 1; #so we can vacuum
foreach my $table ( dbdef->tables ) {
my $sth = dbh->prepare("VACUUM ANALYZE $table") or die dbh->errstr;
$sth->execute or die $sth->errstr;
}
}
}
1;
- Previous message: [freeside-commits] freeside/FS/bin freeside-daily, 1.21,
1.22 freeside-monthly, NONE, 1.1
- Next message: [freeside-commits] freeside/FS/t Cron-backup.t, NONE,
1.1 Cron-bill.t, NONE, 1.1 Cron-vacuum.t, NONE, 1.1
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the freeside-commits
mailing list