summaryrefslogtreecommitdiff
path: root/httemplate/edit/process/cust_pay.cgi
blob: 56d3f2ff1f550bd10f5a6eba49fe6088ce7c34eb (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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
%if ($error) {
%  $cgi->param('error', $error);
<% $cgi->redirect(popurl(2). 'cust_pay.cgi?'. $cgi->query_string ) %>
%} elsif ( $field eq 'invnum' ) {
<% $cgi->redirect(popurl(3). "view/cust_bill.cgi?$linknum") %>
%} elsif ( $field eq 'custnum' ) {
%  if ( $cgi->param('apply') eq 'yes' ) {
%    my $cust_main = qsearchs('cust_main', { 'custnum' => $linknum })
%      or die "unknown custnum $linknum";
%    $cust_main->apply_payments( 'manual' => 1,
%                                'backdate_application' => ($_date < time-86400) );
%  }
%  if ( $link eq 'popup' ) {
%    
<% header(emt('Payment entered')) %>
    <SCRIPT TYPE="text/javascript">
      window.top.location.reload();
    </SCRIPT>

    </BODY></HTML>
%
%  } elsif ( $link eq 'custnum' ) {
<% $cgi->redirect(popurl(3). "view/cust_main.cgi?$linknum") %>
%  } else {
%    die "unknown link $link";
%  }
%
%}
<%init>

my $conf = FS::Conf->new;

$cgi->param('linknum') =~ /^(\d+)$/
  or die "Illegal linknum: ". $cgi->param('linknum');
my $linknum = $1;

$cgi->param('link') =~ /^(custnum|invnum|popup)$/
  or die "Illegal link: ". $cgi->param('link');
my $field = my $link = $1;
$field = 'custnum' if $field eq 'popup';

my $_date;
if ( $FS::CurrentUser::CurrentUser->access_right('Backdate payment') ) {
  $_date = parse_datetime($cgi->param('_date'));
}
else {
  $_date = time;
}

my $new = new FS::cust_pay ( {
  $field => $linknum,
  _date  => $_date,
  no_auto_apply => ($cgi->param('apply') eq 'never') ? 'Y' : '',
  map {
    $_, scalar($cgi->param($_));
  } qw( paid payby payinfo paybatch
        pkgnum discount_term
        bank depositor account teller
      )
  #} fields('cust_pay')
  # gatewaynum, processor, auth, order_number
  # are for realtime payments only, and can't be entered manually
} );

my @rights = ('Post payment');
push @rights, 'Post check payment' if $new->payby eq 'BILL';
push @rights, 'Post cash payment'  if $new->payby eq 'CASH';

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right(\@rights);

my $error ||= $new->insert( 'manual' => 1 );

</%init>