/* * ==================== * 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(); } }