View Javadoc

1   //
2   //  ========================================================================
3   //  Copyright (c) 1995-2016 Mort Bay Consulting Pty. Ltd.
4   //  ------------------------------------------------------------------------
5   //  All rights reserved. This program and the accompanying materials
6   //  are made available under the terms of the Eclipse Public License v1.0
7   //  and Apache License v2.0 which accompanies this distribution.
8   //
9   //      The Eclipse Public License is available at
10  //      http://www.eclipse.org/legal/epl-v10.html
11  //
12  //      The Apache License v2.0 is available at
13  //      http://www.opensource.org/licenses/apache2.0.php
14  //
15  //  You may elect to redistribute this code under either of these licenses.
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   * Factory for {@link MessageHandlerMetadata}
35   */
36  public class MessageHandlerFactory
37  {
38      private static final Logger LOG = Log.getLogger(MessageHandlerFactory.class);
39      /** Registered MessageHandlers at this level */
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 }