001: /**
002: * JOnAS: Java(TM) Open Application Server
003: * Copyright (C) 1999-2004 Bull S.A.
004: * Contact: jonas-team@objectweb.org
005: *
006: * This library is free software; you can redistribute it and/or
007: * modify it under the terms of the GNU Lesser General Public
008: * License as published by the Free Software Foundation; either
009: * version 2.1 of the License, or 1any later version.
010: *
011: * This library is distributed in the hope that it will be useful,
012: * but WITHOUT ANY WARRANTY; without even the implied warranty of
013: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
014: * Lesser General Public License for more details.
015: *
016: * You should have received a copy of the GNU Lesser General Public
017: * License along with this library; if not, write to the Free Software
018: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
019: * USA
020: *
021: * Initial developer: Florent BENOIT
022: * --------------------------------------------------------------------------
023: * $Id: JResourceLDAPFactory.java 4804 2004-05-25 15:13:29Z benoitf $
024: * --------------------------------------------------------------------------
025: */package org.objectweb.jonas.security.realm.factory;
026:
027: //import java
028: import java.util.Hashtable;
029:
030: //import javax
031: import javax.naming.Context;
032: import javax.naming.Name;
033: import javax.naming.Reference;
034:
035: //import objectweb.util
036: import org.objectweb.util.monolog.api.BasicLevel;
037:
038: /**
039: * This class provides an implementation of a JResource JNDI factory for
040: * managing users
041: * @author Florent Benoit
042: */
043: public class JResourceLDAPFactory extends JResourceFactory {
044:
045: /**
046: * The Java type for which this factory knows how to create objects.
047: */
048: private static final String FACTORY_TYPE = "org.objectweb.jonas.security.realm.factory.JResourceLDAP";
049:
050: /**
051: * Creates a javax.mail.Session object using the location or reference
052: * information specified.
053: * @param obj the possibly null object containing location or reference
054: * information that can be used in creating an object.
055: * @param name the name of this object relative to nameCtx, or null if no
056: * name is specified.
057: * @param nameCtx the context relative to which the name parameter is
058: * specified, or null if name is relative to the default initial
059: * context.
060: * @param environment the possibly null environment that is used in creating
061: * the object.
062: * @return a newly created javax.mail.Session object with the specific
063: * configuration; null if an object cannot be created.
064: * @throws Exception if this object factory encountered an exception while
065: * attempting to create an object, and no other object factories are
066: * to be tried.
067: */
068: public Object getObjectInstance(Object obj, Name name,
069: Context nameCtx, Hashtable environment) throws Exception {
070:
071: // Get the reference
072: Reference ref = (Reference) obj;
073:
074: // Get the class name
075: String clname = ref.getClassName();
076:
077: // Check the class name
078: if (!ref.getClassName().equals(FACTORY_TYPE)) {
079: getLogger().log(
080: BasicLevel.ERROR,
081: "Cannot create object : required type is '"
082: + FACTORY_TYPE + "', but found type is '"
083: + clname + "'.");
084: return (null);
085: }
086:
087: String jResName = (String) ref.get("name").getContent();
088: String initialContextFactory = (String) ref.get(
089: "initialContextFactory").getContent();
090: String providerUrl = (String) ref.get("providerUrl")
091: .getContent();
092: String securityAuthentication = (String) ref.get(
093: "securityAuthentication").getContent();
094: String securityPrincipal = (String) ref
095: .get("securityPrincipal").getContent();
096: String securityCredentials = (String) ref.get(
097: "securityCredentials").getContent();
098: String securityProtocol = (String) ref.get("securityProtocol")
099: .getContent();
100: String language = (String) ref.get("language").getContent();
101: String referral = (String) ref.get("referral").getContent();
102: String stateFactories = (String) ref.get("stateFactories")
103: .getContent();
104: String authenticationMode = (String) ref.get(
105: "authenticationMode").getContent();
106: String userPasswordAttribute = (String) ref.get(
107: "userPasswordAttribute").getContent();
108: String userRolesAttribute = (String) ref.get(
109: "userRolesAttribute").getContent();
110: String roleNameAttribute = (String) ref
111: .get("roleNameAttribute").getContent();
112: String baseDN = (String) ref.get("baseDN").getContent();
113: String userDN = (String) ref.get("userDN").getContent();
114: String userSearchFilter = (String) ref.get("userSearchFilter")
115: .getContent();
116: String roleDN = (String) ref.get("roleDN").getContent();
117: String roleSearchFilter = (String) ref.get("roleSearchFilter")
118: .getContent();
119: String algorithm = (String) ref.get("algorithm").getContent();
120:
121: // Create and return a new object
122: JResourceLDAP jResourceLDAP = new JResourceLDAP();
123: jResourceLDAP.setName(jResName);
124: jResourceLDAP.setInitialContextFactory(initialContextFactory);
125: jResourceLDAP.setProviderUrl(providerUrl);
126: jResourceLDAP.setSecurityAuthentication(securityAuthentication);
127: jResourceLDAP.setSecurityPrincipal(securityPrincipal);
128: jResourceLDAP.setSecurityCredentials(securityCredentials);
129: jResourceLDAP.setSecurityProtocol(securityProtocol);
130: jResourceLDAP.setLanguage(language);
131: jResourceLDAP.setReferral(referral);
132: jResourceLDAP.setStateFactories(stateFactories);
133: jResourceLDAP.setAuthenticationMode(authenticationMode);
134: jResourceLDAP.setUserPasswordAttribute(userPasswordAttribute);
135: jResourceLDAP.setUserRolesAttribute(userRolesAttribute);
136: jResourceLDAP.setRoleNameAttribute(roleNameAttribute);
137: jResourceLDAP.setBaseDN(baseDN);
138: jResourceLDAP.setUserDN(userDN);
139: jResourceLDAP.setUserSearchFilter(userSearchFilter);
140: jResourceLDAP.setRoleDN(roleDN);
141: jResourceLDAP.setRoleSearchFilter(roleSearchFilter);
142: jResourceLDAP.setAlgorithm(algorithm);
143:
144: return jResourceLDAP;
145: }
146:
147: }
|