/*
* ====================
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2008-2009 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of the Common Development
* and Distribution License("CDDL") (the "License"). You may not use this file
* except in compliance with the License.
*
* You can obtain a copy of the License at
* http://IdentityConnectors.dev.java.net/legal/license.txt
* See the License for the specific language governing permissions and limitations
* under the License.
*
* When distributing the Covered Code, include this CDDL Header Notice in each file
* and include the License file at identityconnectors/legal/license.txt.
* If applicable, add the following below this CDDL Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
* ====================
*/
package org.identityconnectors.ldap.search;
import java.io.IOException;
import java.util.Arrays;
import java.util.List;
import javax.naming.NamingException;
import javax.naming.directory.SearchControls;
import javax.naming.ldap.LdapContext;
public abstract class LdapSearchStrategy {
public abstract void doSearch(LdapContext initCtx, List<String> baseDNs, String query, SearchControls searchControls, SearchResultsHandler handler)
throws IOException, NamingException;
static String searchControlsToString(SearchControls controls) {
StringBuilder builder = new StringBuilder();
builder.append("SearchControls: {returningAttributes=");
String[] attrs = controls.getReturningAttributes();
builder.append(attrs != null ? Arrays.asList(attrs) : "null");
builder.append(", scope=");
switch (controls.getSearchScope()) {
case SearchControls.OBJECT_SCOPE:
builder.append("OBJECT");
break;
case SearchControls.ONELEVEL_SCOPE:
builder.append("ONELEVEL");
break;
case SearchControls.SUBTREE_SCOPE:
builder.append("SUBTREE");
break;
}
builder.append('}');
return builder.toString();
}
}