IDEMPIERE-5284 Create method EMail.sendEx to have access to the full Exception when sending EMails (FHCA-3587) (#1316)

- improved also the dumpMessage, is just called when the level is finest, but it was logging on fine level, also the if must be out of the loop
This commit is contained in:
Carlos Ruiz 2022-05-06 11:57:09 +02:00 committed by GitHub
parent b6191ecee3
commit 35cda7ffe8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 4 deletions

View File

@ -110,7 +110,7 @@ public class EMailTest extends SvrProcess
if (! from.contains("@")) if (! from.contains("@"))
from = "test@" + from; from = "test@" + from;
email.setFrom(from); email.setFrom(from);
String msg = email.send(); String msg = email.sendEx();
if (EMail.SENT_OK.equals (msg)) if (EMail.SENT_OK.equals (msg))
{ {
if (log.isLoggable(Level.INFO)) log.info("Sent Test EMail to " + client.getRequestEMail()); if (log.isLoggable(Level.INFO)) log.info("Sent Test EMail to " + client.getRequestEMail());

View File

@ -248,6 +248,31 @@ public final class EMail implements Serializable
* @return OK or error message * @return OK or error message
*/ */
public String send() public String send()
{
String msg;
try {
msg = send(false);
} catch (Exception e) {
msg = e.getLocalizedMessage();
}
return msg;
}
/**
* Send Mail direct
* @return OK or error message
*/
public String sendEx() throws Exception
{
return send(true);
}
/**
* Send Mail direct
* @return OK or error message
* @throws Exception
*/
public String send(boolean throwException) throws Exception
{ {
if (!m_forceUseTenantSmtp && getFrom() != null) { if (!m_forceUseTenantSmtp && getFrom() != null) {
MSMTP smtp = MSMTP.get(m_ctx, Env.getAD_Client_ID(m_ctx), getFrom().getAddress()); MSMTP smtp = MSMTP.get(m_ctx, Env.getAD_Client_ID(m_ctx), getFrom().getAddress());
@ -325,6 +350,8 @@ public final class EMail implements Serializable
} }
catch (SecurityException se) catch (SecurityException se)
{ {
if (throwException)
throw se;
log.log(Level.WARNING, "Auth=" + m_auth + " - " + se.toString()); log.log(Level.WARNING, "Auth=" + m_auth + " - " + se.toString());
m_sentMsg = se.toString(); m_sentMsg = se.toString();
Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg); Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg);
@ -332,6 +359,8 @@ public final class EMail implements Serializable
} }
catch (Exception e) catch (Exception e)
{ {
if (throwException)
throw e;
log.log(Level.SEVERE, "Auth=" + m_auth, e); log.log(Level.SEVERE, "Auth=" + m_auth, e);
m_sentMsg = e.toString(); m_sentMsg = e.toString();
Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg); Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg);
@ -420,6 +449,8 @@ public final class EMail implements Serializable
} }
catch (MessagingException me) catch (MessagingException me)
{ {
if (throwException)
throw me;
me.printStackTrace(); me.printStackTrace();
Exception ex = me; Exception ex = me;
StringBuilder sb = new StringBuilder("(ME)"); StringBuilder sb = new StringBuilder("(ME)");
@ -504,6 +535,8 @@ public final class EMail implements Serializable
} }
catch (Exception e) catch (Exception e)
{ {
if (throwException)
throw e;
log.log(Level.SEVERE, "", e); log.log(Level.SEVERE, "", e);
m_sentMsg = e.getLocalizedMessage(); m_sentMsg = e.getLocalizedMessage();
Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg); Env.getCtx().put(EMAIL_SEND_MSG, m_sentMsg);
@ -560,13 +593,13 @@ public final class EMail implements Serializable
*/ */
private void dumpMessage() private void dumpMessage()
{ {
if (m_msg == null) if (m_msg == null || !log.isLoggable(Level.FINEST))
return; return;
try try
{ {
Enumeration<?> e = m_msg.getAllHeaderLines (); Enumeration<?> e = m_msg.getAllHeaderLines ();
while (e.hasMoreElements ()) while (e.hasMoreElements ())
if (log.isLoggable(Level.FINE)) log.fine("- " + e.nextElement ()); log.finest("- " + e.nextElement ());
} }
catch (MessagingException ex) catch (MessagingException ex)
{ {