blob: 0025b16b586730dd8831b67b6c9b8564ccfc6038 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<%
$cgi->param('paynum') =~ /^(\d*)$/ or die "Illegal paynum!";
my $paynum = $1;
my $cust_pay = qsearchs('cust_pay', { 'paynum' => $paynum } )
or die "No such paynum";
my $cust_main = qsearchs('cust_main', { 'custnum' => $cust_pay->custnum } )
or die "Bogus credit: not attached to customer";
my $custnum = $cust_main->custnum;
my $new;
if ($cgi->param('invnum') =~ /^Refund$/) {
$new = new FS::cust_refund ( {
'reason' => 'Refunding payment', #enter reason in UI
'refund' => $cgi->param('amount'),
'payby' => 'BILL',
#'_date' => $cgi->param('_date'),
'payinfo' => 'Cash', #enter payinfo in UI
'paynum' => $paynum,
} );
} else {
$new = new FS::cust_bill_pay ( {
map {
$_, scalar($cgi->param($_));
#} qw(custnum _date amount invnum)
} fields('cust_bill_pay')
} );
}
my $error = $new->insert;
if ( $error ) {
$cgi->param('error', $error);
print $cgi->redirect(popurl(2). "cust_bill_pay.cgi?". $cgi->query_string );
} else {
print $cgi->redirect(popurl(3). "view/cust_main.cgi?$custnum");
}
%>
|