1 <& /elements/header-popup.html, mt("Customer cancelled") &>
2 <script src="<% $fsurl %>elements/js.cookie.js"></script>
3 <SCRIPT TYPE="text/javascript">
4 Cookies.set('freeside_status', <% mt("Customer cancelled") |js_string %>,{
14 unless $FS::CurrentUser::CurrentUser->access_right('Cancel customer');
19 if ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
21 $ban = $cgi->param('ban');
22 $expire = $cgi->param('expire');
24 my($query) = $cgi->keywords;
25 $query =~ /^(\d+)$/ || die "Illegal custnum";
30 #untaint reasonnum / create new reason
31 my ($reasonnum, $error) = $m->comp('process/elements/reason');
33 $error ||= 'Reason required'
36 my $cust_main = qsearchs( {
37 'table' => 'cust_main',
38 'hashref' => { 'custnum' => $custnum },
39 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
44 } elsif ( $cgi->param('now_or_later') ) {
45 $expire = parse_datetime($expire);
47 #warn "setting expire dates on custnum#$custnum\n";
48 my @pkgs = $cust_main->ncancelled_pkgs;
49 my @errors = grep {$_} map { $_->cancel(
50 'reason' => $reasonnum,
53 $error = join(' / ', @errors);
56 $error = ("error parsing expire date: ".$cgi->param('expire'));
60 warn "cancelling $cust_main";
61 my @error = $cust_main->cancel( #returns list of errors
63 'reason' => $reasonnum,
65 $error = join(', ',@error);
69 $cgi->param('error', $error);
70 print $cgi->redirect(popurl(1). "cancel_cust.html?". $cgi->query_string );