Class DistinguishedName
- All Implemented Interfaces:
Serializable,Cloneable,Comparable<Object>,Name
Name corresponding to an LDAP path. A Distinguished
Name manipulation implementation is included in JDK1.5 (LdapName), but not in prior
releases.
A DistinguishedName is particularly useful when building or modifying an
LDAP path dynamically, as escaping will be taken care of.
A path is split into several names. The Name interface specifies that the most
significant part be in position 0.
Example:
- The path
- uid=adam.skogman, ou=People, ou=EU
- Name[0]
- ou=EU
- Name[1]
- ou=People
- Name[2]
- uid=adam.skogman
Name instances, and consequently DistinguishedName instances
are naturally mutable, which is useful when constructing DistinguishedNames. Example:
DistinguishedName path = new DistinguishedName("dc=jayway,dc=se");
path.add("ou", "People");
path.add("uid", "adam.skogman");
String dn = path.toString();
will render uid=adam.skogman,ou=People,dc=jayway,dc=se.
NOTE: The fact that DistinguishedName instances are mutable needs to be taken
into careful account, as this means that they may be modified involuntarily. This means
that whenever a DistinguishedName instance is kept for reference (e.g. for
identification of a domain entry) or as a constant, you should consider getting an
immutable copy of the instance using immutableDistinguishedName() or
immutableDistinguishedName(String).
NB:As of version 1.3 the default toString representation of DistinguishedName
now defaults to a compact one, without spaces between the respective RDNs. For backward
compatibility, set the SPACED_DN_FORMAT_PROPERTY
("org.springframework.ldap.core.spacedDnFormat") to true.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final DistinguishedNameDeprecated.An empty, unmodifiable DistinguishedName.static final StringDeprecated.static final StringDeprecated.static final StringDeprecated.System property that will be inspected to determine whether creating a DistinguishedName will convert the keys to lowercase, convert the keys to uppercase, or leave the keys as they were in the original String, ie none.static final StringDeprecated.static final StringDeprecated.System property that will be inspected to determine whethertoString()will format the DN with spaces after each comma or use a more compact representation, i.e.:uid=adam.skogman, ou=People, dc=jayway, dc=serather thanuid=adam.skogman,ou=People,dc=jayway,dc=se. -
Constructor Summary
ConstructorsConstructorDescriptionDeprecated.Construct a new DistinguishedName with no components.DistinguishedName(String path) Deprecated.Construct a newDistinguishedNamefrom a String.DistinguishedName(List list) Deprecated.DistinguishedName(Name name) Deprecated.Construct a newDistinguishedNamefrom the suppliedName. -
Method Summary
Modifier and TypeMethodDescriptionDeprecated.voidDeprecated.Add the suppliedLdapRdnatt the specified index.Deprecated.voidDeprecated.Add a newLdapRdnusing the supplied key and value.voidDeprecated.Add the suppliedLdapRdnlast in the list of Rdns.Deprecated.Deprecated.Deprecated.Append a newLdapRdnusing the supplied key and value.append(DistinguishedName path) Deprecated.Add an LDAP path last in this DistinguishedName.clone()Deprecated.intDeprecated.Compare this instance to another object.booleancontains(DistinguishedName path) Deprecated.Determines if thisDistinguishedNamepath contains another path.encode()Deprecated.Builds a complete LDAP path, ldap encoded, useful as a DN.booleanDeprecated.Determines if thisDistinguishedNameends with a certian path.booleanDeprecated.get(int index) Deprecated.getAll()Deprecated.getLdapRdn(int index) Deprecated.Get theLdapRdnat a specified position.getLdapRdn(String key) Deprecated.Get theLdapRdnwith the specified key.getNames()Deprecated.Get the nameList.getPrefix(int index) Deprecated.getSuffix(int index) Deprecated.Deprecated.Get the value of theLdapRdnComponentwith the specified key (Attribute value).inthashCode()Deprecated.Deprecated.Return an immutable copy of this instance.static final DistinguishedNameimmutableDistinguishedName(String dnString) Deprecated.Create an immutable DistinguishedName instance, suitable as a constant.booleanisEmpty()Deprecated.protected final voidDeprecated.Parse the supplied String and make this instance represent the corresponding distinguished name.voidprepend(DistinguishedName path) Deprecated.Add an LDAP path first in this DistinguishedName.remove(int arg0) Deprecated.Deprecated.Remove the first part of thisDistinguishedName.voidremoveFirst(Name path) Deprecated.Remove the supplied path from the beginning of thisDistinguishedNameif this instance starts withpath.Deprecated.Remove the last part of thisDistinguishedName.intsize()Deprecated.booleanstartsWith(Name name) Deprecated.Deprecated.Get the compact String representation of thisDistinguishedName.toString()Deprecated.Get the String representation of thisDistinguishedName.toUrl()Deprecated.Builds a complete LDAP path, ldap and url encoded.
-
Field Details
-
SPACED_DN_FORMAT_PROPERTY
Deprecated.System property that will be inspected to determine whethertoString()will format the DN with spaces after each comma or use a more compact representation, i.e.:uid=adam.skogman, ou=People, dc=jayway, dc=serather thanuid=adam.skogman,ou=People,dc=jayway,dc=se. A value other than null or blank will trigger the spaced format. Default is the compact representation.Valid values are:
- blank or null (property not set)
- any non-blank value
- Since:
- 1.3
- See Also:
-
KEY_CASE_FOLD_PROPERTY
Deprecated.System property that will be inspected to determine whether creating a DistinguishedName will convert the keys to lowercase, convert the keys to uppercase, or leave the keys as they were in the original String, ie none. Default is to convert the keys to lowercase.Valid values are:
- "lower" or blank or null (property not set)
- "upper"
- "none"
- Since:
- 1.3.1
- See Also:
-
KEY_CASE_FOLD_LOWER
Deprecated.- See Also:
-
KEY_CASE_FOLD_UPPER
Deprecated.- See Also:
-
KEY_CASE_FOLD_NONE
Deprecated.- See Also:
-
EMPTY_PATH
Deprecated.An empty, unmodifiable DistinguishedName.
-
-
Constructor Details
-
DistinguishedName
public DistinguishedName()Deprecated.Construct a new DistinguishedName with no components. -
DistinguishedName
Deprecated.Construct a newDistinguishedNamefrom a String.- Parameters:
path- a String corresponding to a (syntactically) valid LDAP path.
-
DistinguishedName
Deprecated.- Parameters:
list- the components that this instance will consist of.
-
DistinguishedName
Deprecated.Construct a newDistinguishedNamefrom the suppliedName. The parts of the suppliedNamemust be syntactically correctLdapRdns.- Parameters:
name- theNameto construct a newDistinguishedNamefrom.
-
-
Method Details
-
parse
Deprecated.Parse the supplied String and make this instance represent the corresponding distinguished name.- Parameters:
path- the LDAP path to parse.
-
getLdapRdn
Deprecated.Get theLdapRdnat a specified position. -
getLdapRdn
Deprecated.Get theLdapRdnwith the specified key. If there are severalRdns with the same key, the first one found (in order of significance) will be returned.- Parameters:
key- Attribute name of theLdapRdnto retrieve.- Returns:
- the
LdapRdnwith the requested key. - Throws:
IllegalArgumentException- if no Rdn matches the given key.
-
getValue
Deprecated.Get the value of theLdapRdnComponentwith the specified key (Attribute value). If there are several Rdns with the same key, the value of the first one found (in order of significance) will be returned.- Parameters:
key- Attribute name of theLdapRdnto retrieve.- Returns:
- the value.
- Throws:
IllegalArgumentException- if no Rdn matches the given key.
-
getNames
Deprecated.Get the nameList.- Returns:
- the list of
LdapRdns that thisDistinguishedNameconsists of.
-
toCompactString
Deprecated.Get the compact String representation of thisDistinguishedName. Add no space after each comma, to make it compact.- Returns:
- a syntactically correct, properly escaped String representation of the
DistinguishedName.
-
encode
Deprecated.Builds a complete LDAP path, ldap encoded, useful as a DN. Always uses lowercase, always separates with ", " i.e. comma and a space.- Returns:
- the LDAP path.
-
toUrl
Deprecated.Builds a complete LDAP path, ldap and url encoded. Separates only with ",".- Returns:
- the LDAP path, for use in an url.
-
contains
Deprecated.Determines if thisDistinguishedNamepath contains another path.- Parameters:
path- the path to check.- Returns:
trueif the supplied path is conained in this instance,falseotherwise.
-
append
Deprecated.Add an LDAP path last in this DistinguishedName. E.g.:DistinguishedName name1 = new DistinguishedName("c=SE, dc=jayway, dc=se"); DistinguishedName name2 = new DistinguishedName("ou=people"); name1.append(name2);will result inou=people, c=SE, dc=jayway, dc=se- Parameters:
path- the path to append.- Returns:
- this instance.
-
append
Deprecated.Append a newLdapRdnusing the supplied key and value. -
prepend
Deprecated.Add an LDAP path first in this DistinguishedName. E.g.:DistinguishedName name1 = new DistinguishedName("ou=people"); DistinguishedName name2 = new DistinguishedName("c=SE, dc=jayway, dc=se"); name1.prepend(name2);will result inou=people, c=SE, dc=jayway, dc=se- Parameters:
path- the path to prepend.
-
removeFirst
Deprecated.Remove the first part of thisDistinguishedName.- Returns:
- the removed entry.
-
removeFirst
Deprecated.Remove the supplied path from the beginning of thisDistinguishedNameif this instance starts withpath. Useful for stripping base path suffix from aDistinguishedName.- Parameters:
path- the path to remove from the beginning of this instance.
-
clone
Deprecated. -
equals
Deprecated. -
hashCode
public int hashCode()Deprecated. -
toString
Deprecated.Get the String representation of thisDistinguishedName. Depending on the setting of propertyorg.springframework.ldap.core.spacedDnFormata space will be added after each comma, to make the result more readable. Default is compact representation, i.e. without any spaces. -
compareTo
Deprecated.Compare this instance to another object. Note that the comparison is done in order of significance, so the most significant Rdn is compared first, then the second and so on.- Specified by:
compareToin interfaceComparable<Object>- Specified by:
compareToin interfaceName- See Also:
-
size
public int size()Deprecated. -
isEmpty
public boolean isEmpty()Deprecated. -
getAll
Deprecated. -
get
Deprecated. -
getPrefix
Deprecated. -
getSuffix
Deprecated. -
startsWith
Deprecated.- Specified by:
startsWithin interfaceName
-
endsWith
Deprecated.Determines if thisDistinguishedNameends with a certian path. If the argument path is empty (no names in path) this method will returnfalse. -
addAll
Deprecated.- Specified by:
addAllin interfaceName- Throws:
InvalidNameException
-
addAll
Deprecated.- Specified by:
addAllin interfaceName- Throws:
InvalidNameException
-
add
Deprecated.- Specified by:
addin interfaceName- Throws:
InvalidNameException
-
add
Deprecated.- Specified by:
addin interfaceName- Throws:
InvalidNameException
-
remove
Deprecated.- Specified by:
removein interfaceName- Throws:
InvalidNameException
-
removeLast
Deprecated.Remove the last part of thisDistinguishedName.- Returns:
- the removed
LdapRdn.
-
add
Deprecated.Add a newLdapRdnusing the supplied key and value. -
add
Deprecated.Add the suppliedLdapRdnlast in the list of Rdns.- Parameters:
rdn- theLdapRdnto add.
-
add
Deprecated.Add the suppliedLdapRdnatt the specified index.- Parameters:
idx- the index at which to add the LdapRdn.rdn- the LdapRdn to add.
-
immutableDistinguishedName
Deprecated.Return an immutable copy of this instance. It will not be possible to add or remove any Rdns to or from the returned instance, and the respective Rdns will also be immutable in turn.- Returns:
- a copy of this instance backed by an immutable list.
- Since:
- 1.2
-
immutableDistinguishedName
Deprecated.Create an immutable DistinguishedName instance, suitable as a constant.- Parameters:
dnString- the DN string to parse.- Returns:
- an immutable DistinguishedName corresponding to the supplied DN string.
- Since:
- 1.3
-
LdapNamealong with utility methods inLdapUtilsinstead.