1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package org.eclipse.jetty.websocket.jsr356;
20
21 import java.util.ArrayList;
22 import java.util.List;
23 import java.util.Map;
24 import java.util.concurrent.ConcurrentHashMap;
25
26 import javax.websocket.MessageHandler;
27
28 import org.eclipse.jetty.util.log.Log;
29 import org.eclipse.jetty.util.log.Logger;
30 import org.eclipse.jetty.websocket.common.util.ReflectUtils;
31 import org.eclipse.jetty.websocket.jsr356.metadata.MessageHandlerMetadata;
32
33
34
35
36 public class MessageHandlerFactory
37 {
38 private static final Logger LOG = Log.getLogger(MessageHandlerFactory.class);
39
40 private Map<Class<? extends MessageHandler>, List<MessageHandlerMetadata>> registered;
41
42 public MessageHandlerFactory()
43 {
44 registered = new ConcurrentHashMap<>();
45 }
46
47 public List<MessageHandlerMetadata> getMetadata(Class<? extends MessageHandler> handler) throws IllegalStateException
48 {
49 if (LOG.isDebugEnabled())
50 {
51 LOG.debug("getMetadata({})",handler);
52 }
53 List<MessageHandlerMetadata> ret = registered.get(handler);
54 if (ret != null)
55 {
56 return ret;
57 }
58
59 return register(handler);
60 }
61
62 public List<MessageHandlerMetadata> register(Class<? extends MessageHandler> handler)
63 {
64 List<MessageHandlerMetadata> metadatas = new ArrayList<>();
65
66 boolean partial = false;
67
68 if (MessageHandler.Partial.class.isAssignableFrom(handler))
69 {
70 if (LOG.isDebugEnabled())
71 {
72 LOG.debug("supports Partial: {}",handler);
73 }
74 partial = true;
75 Class<?> onMessageClass = ReflectUtils.findGenericClassFor(handler,MessageHandler.Partial.class);
76 if (LOG.isDebugEnabled())
77 {
78 LOG.debug("Partial message class: {}",onMessageClass);
79 }
80 metadatas.add(new MessageHandlerMetadata(handler,onMessageClass,partial));
81 }
82
83 if (MessageHandler.Whole.class.isAssignableFrom(handler))
84 {
85 if (LOG.isDebugEnabled())
86 {
87 LOG.debug("supports Whole: {}",handler.getName());
88 }
89 partial = false;
90 Class<?> onMessageClass = ReflectUtils.findGenericClassFor(handler,MessageHandler.Whole.class);
91 if (LOG.isDebugEnabled())
92 {
93 LOG.debug("Whole message class: {}",onMessageClass);
94 }
95 metadatas.add(new MessageHandlerMetadata(handler,onMessageClass,partial));
96 }
97
98 registered.put(handler,metadatas);
99 return metadatas;
100 }
101 }