1 package FS::part_pkg::recur_Common;
4 use vars qw( @ISA %recur_method );
7 use FS::part_pkg::prorate;
9 @ISA = qw(FS::part_pkg::prorate);
11 tie %recur_method, 'Tie::IxHash',
12 'anniversary' => 'Charge the recurring fee at the frequency specified above',
13 'prorate' => 'Charge a prorated fee the first time (selectable billing date)',
14 'subscription' => 'Charge the full fee for the first partial period (selectable billing date)',
17 sub calc_recur_Common {
19 my($cust_pkg, $sdate, $details, $param ) = @_; #only need $sdate & $param
23 if ( $param->{'increment_next_bill'} ) {
25 my $recur_method = $self->option('recur_method', 1) || 'anniversary';
27 if ( $recur_method eq 'prorate' ) {
29 $charges = $self->SUPER::calc_recur(@_);
33 $charges = $self->option('recur_fee');
35 if ( $recur_method eq 'subscription' ) {
37 my $cutoff_day = $self->option('cutoff_day', 1) || 1;
38 my ($day, $mon, $year) = ( localtime($$sdate) )[ 3..5 ];
40 if ( $day < $cutoff_day ) {
41 if ( $mon == 0 ) { $mon=11; $year--; }
45 $$sdate = timelocal(0, 0, 0, $cutoff_day, $mon, $year);
47 }#$recur_method eq 'subscription'
49 }#$recur_method eq 'prorate'