Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
   *
   * Copyright 2011 Tirasa. All rights reserved.
   *
   * The contents of this file are subject to the terms of either the GNU
   * General Public License Version 2 only ("GPL") or the Common Development
   * and Distribution License("CDDL") (collectively, the "License").  You
   * may not use this file except in compliance with the License. You can obtain
  * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
  * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
  * language governing permissions and limitations under the License.
  *
  * When distributing the software, include this License Header Notice in each
  * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
  * Sun designates this particular file as subject to the "Classpath" exception
  * as provided by Sun in the GPL Version 2 section of the License file that
  * accompanied this code.  If applicable, add the following below the License
  * Header, with the fields enclosed by brackets [] replaced by your own
  * identifying information: "Portions Copyrighted [year]
  * [name of copyright owner]"
  */
 package org.connid.ad.search;
 
 import java.util.List;
 
 public class ADDefaultSearchStrategy extends DefaultSearchStrategy {
 
     private static final Log LOG = Log.getLog(ADDefaultSearchStrategy.class);
 
     private final boolean ignoreNonExistingBaseDNs;
 
     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 .:
                 builder.append("OBJECT");
                 break;
             case .:
                 builder.append("ONELEVEL");
                 break;
             case .:
                 builder.append("SUBTREE");
                 break;
         }
         builder.append('}');
         return builder.toString();
     }
 
     public ADDefaultSearchStrategy(boolean ignoreNonExistingBaseDNs) {
         super(ignoreNonExistingBaseDNs);
         this. = ignoreNonExistingBaseDNs;
     }
 
     @Override
     public void doSearch(
             final LdapContext initCtx,
             final List<StringbaseDNs,
             final String query,
             final SearchControls searchControls,
             final SearchResultsHandler handler)
             throws NamingException {
 
         if (.isOk()) {
             .ok("Searching in {0} with filter {1} and {2}",
                     baseDNsquerysearchControlsToString(searchControls));
         }
 
         Iterator<StringbaseDNIter = baseDNs.iterator();
         boolean proceed = true;
 
         while (baseDNIter.hasNext() && proceed) {
             String baseDN = baseDNIter.next();
 
             NamingEnumeration<SearchResultresults;
             try {
                 results = initCtx.search(baseDNquerysearchControls);
             } catch (NameNotFoundException e) {
                 if (!) {
                     throw e;
                 }
                 .warn(enull);
                 continue;
            } catch (InvalidNameException e) {
                if (!) {
                    throw e;
                }
                .warn(enull);
                continue;
            }
            try {
                // hasMore call for referral resolution ... it fails with AD
                // while (proceed && results.hasMore()) {
                while (proceed && results.hasMoreElements()) {
                    proceed = handler.handle(baseDNresults.next());
                }
            } finally {
                results.close();
            }
        }
    }
New to GrepCode? Check out our FAQ X