[jboss-cvs] JBossRemoting/src/main/org/jboss/remoting ...

Ron Sigal ron_sigal at yahoo.com
Tue Jan 16 00:43:22 EST 2007


  User: rsigal  
  Date: 07/01/16 00:43:22

  Modified:    src/main/org/jboss/remoting  Tag: remoting_2_x
                        AbstractInvoker.java
  Log:
  JBREM-298, JBREM-622: (1) Stripped sessionId from unique listenerid; (2)  Added ability to wrap SocketFactory with CreationListenerSocketFactory.
  
  Revision  Changes    Path
  No                   revision
  
  
  No                   revision
  
  
  1.12.4.8  +44 -8     JBossRemoting/src/main/org/jboss/remoting/AbstractInvoker.java
  
  (In the diff below, changes in quantity of whitespace are not shown.)
  
  Index: AbstractInvoker.java
  ===================================================================
  RCS file: /cvsroot/jboss/JBossRemoting/src/main/org/jboss/remoting/AbstractInvoker.java,v
  retrieving revision 1.12.4.7
  retrieving revision 1.12.4.8
  diff -u -b -r1.12.4.7 -r1.12.4.8
  --- AbstractInvoker.java	13 Jan 2007 12:42:34 -0000	1.12.4.7
  +++ AbstractInvoker.java	16 Jan 2007 05:43:22 -0000	1.12.4.8
  @@ -27,6 +27,9 @@
   import org.jboss.remoting.marshal.MarshallLoaderFactory;
   import org.jboss.remoting.security.SSLSocketBuilder;
   import org.jboss.remoting.serialization.SerializationStreamFactory;
  +import org.jboss.remoting.socketfactory.CreationListenerSocketFactory;
  +import org.jboss.remoting.socketfactory.SocketCreationListener;
  +import org.jboss.remoting.socketfactory.SocketFactoryWrapper;
   import org.jboss.remoting.serialization.ClassLoaderUtility;
   import org.jboss.remoting.callback.InvokerCallbackHandler;
   import org.jboss.util.id.GUID;
  @@ -48,12 +51,11 @@
    *
    * @author <a href="mailto:jhaynie at vocalocity.net">Jeff Haynie</a>
    * @author <a href="mailto:telrod at e2technologies.net">Tom Elrod</a>
  - * @version $Revision: 1.12.4.7 $
  + * @version $Revision: 1.12.4.8 $
    */
   public abstract class AbstractInvoker implements Invoker
   {
  -   private static final Logger log = Logger.getLogger(AbstractInvoker.class);
  -
  +   protected final Logger log = Logger.getLogger(getClass());
      protected ClassByteClassLoader classbyteloader;
      protected InvokerLocator locator;
      protected Map localServerLocators = new HashMap();
  @@ -140,9 +142,10 @@
            // if got this far, the entry does not exist, so need to add it and create a listener id
            CallbackHandlerHolder holder = new CallbackHandlerHolder(callbackhandler, locator);
            listenerId = new GUID().toString();
  +         String key = listenerId;
            if (sessionId != null)
  -            listenerId = sessionId + "+" + listenerId;
  -         localServerLocators.put(listenerId, holder);
  +            key = sessionId + "+" + listenerId;
  +         localServerLocators.put(key, holder);
         }
   
         return listenerId;
  @@ -179,9 +182,12 @@
               {
                  Map.Entry entry = (Map.Entry) itr.next();
                  String listenerId = (String) entry.getKey();
  -               String prefix = listenerId.substring(0, listenerId.indexOf('+'));
  +               int index = listenerId.indexOf('+');
  +               String prefix = listenerId.substring(0, index);
                  if (!sessionId.equals(prefix))
                     continue;
  +               if (index >= 0)
  +                  listenerId = listenerId.substring(index + 1);
                  CallbackHandlerHolder holder = (CallbackHandlerHolder) entry.getValue();
                  InvokerCallbackHandler holderHandler = holder.getHandler();
                  if(holderHandler.equals(handler))
  @@ -195,7 +201,9 @@
               {
                  for(int x = 0; x < holderList.size(); x++)
                  {
  -                  localServerLocators.remove(((CallbackLocatorHolder)holderList.get(x)).getListenerId());
  +                  String listenerId = ((CallbackLocatorHolder)holderList.get(x)).getListenerId();
  +                  String key = sessionId + "+" + listenerId;
  +                  localServerLocators.remove(key);
                  }
               }
            }
  @@ -305,7 +313,35 @@
            }
         }
   
  -      return factory;
  +      return wrapSocketFactory(factory, configuration);
  +   }
  +   
  +   
  +   static public SocketFactory wrapSocketFactory(SocketFactory socketFactory, Map config)
  +   {
  +      if (config == null)
  +         return socketFactory;
  +      
  +      Object o = config.get(Remoting.SOCKET_CREATION_LISTENER);
  +      if (o != null && o instanceof SocketCreationListener)
  +      {
  +         SocketCreationListener listener = (SocketCreationListener) o;
  +         return new CreationListenerSocketFactory(socketFactory, listener);
  +      }
  +      
  +      return socketFactory;
  +   }
  +   
  +   
  +   static public boolean isCompleteSocketFactory(SocketFactory sf)
  +   {
  +      if (sf != null)
  +      {
  +         if (!(sf instanceof SocketFactoryWrapper) ||
  +             ((SocketFactoryWrapper)sf).getSocketFactory() != null)
  +            return true;
  +      }
  +      return false;
      }
   
   
  
  
  



More information about the jboss-cvs-commits mailing list