2 * Copyright (C) 2010 Mathieu Baudier <mbaudier@argeo.org>
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 package org
.argeo
.slc
.jms
;
19 import java
.util
.List
;
21 import javax
.jms
.Destination
;
23 import org
.apache
.commons
.logging
.Log
;
24 import org
.apache
.commons
.logging
.LogFactory
;
25 import org
.argeo
.slc
.UnsupportedException
;
26 import org
.argeo
.slc
.execution
.ExecutionProcess
;
27 import org
.argeo
.slc
.execution
.ExecutionStep
;
28 import org
.argeo
.slc
.msg
.process
.SlcExecutionStatusRequest
;
29 import org
.argeo
.slc
.msg
.process
.SlcExecutionStepsRequest
;
30 import org
.argeo
.slc
.process
.SlcExecution
;
31 import org
.argeo
.slc
.process
.SlcExecutionNotifier
;
32 import org
.argeo
.slc
.process
.SlcExecutionStep
;
33 import org
.springframework
.jms
.JmsException
;
34 import org
.springframework
.jms
.core
.JmsTemplate
;
36 @SuppressWarnings("deprecation")
37 public class JmsSlcExecutionNotifier
implements SlcExecutionNotifier
{
38 private final static Log log
= LogFactory
39 .getLog(JmsSlcExecutionNotifier
.class);
41 private JmsTemplate jmsTemplate
;
43 private Destination executionEventDestination
;
45 // private Destination updateStatusDestination;
47 public void updateStatus(ExecutionProcess slcExecution
, String oldStatus
,
49 SlcExecutionStatusRequest req
= new SlcExecutionStatusRequest(
50 slcExecution
.getUuid(), newStatus
);
54 public void addSteps(ExecutionProcess slcExecution
,
55 List
<ExecutionStep
> additionalSteps
) {
56 SlcExecutionStepsRequest req
= new SlcExecutionStepsRequest(
57 slcExecution
.getUuid(), additionalSteps
);
61 public void newExecution(SlcExecution slcExecution
) {
62 throw new UnsupportedException();
65 public void updateExecution(SlcExecution slcExecution
) {
66 throw new UnsupportedException();
69 public void setJmsTemplate(JmsTemplate jmsTemplate
) {
70 this.jmsTemplate
= jmsTemplate
;
73 public void setExecutionEventDestination(
74 Destination executionEventDestination
) {
75 this.executionEventDestination
= executionEventDestination
;
78 protected void convertAndSend(Object req
) {
80 jmsTemplate
.convertAndSend(executionEventDestination
, req
);
81 } catch (JmsException e
) {
82 log
.warn("Send request " + req
.getClass() + " to server: "
84 if (log
.isTraceEnabled())
85 log
.debug("Original error.", e
);