Package fr.dyade.aaa.jndi2.client

Source Code of fr.dyade.aaa.jndi2.client.NamingContextFactory

/*
* JORAM: Java(TM) Open Reliable Asynchronous Messaging
* Copyright (C) 2001 - 2007 ScalAgent Distributed Technologies
* Copyright (C) 1996 - 2000 Dyade
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
* USA.
*
* Initial developer(s): Sofiane Chibani
* Contributor(s): ScalAgent Distributed Technologies
*/
package fr.dyade.aaa.jndi2.client;

import java.util.Hashtable;
import java.util.StringTokenizer;

import javax.naming.CompositeName;
import javax.naming.Context;
import javax.naming.NamingException;
import javax.naming.spi.InitialContextFactory;

import org.objectweb.util.monolog.api.BasicLevel;

public class NamingContextFactory implements InitialContextFactory {
  /**
   * Name of the property which defines the listener port used when
   * creating an initial context using this factory.
   */
  public final static String JAVA_PORT_PROPERTY = "java.naming.factory.port";

  /**
   * Name of the property which defines the host name used when
   * creating an initial context using this factory.
   */
  public final static String JAVA_HOST_PROPERTY = "java.naming.factory.host";

  /**
   * Specific property. It is useful when several naming provider use
   * the same property.
   */
  public final static String SCN_PORT_PROPERTY = "scn.naming.factory.port";

  /**
   * Specific property. It is useful when several naming provider use
   * the same property.
   */
  public final static String SCN_HOST_PROPERTY = "scn.naming.factory.host";

  /**
   * Specific property. It is useful when several naming provider use
   * the same property.
   */
  public final static String SCN_PROVIDER_URL = "scn.naming.provider.url";

  /**
   * @param  env  This contains the hostname and the port.
   * @return  A JNDI initial context.
   * @exception  NamingException  Thrown if the host and port properties
   * aren't strings, if the port string does not represent a valid number,
   * or if an exception is thrown from the NamingContext constructor.
   */
  public Context getInitialContext(Hashtable env) throws NamingException {
    if (Trace.logger.isLoggable(BasicLevel.DEBUG))
      Trace.logger.log(BasicLevel.DEBUG,
                       "NamingContextFactory.getInitialContext(" + env + ')');

    return new NamingContextImpl(getNamingConnection(env),
                                 new CompositeName());   
  }

  public static NamingConnection getNamingConnection(Hashtable env) throws NamingException {
    if (Trace.logger.isLoggable(BasicLevel.DEBUG))
      Trace.logger.log(BasicLevel.DEBUG,
                       "NamingContextFactory.getNamingConnection(" + env + ')');

    try {
      String host;
      int port;
     
      // The URL format is scn://host:port
      String url = (String) env.get(SCN_PROVIDER_URL);
      if (url == null)
        url = (String) env.get(Context.PROVIDER_URL);
      if (url != null && !url.equals("")) {
        StringTokenizer tokenizer = new StringTokenizer(url, "/:,");
        if (! tokenizer.hasMoreElements())
          throw new NamingException("URL not valid:" + url);
        String protocol = tokenizer.nextToken();       
        if (protocol.equals("scn")) {
          host = tokenizer.nextToken();
          String portStr = tokenizer.nextToken();
          port = Integer.parseInt(portStr);
        } else {
          throw new NamingException("Unknown protocol:" + protocol);
        }
      } else {       
        host = (String) env.get(SCN_HOST_PROPERTY);
        if (host == null)
          host = System.getProperty(SCN_HOST_PROPERTY);
        if (host == null)
          host = (String) env.get(JAVA_HOST_PROPERTY);
        if (host == null)
          host = System.getProperty(JAVA_HOST_PROPERTY);
        if (host == null)
          host = "localhost";

        String portStr = (String) env.get(SCN_PORT_PROPERTY);
        if (portStr == null)
          portStr = System.getProperty(SCN_PORT_PROPERTY);
        if (portStr == null)
          portStr = (String) env.get(JAVA_PORT_PROPERTY);
        if (portStr == null)
          portStr = System.getProperty(JAVA_PORT_PROPERTY);
        if (portStr == null)
          portStr = "16400";

        port = Integer.parseInt(portStr);
      }

      SimpleNamingConnection namingConnection = new SimpleNamingConnection(host, port, env);
      namingConnection.init(host, port, env);

      return namingConnection;
    } catch (NumberFormatException e) {
      NamingException nx = new NamingException();
      nx.setRootCause(e);
      throw nx;
    } catch (Exception e) {
      NamingException nx = new NamingException();
      nx.setRootCause(e);
      throw nx;
    }
  }
}
TOP

Related Classes of fr.dyade.aaa.jndi2.client.NamingContextFactory

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.