1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.openehealth.ipf.commons.audit.queue;
18
19 import org.openehealth.ipf.commons.audit.AuditContext;
20 import org.slf4j.Logger;
21 import org.slf4j.LoggerFactory;
22
23 import javax.jms.JMSException;
24 import javax.jms.Message;
25 import javax.jms.MessageListener;
26 import javax.jms.TextMessage;
27
28 import static java.util.Objects.requireNonNull;
29
30
31
32
33
34
35
36
37
38
39 public class JmsAuditMessageListener implements MessageListener {
40
41 private static final Logger LOG = LoggerFactory.getLogger(JmsAuditMessageListener.class);
42
43 private final AuditContext auditContext;
44
45 public JmsAuditMessageListener(AuditContext auditContext) {
46 this.auditContext = requireNonNull(auditContext, "AuditContext must not be null");
47 }
48
49 @Override
50 public void onMessage(Message message) {
51 TextMessage textMessage = (TextMessage) message;
52 try {
53 String text = textMessage.getText();
54 auditContext.getAuditTransmissionProtocol().send(auditContext, text);
55 } catch (JMSException jmsException1) {
56 LOG.error("Could not obtain text from JMS message", jmsException1);
57 } catch (Exception e) {
58 LOG.warn("Could not send audit message, rolling back", e);
59 throw new RuntimeException(e);
60 }
61 }
62 }