summaryrefslogtreecommitdiff
path: root/FS
diff options
context:
space:
mode:
authorivan <ivan>2003-05-19 13:38:41 +0000
committerivan <ivan>2003-05-19 13:38:41 +0000
commita1295d0682aa81a408abe06fcaa7c14440f6a2e2 (patch)
tree0ede9fe45caf553f5258ba36bd4535acad8db5f4 /FS
parentfd9138f66cf7f3ab9557e0beebb4e2657a59e34c (diff)
first crack at payment processing with self-service (step two of the process)
Diffstat (limited to 'FS')
-rw-r--r--FS/FS/ClientAPI/MyAccount.pm23
-rw-r--r--FS/FS/cust_main.pm13
2 files changed, 34 insertions, 2 deletions
diff --git a/FS/FS/ClientAPI/MyAccount.pm b/FS/FS/ClientAPI/MyAccount.pm
index a64cfb5d7..2ce55a8e7 100644
--- a/FS/FS/ClientAPI/MyAccount.pm
+++ b/FS/FS/ClientAPI/MyAccount.pm
@@ -185,7 +185,30 @@ sub make_payment{
my $custnum = $session->{'custnum'};
+ my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
+ or return { 'error' => "unknown custnum $custnum" };
+
+ if ( $p->{'save'} ) {
+ my $new = new FS::cust_main { $cust_main->hash };
+ $new->set( $_ => $p->{$_} )
+ foreach qw( payname address1 address2 city state zip payinfo );
+ $new->set( 'paydate' => $p->{'month'}. '-'. $p->{'year'} );
+ $new->set( 'payby' => $p->{'auto'} ? 'CARD' : 'DCRD' );
+ my $error = $new->replace($cust_main);
+ return { 'error' => $error } if $error;
+ $cust_main = $new;
+ }
+
+ my $error = $cust_main->realtime_bop( 'CC', $p->{'amount'}, quiet=>1,
+ 'paydate' => $p->{'month'}. '-'. $p->{'year'},
+ map { $_ => $p->{$_} }
+ qw( payname address1 address2 city state zip payinfo )
+ );
+ return { 'error' => $error } if $error;
+
+ $cust_main->apply_payments;
+ return { 'error' => '' };
}
diff --git a/FS/FS/cust_main.pm b/FS/FS/cust_main.pm
index b162622a4..09c56474c 100644
--- a/FS/FS/cust_main.pm
+++ b/FS/FS/cust_main.pm
@@ -1411,7 +1411,6 @@ sub collect {
=item realtime_bop METHOD AMOUNT [ OPTION => VALUE ... ]
-
Runs a realtime credit card, ACH (electronic check) or phone bill transaction
via a Business::OnlinePayment realtime gateway. See
L<http://420.am/business-onlinepayment> for supported gateways.
@@ -1420,6 +1419,10 @@ Available methods are: I<CC>, I<ECHECK> and I<LEC>
Available options are: I<description>, I<invnum>, I<quiet>
+The additional options I<payname>, I<address1>, I<address2>, I<city>, I<state>,
+I<zip>, I<payinfo> and I<paydate> are also available. Any of these options,
+if set, will override the value from the customer record.
+
I<description> is a free-text field passed to the gateway. It defaults to
"Internet services".
@@ -1443,6 +1446,11 @@ sub realtime_bop {
eval "use Business::OnlinePayment";
die $@ if $@;
+ #overrides
+ $self->set( $_ => $options{$_} )
+ foreach grep { exists($options{$_}) }
+ qw( payname address1 address2 city state zip payinfo paydate );
+
#load up config
my $bop_config = 'business-onlinepayment';
$bop_config .= '-ach'
@@ -1571,7 +1579,8 @@ sub realtime_bop {
);
my $cust_pay = new FS::cust_pay ( {
- 'invnum' => $self->invnum, #!!!!!!!!
+ 'custnum' => $self->custnum,
+ 'invnum' => $options{'invnum'},
'paid' => $amount,
'_date' => '',
'payby' => $method2payby{$method},