- /*
- * @(#)DirContext.java 1.8 01/02/09
- *
- * Copyright 1999-2001 Sun Microsystems, Inc. All Rights Reserved.
- *
- * This software is the proprietary information of Sun Microsystems, Inc.
- * Use is subject to license terms.
- *
- */
-
- package javax.naming.directory;
-
- import javax.naming.*;
-
- /**
- * The directory service interface, containing
- * methods for examining and updating attributes
- * associated with objects, and for searching the directory.
- * <p>
- * <h4>Names</h4>
- * Each name passed as an argument to a <tt>DirContext</tt> method is relative
- * to that context. The empty name is used to name the context itself.
- * The name parameter may never be null.
- * <p>
- * Most of the methods have overloaded versions with one taking a
- * <code>Name</code> parameter and one taking a <code>String</code>.
- * These overloaded versions are equivalent in that if
- * the <code>Name</code> and <code>String</code> parameters are just
- * different representations of the same name, then the overloaded
- * versions of the same methods behave the same.
- * In the method descriptions below, only one version is documented.
- * The second version instead has a link to the first: the same
- * documentation applies to both.
- * <p>
- * See <tt>Context</tt> for a discussion on the interpretation of the
- * name argument to the <tt>Context</tt> methods. These same rules
- * apply to the name argument to the <tt>DirContext</tt> methods.
- * <p>
- * <h4>Attribute Models</h4>
- * There are two basic models of what attributes should be
- * associated with. First, attributes may be directly associated with a
- * DirContext object.
- * In this model, an attribute operation on the named object is
- * roughly equivalent
- * to a lookup on the name (which returns the DirContext object),
- * followed by the attribute operation invoked on the DirContext object
- * in which the caller supplies an empty name. The attributes can be viewed
- * as being stored along with the object (note that this does not imply that
- * the implementation must do so).
- * <p>
- * The second model is that attributes are associated with a
- * name (typically an atomic name) in a DirContext.
- * In this model, an attribute operation on the named object is
- * roughly equivalent to a lookup on the name of the parent DirContext of the
- * named object, followed by the attribute operation invoked on the parent
- * in which the caller supplies the terminal atomic name.
- * The attributes can be viewed as being stored in the parent DirContext
- * (again, this does not imply that the implementation must do so).
- * Objects that are not DirContexts can have attributes, as long as
- * their parents are DirContexts.
- * <p>
- * JNDI support both of these models.
- * It is up to the individual service providers to decide where to
- * "store" attributes.
- * JNDI clients are safest when they do not make assumptions about
- * whether an object's attributes are stored as part of the object, or stored
- * within the parent object and associated with the object's name.
- * <p>
- * <h4>Attribute Type Names</h4>
- * In the <tt>getAttributes()</tt> and <tt>search()</tt> methods,
- * you can supply the attributes to return by supplying a list of
- * attribute names (strings).
- * The attributes that you get back might not have the same names as the
- * attribute names you have specified. This is because some directories
- * support features that cause them to return other attributes. Such
- * features include attribute subclassing, attribute name synonyms, and
- * attribute language codes.
- * <p>
- * In attribute subclassing, attributes are defined in a class hierarchy.
- * In some directories, for example, the "name" attribute might be the
- * superclass of all name-related attributes, including "commonName" and
- * "surName". Asking for the "name" attribute might return both the
- * "commonName" and "surName" attributes.
- * <p>
- * With attribute type synonyms, a directory can assign multiple names to
- * the same attribute. For example, "cn" and "commonName" might both
- * refer to the same attribute. Asking for "cn" might return the
- * "commonName" attribute.
- * <p>
- * Some directories support the language codes for attributes.
- * Asking such a directory for the "description" attribute, for example,
- * might return all of the following attributes:
- * <ul>
- * <li>description
- * <li>description;lang-en
- * <li>description;lang-de
- * <li>description;lang-fr
- * </ul>
- *
- * <p>
- *<h4>Operational Attributes</h4>
- *<p>
- * Some directories have the notion of "operational attributes" which are
- * attributes associated with a directory object for administrative
- * purposes. An example of operational attributes is the access control
- * list for an object.
- * <p>
- * In the <tt>getAttributes()</tt> and <tt>search()</tt> methods,
- * you can specify that all attributes associated with the requested objects
- * be returned by supply <tt>null</tt> as the list of attributes to return.
- * The attributes returned do <em>not</em> include operational attributes.
- * In order to retrieve operational attributes, you must name them explicitly.
- *
- * <p>
- * <h4>Named Context</h4>
- * <p>
- * There are certain methods in which the name must resolve to a context
- * (for example, when searching a single level context). The documentation
- * of such methods
- * use the term <em>named context</em> to describe their name parameter.
- * For these methods, if the named object is not a DirContext,
- * <code>NotContextException</code> is thrown.
- * Aside from these methods, there is no requirement that the
- * <em>named object</em> be a DirContext.
- *<p>
- *<h4>Parameters</h4>
- *<p>
- * An <tt>Attributes</tt>, <tt>SearchControls</tt>, or array object
- * passed as a parameter to any method will not be modified by the
- * service provider. The service provider may keep a reference to it
- * for the duration of the operation, including any enumeration of the
- * method's results and the processing of any referrals generated.
- * The caller should not modify the object during this time.
- * An <tt>Attributes</tt> object returned by any method is owned by
- * the caller. The caller may subsequently modify it; the service
- * provider will not.
- *<p>
- *<h4>Exceptions</h4>
- *<p>
- * All the methods in this interface can throw a NamingException or
- * any of its subclasses. See NamingException and their subclasses
- * for details on each exception.
- *
- * @author Rosanna Lee
- * @author Scott Seligman
- * @author R. Vasudevan
- * @version 1.8 01/02/09
- *
- * @see javax.naming.Context
- * @since 1.3
- */
-
- public interface DirContext extends Context {
-
- /**
- * Retrieves all of the attributes associated with a named object.
- * See the class description regarding attribute models, attribute
- * type names, and operational attributes.
- *
- * @param name
- * the name of the object from which to retrieve attributes
- * @return the set of attributes associated with <code>name</code>.
- * Returns an empty attribute set if name has no attributes;
- * never null.
- * @throws NamingException if a naming exception is encountered
- *
- * @see #getAttributes(String)
- * @see #getAttributes(Name, String[])
- */
- public Attributes getAttributes(Name name) throws NamingException;
-
- /**
- * Retrieves all of the attributes associated with a named object.
- * See {@link #getAttributes(Name)} for details.
- *
- * @param name
- * the name of the object from which to retrieve attributes
- * @return the set of attributes associated with <code>name</code>
- *
- * @throws NamingException if a naming exception is encountered
- */
- public Attributes getAttributes(String name) throws NamingException;
-
- /**
- * Retrieves selected attributes associated with a named object.
- * See the class description regarding attribute models, attribute
- * type names, and operational attributes.
- *
- * <p> If the object does not have an attribute
- * specified, the directory will ignore the nonexistent attribute
- * and return those requested attributes that the object does have.
- *
- * <p> A directory might return more attributes than was requested
- * (see <strong>Attribute Type Names</strong> in the class description),
- * but is not allowed to return arbitrary, unrelated attributes.
- *
- * <p> See also <strong>Operational Attributes</strong> in the class
- * description.
- *
- * @param name
- * the name of the object from which to retrieve attributes
- * @param attrIds
- * the identifiers of the attributes to retrieve.
- * null indicates that all attributes should be retrieved;
- * an empty array indicates that none should be retrieved.
- * @return the requested attributes; never null
- *
- * @throws NamingException if a naming exception is encountered
- */
- public Attributes getAttributes(Name name, String[] attrIds)
- throws NamingException;
-
- /**
- * Retrieves selected attributes associated with a named object.
- * See {@link #getAttributes(Name, String[])} for details.
- *
- * @param name
- * The name of the object from which to retrieve attributes
- * @param attrIds
- * the identifiers of the attributes to retrieve.
- * null indicates that all attributes should be retrieved;
- * an empty array indicates that none should be retrieved.
- * @return the requested attributes; never null
- *
- * @throws NamingException if a naming exception is encountered
- */
- public Attributes getAttributes(String name, String[] attrIds)
- throws NamingException;
-
- /**
- * This constant specifies to add an attribute with the specified values.
- * <p>
- * If attribute does not exist,
- * create the attribute. The resulting attribute has a union of the
- * specified value set and the prior value set.
- * Adding an attribute with no value will throw
- * <code>InvalidAttributeValueException</code> if the attribute must have
- * at least one value. For a single-valued attribute where that attribute
- * already exists, throws <code>AttributeInUseException</code>.
- * If attempting to add more than one value to a single-valued attribute,
- * throws <code>InvalidAttributeValueException</code>.
- * <p>
- * The value of this constant is <tt>1</tt>.
- *
- * @see ModificationItem
- * @see #modifyAttributes
- */
- public final static int ADD_ATTRIBUTE = 1;
-
- /**
- * This constant specifies to replace an attribute with specified values.
- *<p>
- * If attribute already exists,
- * replaces all existing values with new specified values. If the
- * attribute does not exist, creates it. If no value is specified,
- * deletes all the values of the attribute.
- * Removal of the last value will remove the attribute if the attribute
- * is required to have at least one value. If
- * attempting to add more than one value to a single-valued attribute,
- * throws <code>InvalidAttributeValueException</code>.
- * <p>
- * The value of this constant is <tt>2</tt>.
- *
- * @see ModificationItem
- * @see #modifyAttributes
- */
- public final static int REPLACE_ATTRIBUTE = 2;
-
- /**
- * This constant specifies to delete
- * the specified attribute values from the attribute.
- *<p>
- * The resulting attribute has the set difference of its prior value set
- * and the specified value set.
- * If no values are specified, deletes the entire attribute.
- * If the attribute does not exist, or if some or all members of the
- * specified value set do not exist, this absence may be ignored
- * and the operation succeeds, or a NamingException may be thrown to
- * indicate the absence.
- * Removal of the last value will remove the attribute if the
- * attribute is required to have at least one value.
- * <p>
- * The value of this constant is <tt>3</tt>.
- *
- * @see ModificationItem
- * @see #modifyAttributes
- */
- public final static int REMOVE_ATTRIBUTE = 3;
-
- /**
- * Modifies the attributes associated with a named object.
- * The order of the modifications is not specified. Where
- * possible, the modifications are performed atomically.
- *
- * @param name
- * the name of the object whose attributes will be updated
- * @param mod_op
- * the modification operation, one of:
- * <code>ADD_ATTRIBUTE</code>,
- * <code>REPLACE_ATTRIBUTE</code>,
- * <code>REMOVE_ATTRIBUTE</code>.
- * @param attrs
- * the attributes to be used for the modification; may not be null
- *
- * @throws AttributeModificationException if the modification cannot
- * be completed successfully
- * @throws NamingException if a naming exception is encountered
- *
- * @see #modifyAttributes(Name, ModificationItem[])
- */
- public void modifyAttributes(Name name, int mod_op, Attributes attrs)
- throws NamingException;
-
- /**
- * Modifies the attributes associated with a named object.
- * See {@link #modifyAttributes(Name, int, Attributes)} for details.
- *
- * @param name
- * the name of the object whose attributes will be updated
- * @param mod_op
- * the modification operation, one of:
- * <code>ADD_ATTRIBUTE</code>,
- * <code>REPLACE_ATTRIBUTE</code>,
- * <code>REMOVE_ATTRIBUTE</code>.
- * @param attrs
- * the attributes to be used for the modification; map not be null
- *
- * @throws AttributeModificationException if the modification cannot
- * be completed successfully
- * @throws NamingException if a naming exception is encountered
- */
- public void modifyAttributes(String name, int mod_op, Attributes attrs)
- throws NamingException;
-
- /**
- * Modifies the attributes associated with a named object using
- * an ordered list of modifications.
- * The modifications are performed
- * in the order specified. Each modification specifies a
- * modification operation code and an attribute on which to
- * operate. Where possible, the modifications are
- * performed atomically.
- *
- * @param name
- * the name of the object whose attributes will be updated
- * @param mods
- * an ordered sequence of modifications to be performed;
- * may not be null
- *
- * @throws AttributeModificationException if the modifications
- * cannot be completed successfully
- * @throws NamingException if a naming exception is encountered
- *
- * @see #modifyAttributes(Name, int, Attributes)
- * @see ModificationItem
- */
- public void modifyAttributes(Name name, ModificationItem[] mods)
- throws NamingException;
-
- /**
- * Modifies the attributes associated with a named object using
- * an ordered list of modifications.
- * See {@link #modifyAttributes(Name, ModificationItem[])} for details.
- *
- * @param name
- * the name of the object whose attributes will be updated
- * @param mods
- * an ordered sequence of modifications to be performed;
- * may not be null
- *
- * @throws AttributeModificationException if the modifications
- * cannot be completed successfully
- * @throws NamingException if a naming exception is encountered
- */
- public void modifyAttributes(String name, ModificationItem[] mods)
- throws NamingException;
-
- /**
- * Binds a name to an object, along with associated attributes.
- * If <tt>attrs</tt> is null, the resulting binding will have
- * the attributes associated with <tt>obj</tt> if <tt>obj</tt> is a
- * <tt>DirContext</tt>, and no attributes otherwise.
- * If <tt>attrs</tt> is non-null, the resulting binding will have
- * <tt>attrs</tt> as its attributes; any attributes associated with
- * <tt>obj</tt> are ignored.
- *
- * @param name
- * the name to bind; may not be empty
- * @param obj
- * the object to bind; possibly null
- * @param attrs
- * the attributes to associate with the binding
- *
- * @throws NameAlreadyBoundException if name is already bound
- * @throws InvalidAttributesException if some "mandatory" attributes
- * of the binding are not supplied
- * @throws NamingException if a naming exception is encountered
- *
- * @see Context#bind(Name, Object)
- * @see #rebind(Name, Object, Attributes)
- */
- public void bind(Name name, Object obj, Attributes attrs)
- throws NamingException;
-
- /**
- * Binds a name to an object, along with associated attributes.
- * See {@link #bind(Name, Object, Attributes)} for details.
- *
- * @param name
- * the name to bind; may not be empty
- * @param obj
- * the object to bind; possibly null
- * @param attrs
- * the attributes to associate with the binding
- *
- * @throws NameAlreadyBoundException if name is already bound
- * @throws InvalidAttributesException if some "mandatory" attributes
- * of the binding are not supplied
- * @throws NamingException if a naming exception is encountered
- */
- public void bind(String name, Object obj, Attributes attrs)
- throws NamingException;
-
- /**
- * Binds a name to an object, along with associated attributes,
- * overwriting any existing binding.
- * If <tt>attrs</tt> is null and <tt>obj</tt> is a <tt>DirContext</tt>,
- * the attributes from <tt>obj</tt> are used.
- * If <tt>attrs</tt> is null and <tt>obj</tt> is not a <tt>DirContext</tt>,
- * any existing attributes associated with the object already bound
- * in the directory remain unchanged.
- * If <tt>attrs</tt> is non-null, any existing attributes associated with
- * the object already bound in the directory are removed and <tt>attrs</tt>
- * is associated with the named object. If <tt>obj</tt> is a
- * <tt>DirContext</tt> and <tt>attrs</tt> is non-null, the attributes
- * of <tt>obj</tt> are ignored.
- *
- * @param name
- * the name to bind; may not be empty
- * @param obj
- * the object to bind; possibly null
- * @param attrs
- * the attributes to associate with the binding
- *
- * @throws InvalidAttributesException if some "mandatory" attributes
- * of the binding are not supplied
- * @throws NamingException if a naming exception is encountered
- *
- * @see Context#bind(Name, Object)
- * @see #bind(Name, Object, Attributes)
- */
- public void rebind(Name name, Object obj, Attributes attrs)
- throws NamingException;
-
- /**
- * Binds a name to an object, along with associated attributes,
- * overwriting any existing binding.
- * See {@link #rebind(Name, Object, Attributes)} for details.
- *
- * @param name
- * the name to bind; may not be empty
- * @param obj
- * the object to bind; possibly null
- * @param attrs
- * the attributes to associate with the binding
- *
- * @throws InvalidAttributesException if some "mandatory" attributes
- * of the binding are not supplied
- * @throws NamingException if a naming exception is encountered
- */
- public void rebind(String name, Object obj, Attributes attrs)
- throws NamingException;
-
- /**
- * Creates and binds a new context, along with associated attributes.
- * This method creates a new subcontext with the given name, binds it in
- * the target context (that named by all but terminal atomic
- * component of the name), and associates the supplied attributes
- * with the newly created object.
- * All intermediate and target contexts must already exist.
- * If <tt>attrs</tt> is null, this method is equivalent to
- * <tt>Context.createSubcontext()</tt>.
- *
- * @param name
- * the name of the context to create; may not be empty
- * @param attrs
- * the attributes to associate with the newly created context
- * @return the newly created context
- *
- * @throws NameAlreadyBoundException if the name is already bound
- * @throws InvalidAttributesException if <code>attrs</code> does not
- * contain all the mandatory attributes required for creation
- * @throws NamingException if a naming exception is encountered
- *
- * @see Context#createSubcontext(Name)
- */
- public DirContext createSubcontext(Name name, Attributes attrs)
- throws NamingException;
-
- /**
- * Creates and binds a new context, along with associated attributes.
- * See {@link #createSubcontext(Name, Attributes)} for details.
- *
- * @param name
- * the name of the context to create; may not be empty
- * @param attrs
- * the attributes to associate with the newly created context
- * @return the newly created context
- *
- * @throws NameAlreadyBoundException if the name is already bound
- * @throws InvalidAttributesException if <code>attrs</code> does not
- * contain all the mandatory attributes required for creation
- * @throws NamingException if a naming exception is encountered
- */
- public DirContext createSubcontext(String name, Attributes attrs)
- throws NamingException;
-
- // -------------------- schema operations
-
- /**
- * Retrieves the schema associated with the named object.
- * The schema describes rules regarding the structure of the namespace
- * and the attributes stored within it. The schema
- * specifies what types of objects can be added to the directory and where
- * they can be added; what mandatory and optional attributes an object
- * can have. The range of support for schemas is directory-specific.
- *
- * <p> This method returns the root of the schema information tree
- * that is applicable to the named object. Several named objects
- * (or even an entire directory) might share the same schema.
- *
- * <p> Issues such as structure and contents of the schema tree,
- * permission to modify to the contents of the schema
- * tree, and the effect of such modifications on the directory
- * are dependent on the underlying directory.
- *
- * @param name
- * the name of the object whose schema is to be retrieved
- * @return the schema associated with the context; never null
- * @throws OperationNotSupportedException if schema not supported
- * @throws NamingException if a naming exception is encountered
- */
- public DirContext getSchema(Name name) throws NamingException;
-
- /**
- * Retrieves the schema associated with the named object.
- * See {@link #getSchema(Name)} for details.
- *
- * @param name
- * the name of the object whose schema is to be retrieved
- * @return the schema associated with the context; never null
- * @throws OperationNotSupportedException if schema not supported
- * @throws NamingException if a naming exception is encountered
- */
- public DirContext getSchema(String name) throws NamingException;
-
- /**
- * Retrieves a context containing the schema objects of the
- * named object's class definitions.
- *<p>
- * One category of information found in directory schemas is
- * <em>class definitions</em>. An "object class" definition
- * specifies the object's <em>type</em> and what attributes (mandatory
- * and optional) the object must/can have. Note that the term
- * "object class" being referred to here is in the directory sense
- * rather than in the Java sense.
- * For example, if the named object is a directory object of
- * "Person" class, <tt>getSchemaClassDefinition()</tt> would return a
- * <tt>DirContext</tt> representing the (directory's) object class
- * definition of "Person".
- *<p>
- * The information that can be retrieved from an object class definition
- * is directory-dependent.
- *<p>
- * Prior to JNDI 1.2, this method
- * returned a single schema object representing the class definition of
- * the named object.
- * Since JNDI 1.2, this method returns a <tt>DirContext</tt> containing
- * all of the named object's class definitions.
- *
- * @param name
- * the name of the object whose object class
- * definition is to be retrieved
- * @return the <tt>DirContext</tt> containing the named
- * object's class definitions; never null
- *
- * @throws OperationNotSupportedException if schema not supported
- * @throws NamingException if a naming exception is encountered
- */
- public DirContext getSchemaClassDefinition(Name name)
- throws NamingException;
-
- /**
- * Retrieves a context containing the schema objects of the
- * named object's class definitions.
- * See {@link #getSchemaClassDefinition(Name)} for details.
- *
- * @param name
- * the name of the object whose object class
- * definition is to be retrieved
- * @return the <tt>DirContext</tt> containing the named
- * object's class definitions; never null
- *
- * @throws OperationNotSupportedException if schema not supported
- * @throws NamingException if a naming exception is encountered
- */
- public DirContext getSchemaClassDefinition(String name)
- throws NamingException;
-
- // -------------------- search operations
-
- /**
- * Searches in a single context for objects that contain a
- * specified set of attributes, and retrieves selected attributes.
- * The search is performed using the default
- * <code>SearchControls</code> settings.
- * <p>
- * For an object to be selected, each attribute in
- * <code>matchingAttributes</code> must match some attribute of the
- * object. If <code>matchingAttributes</code> is empty or
- * null, all objects in the target context are returned.
- *<p>
- * An attribute <em>A</em><sub>1</sub> in
- * <code>matchingAttributes</code> is considered to match an
- * attribute <em>A</em><sub>2</sub> of an object if
- * <em>A</em><sub>1</sub> and <em>A</em><sub>2</sub> have the same
- * identifier, and each value of <em>A</em><sub>1</sub> is equal
- * to some value of <em>A</em><sub>2</sub>. This implies that the
- * order of values is not significant, and that
- * <em>A</em><sub>2</sub> may contain "extra" values not found in
- * <em>A</em><sub>1</sub> without affecting the comparison. It
- * also implies that if <em>A</em><sub>1</sub> has no values, then
- * testing for a match is equivalent to testing for the presence
- * of an attribute <em>A</em><sub>2</sub> with the same
- * identifier.
- *<p>
- * The precise definition of "equality" used in comparing attribute values
- * is defined by the underlying directory service. It might use the
- * <code>Object.equals</code> method, for example, or might use a schema
- * to specify a different equality operation.
- * For matching based on operations other than equality (such as
- * substring comparison) use the version of the <code>search</code>
- * method that takes a filter argument.
- * <p>
- * When changes are made to this <tt>DirContext</tt>,
- * the effect on enumerations returned by prior calls to this method
- * is undefined.
- *<p>
- * If the object does not have the attribute
- * specified, the directory will ignore the nonexistent attribute
- * and return the requested attributes that the object does have.
- *<p>
- * A directory might return more attributes than was requested
- * (see <strong>Attribute Type Names</strong> in the class description),
- * but is not allowed to return arbitrary, unrelated attributes.
- *<p>
- * See also <strong>Operational Attributes</strong> in the class
- * description.
- *
- * @param name
- * the name of the context to search
- * @param matchingAttributes
- * the attributes to search for. If empty or null,
- * all objects in the target context are returned.
- * @param attributesToReturn
- * the attributes to return. null indicates that
- * all attributes are to be returned;
- * an empty array indicates that none are to be returned.
- * @return
- * a non-null enumeration of <tt>SearchResult</tt> objects.
- * Each <tt>SearchResult</tt> contains the attributes
- * identified by <code>attributesToReturn</code>
- * and the name of the corresponding object, named relative
- * to the context named by <code>name</code>.
- * @throws NamingException if a naming exception is encountered
- *
- * @see SearchControls
- * @see SearchResult
- * @see #search(Name, String, Object[], SearchControls)
- */
- public NamingEnumeration search(Name name,
- Attributes matchingAttributes,
- String[] attributesToReturn)
- throws NamingException;
-
- /**
- * Searches in a single context for objects that contain a
- * specified set of attributes, and retrieves selected attributes.
- * See {@link #search(Name, Attributes, String[])} for details.
- *
- * @param name
- * the name of the context to search
- * @param matchingAttributes
- * the attributes to search for
- * @param attributesToReturn
- * the attributes to return
- * @return a non-null enumeration of <tt>SearchResult</tt> objects
- * @throws NamingException if a naming exception is encountered
- */
- public NamingEnumeration search(String name,
- Attributes matchingAttributes,
- String[] attributesToReturn)
- throws NamingException;
-
- /**
- * Searches in a single context for objects that contain a
- * specified set of attributes.
- * This method returns all the attributes of such objects.
- * It is equivalent to supplying null as
- * the <tt>atributesToReturn</tt> parameter to the method
- * <code>search(Name, Attributes, String[])</code>.
- * <br>
- * See {@link #search(Name, Attributes, String[])} for a full description.
- *
- * @param name
- * the name of the context to search
- * @param matchingAttributes
- * the attributes to search for
- * @return an enumeration of <tt>SearchResult</tt> objects
- * @throws NamingException if a naming exception is encountered
- *
- * @see #search(Name, Attributes, String[])
- */
- public NamingEnumeration search(Name name,
- Attributes matchingAttributes)
- throws NamingException;
-
- /**
- * Searches in a single context for objects that contain a
- * specified set of attributes.
- * See {@link #search(Name, Attributes)} for details.
- *
- * @param name
- * the name of the context to search
- * @param matchingAttributes
- * the attributes to search for
- * @return an enumeration of <tt>SearchResult</tt> objects
- * @throws NamingException if a naming exception is encountered
- */
- public NamingEnumeration search(String name,
- Attributes matchingAttributes)
- throws NamingException;
-
- /**
- * Searches in the named context or object for entries that satisfy the
- * given search filter. Performs the search as specified by
- * the search controls.
- * <p>
- * The format and interpretation of <code>filter</code> follows RFC 2254
- * with the
- * following interpretations for <code>attr</code> and <code>value</code>
- * mentioned in the RFC.
- * <p>
- * <code>attr</code> is the attribute's identifier.
- * <p>
- * <code>value</code> is the string representation the attribute's value.
- * The translation of this string representation into the attribute's value
- * is directory-specific.
- * <p>
- * For the assertion "someCount=127", for example, <code>attr</code>
- * is "someCount" and <code>value</code> is "127".
- * The provider determines, based on the attribute ID ("someCount")
- * (and possibly its schema), that the attribute's value is an integer.
- * It then parses the string "127" appropriately.
- *<p>
- * Any non-ASCII characters in the filter string should be
- * represented by the appropriate Java (Unicode) characters, and
- * not encoded as UTF-8 octets. Alternately, the
- * "backslash-hexcode" notation described in RFC 2254 may be used.
- *<p>
- * If the directory does not support a string representation of
- * some or all of its attributes, the form of <code>search</code> that
- * accepts filter arguments in the form of Objects can be used instead.
- * The service provider for such a directory would then translate
- * the filter arguments to its service-specific representation
- * for filter evaluation.
- * See <code>search(Name, String, Object[], SearchControls)</code>.
- * <p>
- * RFC 2254 defines certain operators for the filter, including substring
- * matches, equality, approximate match, greater than, less than. These
- * operators are mapped to operators with corresponding semantics in the
- * underlying directory. For example, for the equals operator, suppose
- * the directory has a matching rule defining "equality" of the
- * attributes in the filter. This rule would be used for checking
- * equality of the attributes specified in the filter with the attributes
- * of objects in the directory. Similarly, if the directory has a
- * matching rule for ordering, this rule would be used for
- * making "greater than" and "less than" comparisons.
- *<p>
- * Not all of the operators defined in RFC 2254 are applicable to all
- * attributes. When an operator is not applicable, the exception
- * <code>InvalidSearchFilterException</code> is thrown.
- * <p>
- * The result is returned in an enumeration of <tt>SearchResult</tt>s.
- * Each <tt>SearchResult</tt> contains the name of the object
- * and other information about the object (see SearchResult).
- * The name is either relative to the target context of the search
- * (which is named by the <code>name</code> parameter), or
- * it is a URL string. If the target context is included in
- * the enumeration (as is possible when
- * <code>cons</code> specifies a search scope of
- * <code>SearchControls.OBJECT_SCOPE</code> or
- * <code>SearchControls.SUBSTREE_SCOPE</code>), its name is the empty
- * string. The <tt>SearchResult</tt> may also contain attributes of the
- * matching object if the <tt>cons</tt> argument specified that attributes
- * be returned.
- *<p>
- * If the object does not have a requested attribute, that
- * nonexistent attribute will be ignored. Those requested
- * attributes that the object does have will be returned.
- *<p>
- * A directory might return more attributes than were requested
- * (see <strong>Attribute Type Names</strong> in the class description)
- * but is not allowed to return arbitrary, unrelated attributes.
- *<p>
- * See also <strong>Operational Attributes</strong> in the class
- * description.
- *
- * @param name
- * the name of the context or object to search
- * @param filter
- * the filter expression to use for the search; may not be null
- * @param cons
- * the search controls that control the search. If null,
- * the default search controls are used (equivalent
- * to <tt>(new SearchControls())</tt>).
- * @return an enumeration of <tt>SearchResult</tt>s of
- * the objects that satisfy the filter; never null
- *
- * @throws InvalidSearchFilterException if the search filter specified is
- * not supported or understood by the underlying directory
- * @throws InvalidSearchControlsException if the search controls
- * contain invalid settings
- * @throws NamingException if a naming exception is encountered
- *
- * @see #search(Name, String, Object[], SearchControls)
- * @see SearchControls
- * @see SearchResult
- */
- public NamingEnumeration search(Name name,
- String filter,
- SearchControls cons)
- throws NamingException;
-
- /**
- * Searches in the named context or object for entries that satisfy the
- * given search filter. Performs the search as specified by
- * the search controls.
- * See {@link #search(Name, String, SearchControls)} for details.
- *
- * @param name
- * the name of the context or object to search
- * @param filter
- * the filter expression to use for the search; may not be null
- * @param cons
- * the search controls that control the search. If null,
- * the default search controls are used (equivalent
- * to <tt>(new SearchControls())</tt>).
- *
- * @return an enumeration of <tt>SearchResult</tt>s for
- * the objects that satisfy the filter.
- * @throws InvalidSearchFilterException if the search filter specified is
- * not supported or understood by the underlying directory
- * @throws InvalidSearchControlsException if the search controls
- * contain invalid settings
- * @throws NamingException if a naming exception is encountered
- */
- public NamingEnumeration search(String name,
- String filter,
- SearchControls cons)
- throws NamingException;
-
- /**
- * Searches in the named context or object for entries that satisfy the
- * given search filter. Performs the search as specified by
- * the search controls.
- *<p>
- * The interpretation of <code>filterExpr</code> is based on RFC
- * 2254. It may additionally contain variables of the form
- * <code>{i}</code> -- where <code>i</code> is an integer -- that
- * refer to objects in the <code>filterArgs</code> array. The
- * interpretation of <code>filterExpr</code> is otherwise
- * identical to that of the <code>filter</code> parameter of the
- * method <code>search(Name, String, SearchControls)</code>.
- *<p>
- * When a variable <code>{i}</code> appears in a search filter, it
- * indicates that the filter argument <code>filterArgs[i]</code>
- * is to be used in that place. Such variables may be used
- * wherever an <em>attr</em>, <em>value</em>, or
- * <em>matchingrule</em> production appears in the filter grammar
- * of RFC 2254, section 4. When a string-valued filter argument
- * is substituted for a variable, the filter is interpreted as if
- * the string were given in place of the variable, with any
- * characters having special significance within filters (such as
- * <code>'*'</code>) having been escaped according to the rules of
- * RFC 2254.
- *<p>
- * For directories that do not use a string representation for
- * some or all of their attributes, the filter argument
- * corresponding to an attribute value may be of a type other than
- * String. Directories that support unstructured binary-valued
- * attributes, for example, should accept byte arrays as filter
- * arguments. The interpretation (if any) of filter arguments of
- * any other type is determined by the service provider for that
- * directory, which maps the filter operations onto operations with
- * corresponding semantics in the underlying directory.
- *<p>
- * This method returns an enumeration of the results.
- * Each element in the enumeration contains the name of the object
- * and other information about the object (see <code>SearchResult</code>).
- * The name is either relative to the target context of the search
- * (which is named by the <code>name</code> parameter), or
- * it is a URL string. If the target context is included in
- * the enumeration (as is possible when
- * <code>cons</code> specifies a search scope of
- * <code>SearchControls.OBJECT_SCOPE</code> or
- * <code>SearchControls.SUBSTREE_SCOPE</code>),
- * its name is the empty string.
- *<p>
- * The <tt>SearchResult</tt> may also contain attributes of the matching
- * object if the <tt>cons</tt> argument specifies that attributes be
- * returned.
- *<p>
- * If the object does not have a requested attribute, that
- * nonexistent attribute will be ignored. Those requested
- * attributes that the object does have will be returned.
- *<p>
- * A directory might return more attributes than were requested
- * (see <strong>Attribute Type Names</strong> in the class description)
- * but is not allowed to return arbitrary, unrelated attributes.
- *<p>
- * If a search filter with invalid variable substitutions is provided
- * to this method, the result is undefined.
- * When changes are made to this DirContext,
- * the effect on enumerations returned by prior calls to this method
- * is undefined.
- *<p>
- * See also <strong>Operational Attributes</strong> in the class
- * description.
- *
- * @param name
- * the name of the context or object to search
- * @param filterExpr
- * the filter expression to use for the search.
- * The expression may contain variables of the
- * form "<code>{i}</code>" where <code>i</code>
- * is a nonnegative integer. May not be null.
- * @param filterArgs
- * the array of arguments to substitute for the variables
- * in <code>filterExpr</code>. The value of
- * <code>filterArgs[i]</code> will replace each
- * occurrence of "<code>{i}</code>".
- * If null, equivalent to an empty array.
- * @param cons
- * the search controls that control the search. If null,
- * the default search controls are used (equivalent
- * to <tt>(new SearchControls())</tt>).
- * @return an enumeration of <tt>SearchResult</tt>s of the objects
- * that satisfy the filter; never null
- *
- * @throws ArrayIndexOutOfBoundsException if <tt>filterExpr</tt> contains
- * <code>{i}</code> expressions where <code>i</code> is outside
- * the bounds of the array <code>filterArgs</code>
- * @throws InvalidSearchControlsException if <tt>cons</tt> contains
- * invalid settings
- * @throws InvalidSearchFilterException if <tt>filterExpr</tt> with
- * <tt>filterArgs</tt> represents an invalid search filter
- * @throws NamingException if a naming exception is encountered
- *
- * @see #search(Name, Attributes, String[])
- * @see java.text.MessageFormat
- */
- public NamingEnumeration search(Name name,
- String filterExpr,
- Object[] filterArgs,
- SearchControls cons)
- throws NamingException;
-
- /**
- * Searches in the named context or object for entries that satisfy the
- * given search filter. Performs the search as specified by
- * the search controls.
- * See {@link #search(Name, String, Object[], SearchControls)} for details.
- *
- * @param name
- * the name of the context or object to search
- * @param filterExpr
- * the filter expression to use for the search.
- * The expression may contain variables of the
- * form "<code>{i}</code>" where <code>i</code>
- * is a nonnegative integer. May not be null.
- * @param filterArgs
- * the array of arguments to substitute for the variables
- * in <code>filterExpr</code>. The value of
- * <code>filterArgs[i]</code> will replace each
- * occurrence of "<code>{i}</code>".
- * If null, equivalent to an empty array.
- * @param cons
- * the search controls that control the search. If null,
- * the default search controls are used (equivalent
- * to <tt>(new SearchControls())</tt>).
- * @return an enumeration of <tt>SearchResult</tt>s of the objects
- * that satisfy the filter; never null
- *
- * @throws ArrayIndexOutOfBoundsException if <tt>filterExpr</tt> contains
- * <code>{i}</code> expressions where <code>i</code> is outside
- * the bounds of the array <code>filterArgs</code>
- * @throws InvalidSearchControlsException if <tt>cons</tt> contains
- * invalid settings
- * @throws InvalidSearchFilterException if <tt>filterExpr</tt> with
- * <tt>filterArgs</tt> represents an invalid search filter
- * @throws NamingException if a naming exception is encountered
- */
- public NamingEnumeration search(String name,
- String filterExpr,
- Object[] filterArgs,
- SearchControls cons)
- throws NamingException;
- }