summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2014-09-06 14:47:01 -0700
committerIvan Kohler <ivan@freeside.biz>2014-09-06 14:47:01 -0700
commitac03ad840f625e48ed939ff93a28a12a9a78b1a5 (patch)
tree83760d527b4cd70855eaf2d3713be8aaecba7479
parentc51bb6288f574d5b71424880c2bae262564de8a5 (diff)
better error page when re-emailing bad addresses or other SMTP errorsm, RT#25834
-rw-r--r--httemplate/misc/send-invoice.cgi14
1 files changed, 11 insertions, 3 deletions
diff --git a/httemplate/misc/send-invoice.cgi b/httemplate/misc/send-invoice.cgi
index 08dd0e01c..dd9c3ade2 100644
--- a/httemplate/misc/send-invoice.cgi
+++ b/httemplate/misc/send-invoice.cgi
@@ -1,4 +1,8 @@
+% if ( $error ) {
+% errorpage($error);
+% } else {
<% $cgi->redirect("${p}view/cust_main.cgi?$custnum") %>
+% }
<%once>
my %method = ( map { $_=>1 } qw( email print fax_invoice ) );
@@ -26,9 +30,13 @@ my $cust_bill = qsearchs('cust_bill',{'invnum'=>$invnum});
die "Can't find invoice!\n" unless $cust_bill;
$cust_bill->set('mode' => $mode) if $mode;
-$cust_bill->$method({ 'template' => $template,
- 'notice_name' => $notice_name,
- });
+
+#these methods die instead of return errors, so, handle that without a backtrace
+eval { $cust_bill->$method({ 'template' => $template,
+ 'notice_name' => $notice_name,
+ });
+ };
+my $error = $@;
my $custnum = $cust_bill->getfield('custnum');