use of com.helger.smtp.transport.MailTransportError in project ph-web by phax.
the class FailedMailDataTest method testWithExceptionAndData.
@Test
public void testWithExceptionAndData() {
final ISMTPSettings aSettings = _createSMTPSettings();
final EmailData aData = _createEmailData();
final Throwable aError = new MockException("Test error");
final FailedMailData aFMD = new FailedMailData(aSettings, aData, new MailTransportError(aError));
assertNotNull(aFMD.getID());
assertNotNull(aFMD.getErrorDateTime());
assertEquals(aSettings, aFMD.getSMTPSettings());
assertEquals(aData.getSentDateTime(), aFMD.getOriginalSentDateTime());
assertEquals(aData, aFMD.getEmailData());
assertTrue(aFMD.hasTransportError());
assertNotNull(aFMD.getTransportThrowableMessage());
assertNotNull(aFMD.getTransportError());
XMLTestHelper.testMicroTypeConversion(aFMD);
}
use of com.helger.smtp.transport.MailTransportError in project ph-web by phax.
the class FailedMailDataTest method testWithException.
@Test
public void testWithException() {
final ISMTPSettings aSettings = _createSMTPSettings();
final Throwable aError = new MockException("Test error");
final FailedMailData aFMD = new FailedMailData(aSettings, new MailTransportError(aError));
assertNotNull(aFMD.getID());
assertNotNull(aFMD.getErrorDateTime());
assertEquals(aSettings, aFMD.getSMTPSettings());
assertNull(aFMD.getOriginalSentDateTime());
assertNull(aFMD.getEmailData());
assertTrue(aFMD.hasTransportError());
assertNotNull(aFMD.getTransportThrowableMessage());
assertNotNull(aFMD.getTransportError());
XMLTestHelper.testMicroTypeConversion(aFMD);
}
use of com.helger.smtp.transport.MailTransportError in project ph-web by phax.
the class FailedMailDataMicroTypeConverter method convertToNative.
@Nullable
public FailedMailData convertToNative(@Nonnull final IMicroElement eFailedMail) {
final String sID = eFailedMail.getAttributeValue(ATTR_ID);
if (sID == null) {
LOGGER.error("Failed to read ID");
return null;
}
// Read error date/time
final String sErrorDT = eFailedMail.getAttributeValue(ATTR_ERRORDT);
if (sErrorDT == null) {
LOGGER.error("Failed to read error date/time");
return null;
}
LocalDateTime aErrorDT = PDTWebDateHelper.getLocalDateTimeFromXSD(sErrorDT);
if (aErrorDT == null)
aErrorDT = TypeConverter.convert(sErrorDT, LocalDateTime.class);
if (aErrorDT == null) {
if (LOGGER.isErrorEnabled())
LOGGER.error("Failed to parse error date '" + sErrorDT + "'");
return null;
}
// read original sent date/time
final String sOriginalSentDT = eFailedMail.getAttributeValue(ATTR_ORIGINALSENT_DT);
LocalDateTime aOriginalSentDT = null;
if (sOriginalSentDT != null) {
aOriginalSentDT = PDTWebDateHelper.getLocalDateTimeFromXSD(sOriginalSentDT);
if (aOriginalSentDT == null)
aOriginalSentDT = TypeConverter.convert(sOriginalSentDT, LocalDateTime.class);
}
// SMTP settings
final IMicroElement eSMTPSettings = eFailedMail.getFirstChildElement(ELEMENT_SMTP_SETTINGS);
if (eSMTPSettings == null) {
LOGGER.error("Failed to get child element of SMTP settings!");
return null;
}
final ISMTPSettings aSMTPSettings = MicroTypeConverter.convertToNative(eSMTPSettings, SMTPSettings.class);
// email data (may be null)
final IMicroElement eEmailData = eFailedMail.getFirstChildElement(ELEMENT_EMAIL_DATA);
final IMutableEmailData aEmailData = MicroTypeConverter.convertToNative(eEmailData, EmailData.class);
// error message
final String sErrorMessage = MicroHelper.getChildTextContent(eFailedMail, ELEMENT_ERROR_MSG);
final Exception aException = StringHelper.hasNoText(sErrorMessage) ? null : new Exception(sErrorMessage);
MailTransportError aError = null;
if (aException != null) {
final ICommonsList<MailSendDetails> aDetails = new CommonsArrayList<>();
for (final IMicroElement eDetails : eFailedMail.getAllChildElements(ELEMENT_DETAILS)) {
final boolean bAddressValid = StringParser.parseBool(eDetails.getAttributeValue(ATTR_ADDRESS_VALID));
final String sAddress = eDetails.getAttributeValue(ATTR_ADDRESS);
final String sCommand = eDetails.getAttributeValue(ATTR_COMMAND);
final String sDetailsErrorMessage = eDetails.getAttributeValue(ATTR_ERROR_MESSAGE);
final int nErrorCode = StringParser.parseInt(eDetails.getAttributeValue(ATTR_ERROR_CODE), -1);
final ESMTPErrorCode eErrorCode = ESMTPErrorCode.getFromIDOrDefault(nErrorCode, ESMTPErrorCode.FALLBACK);
aDetails.add(new MailSendDetails(bAddressValid, sAddress, sCommand, sDetailsErrorMessage, eErrorCode));
}
aError = new MailTransportError(aException, aDetails);
}
return new FailedMailData(sID, aErrorDT, aSMTPSettings, aOriginalSentDT, aEmailData, aError);
}
use of com.helger.smtp.transport.MailTransportError in project ph-web by phax.
the class FailedMailDataMicroTypeConverter method convertToMicroElement.
@Nonnull
public IMicroElement convertToMicroElement(@Nonnull final FailedMailData aFailedMail, @Nullable final String sNamespaceURI, @Nonnull final String sTagName) {
final IMicroElement eFailedMail = new MicroElement(sNamespaceURI, sTagName);
eFailedMail.setAttribute(ATTR_ID, aFailedMail.getID());
eFailedMail.setAttributeWithConversion(ATTR_ERRORDT, aFailedMail.getErrorDateTime());
eFailedMail.setAttributeWithConversion(ATTR_ORIGINALSENT_DT, aFailedMail.getOriginalSentDateTime());
// SMTP settings
eFailedMail.appendChild(MicroTypeConverter.convertToMicroElement(aFailedMail.getSMTPSettings(), sNamespaceURI, ELEMENT_SMTP_SETTINGS));
// email data
eFailedMail.appendChild(MicroTypeConverter.convertToMicroElement(aFailedMail.getEmailData(), sNamespaceURI, ELEMENT_EMAIL_DATA));
final MailTransportError aTransportError = aFailedMail.getTransportError();
if (aTransportError != null) {
eFailedMail.appendElement(sNamespaceURI, ELEMENT_ERROR_MSG).appendText(aTransportError.getThrowable().getMessage());
for (final MailSendDetails aDetails : aTransportError.getAllDetails()) {
eFailedMail.appendElement(sNamespaceURI, ELEMENT_DETAILS).setAttribute(ATTR_ADDRESS_VALID, aDetails.isAddressValid()).setAttribute(ATTR_ADDRESS, aDetails.getAddress()).setAttribute(ATTR_COMMAND, aDetails.getCommand()).setAttribute(ATTR_ERROR_MESSAGE, aDetails.getErrorMessage()).setAttribute(ATTR_ERROR_CODE, aDetails.getErrorCode().getECode());
}
}
return eFailedMail;
}
Aggregations