<% my $dbh = dbh; #untaint svcnum my($query) = $cgi->keywords; $query =~ /^(\d+)$/; my $svcnum = $1; #my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$svcnum}); #die "Unknown svcnum!" unless $svc_acct; my $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum}); die "Unknown svcnum!" unless $cust_svc; &eidiot(qq!This account has already been audited. Cancel the package instead.!) if $cust_svc->pkgnum ne '' && $cust_svc->pkgnum ne '0'; my $svc_x = $cust_svc->svc_x; local $SIG{HUP} = 'IGNORE'; local $SIG{INT} = 'IGNORE'; local $SIG{QUIT} = 'IGNORE'; local $SIG{TERM} = 'IGNORE'; local $SIG{TSTP} = 'IGNORE'; local $FS::UID::AutoCommit = 0; my $error = $svc_x->cancel; $error ||= $svc_x->delete; $error ||= $cust_svc->delete; if ( $error ) { $dbh->rollback; %> <% &eidiot($error); } else { $dbh->commit or die $dbh->errstr; print $cgi->redirect(popurl(2)); } %>