From 609077ed606e3b094e303f298e8dca10567bc3e2 Mon Sep 17 00:00:00 2001
From: Jean-Noël Rouvignac <jean-noel.rouvignac@forgerock.com>
Date: Fri, 05 Aug 2016 18:42:07 +0000
Subject: [PATCH] Partial OPENDJ-2625 Convert all code that uses JNDI to use the SDK instead
---
opendj-server-legacy/src/main/java/org/opends/admin/ads/util/PreferredConnection.java | 36 ++++++++++++++++++++++++++----------
1 files changed, 26 insertions(+), 10 deletions(-)
diff --git a/opendj-server-legacy/src/main/java/org/opends/admin/ads/util/PreferredConnection.java b/opendj-server-legacy/src/main/java/org/opends/admin/ads/util/PreferredConnection.java
index 89a7466..93051d8 100644
--- a/opendj-server-legacy/src/main/java/org/opends/admin/ads/util/PreferredConnection.java
+++ b/opendj-server-legacy/src/main/java/org/opends/admin/ads/util/PreferredConnection.java
@@ -16,9 +16,14 @@
*/
package org.opends.admin.ads.util;
+import static org.opends.admin.ads.util.PreferredConnection.Type.*;
+
import java.util.Collections;
+import java.util.Objects;
import java.util.Set;
+import org.opends.server.types.HostPort;
+
/**
* A simple class that is used to be able to specify which URL and connection
* type to use when we connect to a server.
@@ -36,18 +41,18 @@
START_TLS
}
- private final String ldapUrl;
+ private final HostPort hostPort;
private final Type type;
/**
* The constructor of the PreferredConnection.
- * @param ldapUrl the LDAP URL to connect to the server.
+ * @param hostPort the host and port to connect to the server.
* @param type the type of connection to be used to connect (required to
* differentiate StartTLS and regular LDAP).
*/
- public PreferredConnection(String ldapUrl, Type type)
+ public PreferredConnection(HostPort hostPort, Type type)
{
- this.ldapUrl = ldapUrl;
+ this.hostPort = hostPort;
this.type = type;
}
@@ -57,11 +62,22 @@
*/
public String getLDAPURL()
{
- return ldapUrl;
+ return (type == LDAPS ? "ldaps" : "ldap") + "://" + hostPort;
+ }
+
+ /**
+ * Returns the host name and port number.
+ *
+ * @return the hostPort
+ */
+ public HostPort getHostPort()
+ {
+ return hostPort;
}
/**
* Returns the type of the connection.
+ *
* @return the type of the connection.
*/
public Type getType()
@@ -72,7 +88,7 @@
@Override
public int hashCode()
{
- return (type + ldapUrl.toLowerCase()).hashCode();
+ return Objects.hash(type, hostPort);
}
@Override
@@ -85,8 +101,8 @@
if (o instanceof PreferredConnection)
{
PreferredConnection p = (PreferredConnection)o;
- return type == p.type
- && ldapUrl.equalsIgnoreCase(p.getLDAPURL());
+ return Objects.equals(type, p.type)
+ && Objects.equals(hostPort, p.hostPort);
}
return false;
}
@@ -94,7 +110,7 @@
@Override
public String toString()
{
- return type + ": " + ldapUrl;
+ return getLDAPURL();
}
/**
@@ -105,7 +121,7 @@
*/
private static PreferredConnection getPreferredConnection(ConnectionWrapper conn)
{
- return new PreferredConnection(conn.getLdapUrl(), conn.getConnectionType());
+ return new PreferredConnection(conn.getHostPort(), conn.getConnectionType());
}
/**
--
Gitblit v1.10.0