/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.jetspeed.security.spi.impl.ldap;
import java.security.Principal;
import javax.naming.directory.Attributes;
import javax.naming.directory.BasicAttribute;
import javax.naming.directory.BasicAttributes;
import org.apache.commons.lang.StringUtils;
import org.apache.jetspeed.security.SecurityException;
import org.apache.jetspeed.security.impl.RolePrincipalImpl;
/**
* <p>
* DAO for handling group objects.
* </p>
*
* @author Davy De Waele
*/
public class LdapRoleDaoImpl extends LdapPrincipalDaoImpl
{
/**
* <p>
* Default constructor.
* </p>
*
* @throws SecurityException A {@link SecurityException}.
*/
public LdapRoleDaoImpl() throws SecurityException
{
super();
}
/**
* <p>
* Initializes the dao.
* </p>
*
* @param ldapConfig Holds the ldap binding configuration.
* @throws SecurityException A {@link SecurityException}.
*/
public LdapRoleDaoImpl(LdapBindingConfig ldapConfig) throws SecurityException
{
super(ldapConfig);
}
/**
* <p>
* A template method for defining the attributes for a particular LDAP class.
* </p>
*
* @param principalUid The principal uid.
* @return The LDAP attributes object for the particular class.
*/
protected Attributes defineLdapAttributes(final String principalUid)
{
Attributes attrs = new BasicAttributes(true);
BasicAttribute classes = new BasicAttribute("objectclass");
for (int i=0;i<getObjectClasses().length;i++)
classes.add(getObjectClasses()[i]);
attrs.put(classes);
attrs.put(getEntryPrefix(), principalUid);
if(!StringUtils.isEmpty(getRoleObjectRequiredAttributeClasses()))
attrs.put(getRoleObjectRequiredAttributeClasses(), "");
for (int i=0;i<getAttributes().length;i++)
attrs.put(parseAttr(getAttributes()[i],principalUid)[0], parseAttr(getAttributes()[i],principalUid)[1]);
return attrs;
}
/**
* @see org.apache.jetspeed.security.spi.impl.ldap.LdapPrincipalDaoImpl#getDnSuffix()
*/
protected String getDnSuffix()
{
return this.getRoleFilterBase();
}
/**
* <p>
* Creates a GroupPrincipal object.
* </p>
*
* @param principalUid The principal uid.
* @return A group principal object.
*/
protected Principal makePrincipal(String principalUid)
{
return new RolePrincipalImpl(principalUid);
}
protected String getEntryPrefix() {
return this.getRoleIdAttribute();
}
protected String getSearchSuffix() {
return this.getRoleFilter();
}
protected String getSearchDomain() {
return this.getRoleFilterBase();
}
protected String[] getObjectClasses() {
return this.getRoleObjectClasses();
}
protected String getUidAttributeForPrincipal() {
return this.getRoleUidAttribute();
}
protected String[] getAttributes() {
return getRoleAttributes();
}
}