diff options
author | jayce <jayce> | 2007-02-16 19:46:04 +0000 |
---|---|---|
committer | jayce <jayce> | 2007-02-16 19:46:04 +0000 |
commit | 0dbc5284b650523d7bf299fa86279b21b0325a9d (patch) | |
tree | 0a8943fba00cc21abb23d305e2604a2dc549494e | |
parent | 2d83c78cd946db628047078ad796e5fddcc3b596 (diff) |
Added a new Plan type, base_rate, which uses the cust_pkg->options to control pricing.
You assign a base rate for charging, and it is multiplied by the 'units' ordered. Solves a need where a company wants to offer an ASP style service, that charges per user, at a base cost, but doesn't want a plan for every combination of user amounts.
-rw-r--r-- | FS/FS/part_pkg/base_rate.pm | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/FS/FS/part_pkg/base_rate.pm b/FS/FS/part_pkg/base_rate.pm new file mode 100644 index 000000000..9e64184ab --- /dev/null +++ b/FS/FS/part_pkg/base_rate.pm @@ -0,0 +1,102 @@ +package FS::part_pkg::base_rate; + +use strict; +use vars qw(@ISA %info); +#use FS::Record qw(qsearch); +use FS::part_pkg; + +@ISA = qw(FS::part_pkg); + +%info = ( + 'name' => 'Base rate (anniversary billing, Times units ordered)', + 'fields' => { + 'setup_fee' => { 'name' => 'Setup fee for this package', + 'default' => 0, + }, + 'recur_fee' => { 'name' => 'Recurring Base fee for this package', + 'default' => 0, + }, + 'unused_credit' => { 'name' => 'Credit the customer for the unused portion'. + ' of service at cancellation', + 'type' => 'checkbox', + }, + 'externalid' => { 'name' => 'Optional External ID', + 'default' => '', + }, + }, + 'fieldorder' => [ 'setup_fee', 'recur_fee', 'unused_credit', + 'externalid' ], + 'weight' => 10, +); + +sub calc_setup { + my($self, $cust_pkg, $sdate, $details ) = @_; + + my $i = 0; + my $count = $self->option( 'additional_count', 'quiet' ) || 0; + while ($i < $count) { + push @$details, $self->option( 'additional_info' . $i++ ); + } + + $self->option('setup_fee'); +} + +sub calc_recur { + my($self, $cust_pkg) = @_; + $self->reset_usage($cust_pkg); + $self->base_recur($cust_pkg); +} + +sub base_recur { + my($self, $cust_pkg) = @_; + my $units = $cust_pkg->option('units') ? $cust_pkg->option('units') : 1 ; + # default to 1 if not found + sprintf("%.2f", + ($self->option('recur_fee') * $units ) + ); +} + +sub calc_remain { + my ($self, $cust_pkg) = @_; + my $time = time; #should be able to pass this in for credit calculation + my $next_bill = $cust_pkg->getfield('bill') || 0; + my $last_bill = $cust_pkg->last_bill || 0; + return 0 if ! $self->base_recur + || ! $self->option('unused_credit', 1) + || ! $last_bill + || ! $next_bill + || $next_bill < $time; + + my %sec = ( + 'h' => 3600, # 60 * 60 + 'd' => 86400, # 60 * 60 * 24 + 'w' => 604800, # 60 * 60 * 24 * 7 + 'm' => 2629744, # 60 * 60 * 24 * 365.2422 / 12 + ); + + $self->freq =~ /^(\d+)([hdwm]?)$/ + or die 'unparsable frequency: '. $self->freq; + my $freq_sec = $1 * $sec{$2||'m'}; + return 0 unless $freq_sec; + + sprintf("%.2f", $self->base_recur * ( $next_bill - $time ) / $freq_sec ); + +} + +sub is_free_options { + qw( setup_fee recur_fee ); +} + +sub is_prepaid { + 0; #no, we're postpaid +} + +sub reset_usage { + my($self, $cust_pkg) = @_; + my %values = map { $_, $self->option($_) } + grep { $self->option($_, 'hush') } + qw(seconds upbytes downbytes totalbytes); + $cust_pkg->set_usage(\%values); +} + +1; |