/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- * * The contents of this file are subject to the Netscape Public * License Version 1.1 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.mozilla.org/NPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1999 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): */ package netscape.ldap; import java.util.*; /** * Represents an entry in the directory. * * @version 1.0 */ public class LDAPEntry implements java.io.Serializable { static final long serialVersionUID = -5563306228920012807L; private String dn = null; private LDAPAttributeSet attrSet = null; /** * Constructs an empty entry. */ public LDAPEntry() { dn = null; attrSet = new LDAPAttributeSet(); } /** * Constructs a new entry with the specified distinguished name and with * an empty attribute set. * @param distinguishedName the distinguished name of the new entry */ public LDAPEntry( String distinguishedName ) { dn = distinguishedName; attrSet = new LDAPAttributeSet(); } /** * Constructs a new entry with the specified distinguished name and * set of attributes. * @param distinguishedName the distinguished name of the new entry * @param attrs the set of attributes to assign to the new entry * @see netscape.ldap.LDAPAttributeSet */ public LDAPEntry( String distinguishedName, LDAPAttributeSet attrs ) { dn = distinguishedName; attrSet = attrs; } /** * Returns the distinguished name of the current entry. * @return distinguished name of the current entry. */ public String getDN() { return dn; } void setDN(String name) { dn = name; } /** * Returns the attribute set of the entry. * @return set of attributes in the entry. * @see netscape.ldap.LDAPAttributeSet */ public LDAPAttributeSet getAttributeSet() { return attrSet; } /** * Creates a new attribute set containing only the attributes * that have the specified subtypes. *
* * For example, suppose an entry contains the following attributes: *
* *
* cn
* cn;lang-ja
* sn;phonetic;lang-ja
* sn;lang-us
*
*
* If you call the getAttributeSet method and pass
* lang-ja as the argument, the method returns
* an attribute set containing the following attributes:
* * *
* cn;lang-ja
* sn;phonetic;lang-ja
*
*
* @param subtype semi-colon delimited list of subtypes
* that you want to find in attribute names.
*
* "lang-ja" // Only Japanese language subtypes
* "binary" // Only binary subtypes
* "binary;lang-ja" // Only Japanese language subtypes
* which also are binary
*
* @return attribute set containing the attributes that have
* the specified subtypes.
* @see netscape.ldap.LDAPAttributeSet
* @see netscape.ldap.LDAPAttributeSet#getSubset
*/
public LDAPAttributeSet getAttributeSet(String subtype) {
return attrSet.getSubset(subtype);
}
/**
* In an entry, returns the single attribute that exactly matches the
* specified attribute name.
* @param attrName name of attribute to return
* For example:
*
* "cn" // Only a non-subtyped version of cn
* "cn;lang-ja" // Only a Japanese version of cn, will not
* // return "cn;lang-ja-JP-kanji", for example
*
* @return attribute in the current entry that has exactly the same name,
* or null (if no attribute in the entry matches the specified name).
* @see netscape.ldap.LDAPAttribute
*/
public LDAPAttribute getAttribute(String attrName) {
return attrSet.getAttribute(attrName);
}
/**
* Returns the subtype that matches "attrName" and that best matches
* a language specification "lang". If there are subtypes other than
* "lang" subtypes included in attrName, e.g. "cn;binary", only
* attributes with all of those subtypes are returned. If lang is
* null or empty, the method behaves as getAttribute(attrName). If
* there are no matching attributes, null is returned.
*
* Example:
* Assume the entry contains only the following attributes:
* cn;lang-en
* cn;lang-ja-JP-kanji
* sn
* getAttribute( "cn" ) returns null.
* getAttribute( "sn" ) returns the "sn" attribute.
* getAttribute( "cn", "lang-en-us" ) returns the "cn;lang-en" attribute.
* getAttribute( "cn", "lang-en" ) returns the "cn;lang-en" attribute.
* getAttribute( "cn", "lang-ja" ) returns null.
* getAttribute( "sn", "lang-en" ) returns the "sn" attribute.
*
*
* @param attrName name of attribute to find in the entry
* @param lang a language specification (for example, lang-en)
* @return the attribute that matches the base name and that best
* matches any specified language subtype.
* @see netscape.ldap.LDAPAttribute
*/
public LDAPAttribute getAttribute( String attrName, String lang ) {
return attrSet.getAttribute( attrName, lang );
}
/**
* Retrieves the string representation of the entry's
* distinguished name (DN) and its attributes.
* For example:
*
*
* LDAPEntry: uid=bjensen, ou=People, o=airius.com; LDAPAttributeSet:
* LDAPAttribute {type='cn', values='Barbara Jensen,Babs Jensen'}
* LDAPAttribute {type='sn', values='Jensen'}LDAPAttribute {type='givenname',
* values='Barbara'}LDAPAttribute {type='objectclass', values='top,person,
* organizationalPerson,inetOrgPerson'}LDAPAttribute {type='ou',
* values='Product Development,People'}
*
*
* @return string representation of the entry's DN and its attributes.
*/
public String toString() {
StringBuffer sb = new StringBuffer("LDAPEntry: ");
if ( dn != null ) {
sb.append(dn);
sb.append("; ");
}
if ( attrSet != null ) {
sb.append(attrSet.toString());
}
return sb.toString();
}
}