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