/*
|
* The contents of this file are subject to the terms of the Common Development and
|
* Distribution License (the License). You may not use this file except in compliance with the
|
* License.
|
*
|
* You can obtain a copy of the License at legal/CDDLv1.0.txt. See the License for the
|
* specific language governing permission and limitations under the License.
|
*
|
* When distributing Covered Software, include this CDDL Header Notice in each file and include
|
* the License file at legal/CDDLv1.0.txt. If applicable, add the following below the CDDL
|
* Header, with the fields enclosed by brackets [] replaced by your own identifying
|
* information: "Portions Copyright [year] [name of copyright owner]".
|
*
|
* Copyright 2008-2010 Sun Microsystems, Inc.
|
* Portions Copyright 2012-2016 ForgeRock AS.
|
*/
|
package org.opends.admin.ads.util;
|
|
import java.util.Collections;
|
import java.util.Set;
|
|
import org.forgerock.opendj.ldap.DN;
|
import org.forgerock.opendj.ldap.Entry;
|
import org.forgerock.opendj.ldap.responses.SearchResultEntry;
|
import org.opends.server.types.HostPort;
|
|
import com.forgerock.opendj.cli.Utils;
|
|
/**
|
* Class providing some utilities to create LDAP connections using JNDI and
|
* to manage entries retrieved using JNDI.
|
*/
|
public class ConnectionUtils
|
{
|
/** Private constructor: this class cannot be instantiated. */
|
private ConnectionUtils()
|
{
|
}
|
|
/**
|
* Returns the LDAP URL for the provided parameters.
|
* @param hostPort the host name and LDAP port.
|
* @param useLdaps whether to use LDAPS.
|
* @return the LDAP URL for the provided parameters.
|
*/
|
public static String getLDAPUrl(HostPort hostPort, boolean useLdaps)
|
{
|
return getLDAPUrl(hostPort.getHost(), hostPort.getPort(), useLdaps);
|
}
|
|
/**
|
* Returns the LDAP URL for the provided parameters.
|
* @param host the host name.
|
* @param port the LDAP port.
|
* @param useLdaps whether to use LDAPS.
|
* @return the LDAP URL for the provided parameters.
|
*/
|
public static String getLDAPUrl(String host, int port, boolean useLdaps)
|
{
|
host = Utils.getHostNameForLdapUrl(host);
|
return (useLdaps ? "ldaps" : "ldap") + "://" + host + ":" + port;
|
}
|
|
/**
|
* Returns the first attribute value in this attribute decoded as a UTF-8 string.
|
*
|
* @param sr
|
* the search result entry
|
* @param attrDesc
|
* the attribute description
|
* @return The first attribute value in this attribute decoded as a UTF-8 string.
|
*/
|
public static String firstValueAsString(Entry sr, String attrDesc)
|
{
|
org.forgerock.opendj.ldap.Attribute attr = sr.getAttribute(attrDesc);
|
return (attr != null && !attr.isEmpty()) ? attr.firstValueAsString() : null;
|
}
|
|
/**
|
* Returns the first value decoded as an Integer, or {@code null} if the attribute does not
|
* contain any values.
|
*
|
* @param sr
|
* the search result entry
|
* @param attrDesc
|
* the attribute description
|
* @return The first value decoded as an Integer.
|
*/
|
public static Integer asInteger(SearchResultEntry sr, String attrDesc)
|
{
|
org.forgerock.opendj.ldap.Attribute attr = sr.getAttribute(attrDesc);
|
return attr != null ? attr.parse().asInteger() : null;
|
}
|
|
/**
|
* Returns the first value decoded as a Boolean, or {@code null} if the attribute does not contain
|
* any values.
|
*
|
* @param sr
|
* the search result entry
|
* @param attrDesc
|
* the attribute description
|
* @return The first value decoded as an Boolean.
|
*/
|
public static Boolean asBoolean(SearchResultEntry sr, String attrDesc)
|
{
|
org.forgerock.opendj.ldap.Attribute attr = sr.getAttribute(attrDesc);
|
return attr != null ? attr.parse().asBoolean() : null;
|
}
|
|
/**
|
* Returns the values decoded as a set of Strings.
|
*
|
* @param sr
|
* the search result entry
|
* @param attrDesc
|
* the attribute description
|
* @return The values decoded as a set of Strings. Never {@code null} and never contains
|
* {@code null} values.
|
*/
|
public static Set<String> asSetOfString(SearchResultEntry sr, String attrDesc)
|
{
|
org.forgerock.opendj.ldap.Attribute attr = sr.getAttribute(attrDesc);
|
return attr != null ? attr.parse().asSetOfString() : Collections.<String> emptySet();
|
}
|
|
/**
|
* Returns the values decoded as a set of DNs.
|
*
|
* @param sr
|
* the search result entry
|
* @param attrDesc
|
* the attribute description
|
* @return The values decoded as a set of DNs. Never {@code null} and never contains {@code null}
|
* values.
|
*/
|
public static Set<DN> asSetOfDN(SearchResultEntry sr, String attrDesc)
|
{
|
org.forgerock.opendj.ldap.Attribute attr = sr.getAttribute(attrDesc);
|
return attr != null ? attr.parse().asSetOfDN() : Collections.<DN> emptySet();
|
}
|
}
|