1 package org
.argeo
.slc
.web
.mvc
;
3 import org
.apache
.commons
.logging
.Log
;
4 import org
.apache
.commons
.logging
.LogFactory
;
5 import org
.argeo
.slc
.msg
.ExecutionAnswer
;
6 import org
.argeo
.slc
.msg
.event
.SlcEvent
;
7 import org
.argeo
.slc
.msg
.event
.SlcEventListener
;
8 import org
.argeo
.slc
.msg
.event
.SlcEventListenerDescriptor
;
9 import org
.argeo
.slc
.msg
.event
.SlcEventListenerRegister
;
10 import org
.springframework
.stereotype
.Controller
;
11 import org
.springframework
.web
.bind
.annotation
.RequestMapping
;
12 import org
.springframework
.web
.bind
.annotation
.RequestParam
;
15 public class EventController
{
17 private final static Log log
= LogFactory
.getLog(EventController
.class);
19 public final static String KEY_ANSWER
= "__answer";
20 private Long defaultTimeout
= 10000l;
23 private SlcEventListenerRegister eventListenerRegister
;
24 private SlcEventListener eventListener
= null;
26 public EventController() {
31 @RequestMapping("/addEventListener.service")
32 public ExecutionAnswer
addEventListener(
33 @RequestParam(SlcEvent
.EVENT_TYPE
) String eventType
,
34 @RequestParam(value
= SlcEvent
.EVENT_FILTER
, required
= false) String eventFilter
) {
37 .addEventListenerDescriptor(new SlcEventListenerDescriptor(
38 eventType
, eventFilter
));
39 if (log
.isTraceEnabled())
40 log
.trace("Registered listener on register "
41 + eventListenerRegister
.getId() + " for type " + eventType
42 + ", filter=" + eventFilter
);
43 return ExecutionAnswer
.ok("Execution completed properly");
47 @RequestMapping("/removeEventListener.service")
48 public ExecutionAnswer
removeEventListener(
49 @RequestParam(SlcEvent
.EVENT_TYPE
) String eventType
,
50 @RequestParam(value
= SlcEvent
.EVENT_FILTER
, required
= false) String eventFilter
) {
53 .removeEventListenerDescriptor(new SlcEventListenerDescriptor(
54 eventType
, eventFilter
));
55 if (log
.isTraceEnabled())
56 log
.trace("Removed listener from register "
57 + eventListenerRegister
.getId() + " for type " + eventType
58 + ", filter=" + eventFilter
);
59 return ExecutionAnswer
.ok("Execution completed properly");
62 @RequestMapping("/pollEvent.service")
63 public Object
pollEvent(
64 @RequestParam(value
= "timeout", required
= false) String timeoutStr
) {
66 if (timeoutStr
!= null)
67 timeout
= Long
.parseLong(timeoutStr
);
69 timeout
= defaultTimeout
;
71 SlcEvent event
= eventListener
.listen(eventListenerRegister
.getId(),
72 eventListenerRegister
.getDescriptorsCopy(), timeout
);
76 return ExecutionAnswer
.ok("Execution completed properly");
80 public void setEventListenerRegister(
81 SlcEventListenerRegister eventListenerRegister
) {
82 this.eventListenerRegister
= eventListenerRegister
;
85 public void setDefaultTimeout(Long defaultTimeout
) {
86 this.defaultTimeout
= defaultTimeout
;
89 public void setEventListener(SlcEventListener eventListener
) {
90 this.eventListener
= eventListener
;