more RT integration / reskin / 2.1, RT#6640
[freeside.git] / httemplate / misc / cust_main-cancel.cgi
1 <% header("Customer cancelled") %>
2   <SCRIPT TYPE="text/javascript">
3     window.top.location.reload();
4   </SCRIPT>
5   </BODY>
6 </HTML>
7 <%init>
8
9 die "access denied"
10   unless $FS::CurrentUser::CurrentUser->access_right('Cancel customer');
11
12 my $custnum;
13 my $ban = '';
14 if ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
15   $custnum = $1;
16   $ban = $cgi->param('ban');
17 } else {
18   my($query) = $cgi->keywords;
19   $query =~ /^(\d+)$/ || die "Illegal custnum";
20   $custnum = $1;
21 }
22
23 #false laziness w/process/cancel_pkg.html
24
25 #untaint reasonnum
26 my $reasonnum = $cgi->param('reasonnum');
27 $reasonnum =~ /^(-?\d+)$/ || die "Illegal reasonnum";
28 $reasonnum = $1;
29
30 if ($reasonnum == -1) {
31   $reasonnum = {
32     'typenum' => scalar( $cgi->param('newreasonnumT') ),
33     'reason'  => scalar( $cgi->param('newreasonnum' ) ),
34   };
35 }
36
37 #eslaf
38
39 my $cust_main = qsearchs( {
40   'table'     => 'cust_main',
41   'hashref'   => { 'custnum' => $custnum },
42   'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
43 } );
44
45 warn "cancelling $cust_main";
46 my @errors = $cust_main->cancel(
47   'ban'    => $ban,
48   'reason' => $reasonnum,
49 );
50 my $error = join(' / ', @errors) if scalar(@errors);
51
52 if ( $error ) {
53   $cgi->param('error', $error);
54   print $cgi->redirect(popurl(1). "cancel_cust.html?". $cgi->query_string );
55 }
56
57 </%init>