NumSubordinateHacker.java revision d25372dc8e65a9ed019a88fdf659ca61313f1b31
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at
* trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
* add the following below this CDDL HEADER, with the fields enclosed
* by brackets "[]" replaced with your own identifying information:
* Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*
*
* Copyright 2008 Sun Microsystems, Inc.
*/
/**
* Class used to handle the case where numsubordinates does not work between
* databases.
*
*/
public class NumSubordinateHacker {
int serverPort;
boolean isUnreliableEntryListEmpty;
/**
* Default constructor.
*
*/
public NumSubordinateHacker() {
serverHost = "not-initialized";
serverPort = -1;
}
/**
* Tells wether the list of unreliable contains children of
* the entry with LDAPUrl parentUrl.
* @param parentUrl the LDAPURL of the parent.
* @return <CODE>true</CODE> if the list of unreliable entries contains a
* children of the parentUrl. Returns <CODE>false</CODE> otherwise.
*/
boolean containsChildren = false;
if (!isUnreliableEntryListEmpty) {
if (isInServer) {
{
try
{
{
containsChildren = true;
break;
}
}
catch (OpenDsException oe)
{
throw new IllegalStateException("Error decoding DN of url: "+
}
}
}
}
return containsChildren;
}
/**
* Tells wether the list of unreliable contains the entry with LDAPURL
* url.
* It assumes that we previously called containsChildrenOf (there's no check
* @param url the LDAPURL of the parent.
* @return <CODE>true</CODE> if the url correspond to an unreliable
* entry and <CODE>false</CODE> otherwise.
*/
boolean contains = false;
if (!isUnreliableEntryListEmpty) {
if (isInServer) {
{
try
{
{
contains = true;
break;
}
}
catch (OpenDsException oe)
{
throw new IllegalStateException("Error decoding DN of url: "+
url);
}
}
}
}
return contains;
}
/**
* This method construct a list with the entries the entries that are parents
* of the suffix entries. This list is needed to overpass the fact that
* numsubordinates does not work between databases.
* @param allSuffixes a collection with all the suffixes.
* @param rootSuffixes a collection with the root suffixes.
* @param serverHost the name of the host where the server is installed.
* @param serverPort the LDAP(s) port of the server.
*/
int serverPort)
{
synchronized (unreliableEntryList) {
}
}
this.serverHost = serverHost;
this.serverPort = serverPort;
}
}