1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package com.hack23.cia.service.component.agent.impl.riksdagen.workers;
20
21 import javax.jms.JMSException;
22 import javax.jms.Message;
23 import javax.jms.MessageListener;
24 import javax.jms.ObjectMessage;
25
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
28 import org.springframework.beans.factory.annotation.Autowired;
29 import org.springframework.stereotype.Service;
30 import org.springframework.transaction.annotation.Transactional;
31
32 import com.hack23.cia.service.component.agent.impl.riksdagen.workers.data.RiksdagenUpdateService;
33 import com.hack23.cia.service.external.riksdagen.api.DataFailureException;
34 import com.hack23.cia.service.external.riksdagen.api.RiksdagenCommitteeProposalApi;
35
36
37
38
39 @Service("riksdagenCommitteeProposalComponentDataWorkConsumerImpl")
40 @Transactional
41 final class RiksdagenCommitteeProposalComponentDataWorkConsumerImpl implements MessageListener {
42
43
44 private static final Logger LOGGER = LoggerFactory
45 .getLogger(RiksdagenCommitteeProposalComponentDataWorkConsumerImpl.class);
46
47
48 @Autowired
49 private RiksdagenUpdateService updateService;
50
51
52 @Autowired
53 private RiksdagenCommitteeProposalApi riksdagenApi;
54
55
56
57
58
59
60 public RiksdagenCommitteeProposalComponentDataWorkConsumerImpl() {
61 super();
62 }
63
64
65 @Override
66 public void onMessage(final Message message) {
67 try {
68 updateService.updateCommitteeProposalComponentData(riksdagenApi
69 .getCommitteeProposal((String) ((ObjectMessage) message)
70 .getObject()));
71 } catch (final DataFailureException | RuntimeException | JMSException e) {
72 LOGGER.warn("Error loading CommitteeProposalComponentData" , e);
73 }
74 }
75 }