use of org.nhindirect.common.audit.AuditContext in project nhin-d by DirectProject.
the class DefaultSmtpAgent method postProcessMessage.
private void postProcessMessage(MessageProcessResult result) {
boolean isOutgoing = (result.getProcessedMessage() instanceof OutgoingMessage);
// check for rejected recipients
if (auditor != null && result.getProcessedMessage().getRejectedRecipients() != null && result.getProcessedMessage().getRejectedRecipients().size() > 0) {
Collection<AuditContext> contexts = createContextCollectionFromMessage(result.getProcessedMessage(), Arrays.asList(AuditEvents.DEFAULT_HEADER_CONTEXT));
StringBuffer rejectedRecips = new StringBuffer();
int cnt = 0;
for (NHINDAddress address : result.getProcessedMessage().getRejectedRecipients()) {
rejectedRecips.append(address.getAddress());
if (++cnt < result.getProcessedMessage().getRejectedRecipients().size())
rejectedRecips.append(", ");
}
contexts.add(new DefaultAuditContext(AuditEvents.REJECTED_RECIPIENTS_CONTEXT, rejectedRecips.toString()));
auditor.audit(PRINICPAL, new AuditEvent(AuditEvents.REJECTED_RECIP_NAME, AuditEvents.EVENT_TYPE), contexts);
}
if (isOutgoing)
postProcessOutgoingMessage(result);
else
postProcessIncomingMessage(result);
}
use of org.nhindirect.common.audit.AuditContext in project nhin-d by DirectProject.
the class DefaultSmtpAgent_AuditMessage_Test method testAuditIncomingMessage_AssertEventsAudited.
public void testAuditIncomingMessage_AssertEventsAudited() throws Exception {
new TestPlan() {
protected String getMessageToProcess() throws Exception {
return TestUtils.readMessageResource("PlainIncomingMessage.txt");
}
@Override
protected void doAssertions(MessageProcessResult result) throws Exception {
DefaultSmtpAgent smtpAgent = (DefaultSmtpAgent) agent;
assertNotNull(smtpAgent.getAuditor());
assertTrue(smtpAgent.getAuditor() instanceof MockAuditor);
assertTrue(auditor.getEvents().size() > 0);
boolean foundIncomingType = false;
boolean foundMDNType = false;
for (Entry<AuditEvent, Collection<? extends AuditContext>> entry : auditor.getEvents().entrySet()) {
AuditEvent event = entry.getKey();
assertEquals(event.getType(), "SMTP Direct Message Processing");
if (event.getName().equals(AuditEvents.INCOMING_MESSAGE_NAME))
foundIncomingType = true;
else if (event.getName().equals(AuditEvents.PRODUCE_MDN_NAME)) {
boolean foundFinalRecip = false;
boolean foundOrigMsgId = false;
boolean foundDisp = false;
for (AuditContext ctx : entry.getValue()) {
if (ctx.getContextName().equals(MDNStandard.Headers.FinalRecipient)) {
foundFinalRecip = true;
} else if (ctx.getContextName().equals(MDNStandard.Headers.OriginalMessageID)) {
foundOrigMsgId = true;
} else if (ctx.getContextName().equals(MDNStandard.Headers.Disposition)) {
assertEquals("automatic-action/MDN-sent-automatically;processed", ctx.getContextValue());
foundDisp = true;
}
}
assertTrue(foundFinalRecip);
assertTrue(foundOrigMsgId);
assertTrue(foundDisp);
foundMDNType = true;
// assert attributes of the event
}
}
assertTrue(foundIncomingType);
assertTrue(foundMDNType);
}
}.perform();
}
Aggregations