diff options
author | Ivan Kohler <ivan@freeside.biz> | 2014-09-06 14:47:01 -0700 |
---|---|---|
committer | Ivan Kohler <ivan@freeside.biz> | 2014-09-06 14:47:01 -0700 |
commit | ac03ad840f625e48ed939ff93a28a12a9a78b1a5 (patch) | |
tree | 83760d527b4cd70855eaf2d3713be8aaecba7479 /httemplate/misc/send-invoice.cgi | |
parent | c51bb6288f574d5b71424880c2bae262564de8a5 (diff) |
better error page when re-emailing bad addresses or other SMTP errorsm, RT#25834
Diffstat (limited to 'httemplate/misc/send-invoice.cgi')
-rw-r--r-- | httemplate/misc/send-invoice.cgi | 14 |
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'); |