| | |
| | | |
| | | |
| | | /** |
| | | * A Search operation search scope as defined in RFC 4511 section |
| | | * 4.5.1.2 is used to specify the scope of a Search operation. |
| | | * A Search operation search scope as defined in RFC 4511 section 4.5.1.2 is |
| | | * used to specify the scope of a Search operation. |
| | | * |
| | | * @see <a href="http://tools.ietf.org/html/rfc4511#section-4.5.1.2">RFC |
| | | * 4511 - Lightweight Directory Access Protocol (LDAP): The |
| | | * Protocol </a> |
| | | * @see <a href="http://tools.ietf.org/html/rfc4511#section-4.5.1.2">RFC 4511 - |
| | | * Lightweight Directory Access Protocol (LDAP): The Protocol </a> |
| | | * @see <a |
| | | * href="http://tools.ietf.org/html/draft-sermersheim-ldap-subordinate-scope"> |
| | | * draft-sermersheim-ldap-subordinate-scope - Subordinate Subtree |
| | | * Search Scope for LDAP </a> |
| | | * draft-sermersheim-ldap-subordinate-scope - Subordinate Subtree Search |
| | | * Scope for LDAP </a> |
| | | */ |
| | | public final class SearchScope |
| | | { |
| | |
| | | public static final SearchScope BASE_OBJECT = register(0, "base"); |
| | | |
| | | /** |
| | | * The scope is constrained to the immediate subordinates of the |
| | | * search base entry. |
| | | * The scope is constrained to the immediate subordinates of the search base |
| | | * entry. |
| | | */ |
| | | public static final SearchScope SINGLE_LEVEL = register(1, "one"); |
| | | |
| | |
| | | public static final SearchScope WHOLE_SUBTREE = register(2, "sub"); |
| | | |
| | | /** |
| | | * The scope is constrained to all the subordinates of the search base |
| | | * entry, but does not include the search base entry itself (as |
| | | * wholeSubtree does). |
| | | * The scope is constrained to all the subordinates of the search base entry, |
| | | * but does not include the search base entry itself (as wholeSubtree does). |
| | | */ |
| | | public static final SearchScope SUBORDINATES = register(3, |
| | | "subordinates"); |
| | | public static final SearchScope SUBORDINATES = register(3, "subordinates"); |
| | | |
| | | |
| | | |
| | | /** |
| | | * Creates and registers a new search scope with the application. |
| | | * |
| | | * @param intValue |
| | | * The integer value of the search scope as defined in RFC |
| | | * 4511 section 4.5.1.2. |
| | | * @param name |
| | | * The name of the search scope as defined in RFC 4516. |
| | | * @return The new search scope. |
| | | */ |
| | | private static SearchScope register(int intValue, String name) |
| | | { |
| | | SearchScope t = new SearchScope(intValue, name); |
| | | ELEMENTS[intValue] = t; |
| | | return t; |
| | | } |
| | | |
| | | |
| | | |
| | | /** |
| | | * Returns the search scope having the specified integer value as |
| | | * defined in RFC 4511 section 4.5.1.2. |
| | | * Returns the search scope having the specified integer value as defined in |
| | | * RFC 4511 section 4.5.1.2. |
| | | * |
| | | * @param intValue |
| | | * The integer value of the search scope. |
| | | * @return The search scope, or {@code null} if there was no search |
| | | * scope associated with {@code intValue}. |
| | | * @return The search scope, or {@code null} if there was no search scope |
| | | * associated with {@code intValue}. |
| | | */ |
| | | public static SearchScope valueOf(int intValue) |
| | | public static SearchScope valueOf(final int intValue) |
| | | { |
| | | if (intValue < 0 || intValue >= ELEMENTS.length) |
| | | { |
| | |
| | | |
| | | |
| | | /** |
| | | * Returns an unmodifiable list containing the set of available search |
| | | * scopes indexed on their integer value as defined in RFC 4511 |
| | | * section 4.5.1.2. |
| | | * Returns an unmodifiable list containing the set of available search scopes |
| | | * indexed on their integer value as defined in RFC 4511 section 4.5.1.2. |
| | | * |
| | | * @return An unmodifiable list containing the set of available search |
| | | * scopes. |
| | | * @return An unmodifiable list containing the set of available search scopes. |
| | | */ |
| | | public static List<SearchScope> values() |
| | | { |
| | |
| | | |
| | | |
| | | |
| | | /** |
| | | * Creates and registers a new search scope with the application. |
| | | * |
| | | * @param intValue |
| | | * The integer value of the search scope as defined in RFC 4511 |
| | | * section 4.5.1.2. |
| | | * @param name |
| | | * The name of the search scope as defined in RFC 4516. |
| | | * @return The new search scope. |
| | | */ |
| | | private static SearchScope register(final int intValue, final String name) |
| | | { |
| | | final SearchScope t = new SearchScope(intValue, name); |
| | | ELEMENTS[intValue] = t; |
| | | return t; |
| | | } |
| | | |
| | | |
| | | |
| | | private final int intValue; |
| | | |
| | | private final String name; |
| | |
| | | |
| | | |
| | | // Prevent direct instantiation. |
| | | private SearchScope(int intValue, String name) |
| | | private SearchScope(final int intValue, final String name) |
| | | { |
| | | this.intValue = intValue; |
| | | this.name = name; |
| | |
| | | /** |
| | | * {@inheritDoc} |
| | | */ |
| | | public boolean equals(Object obj) |
| | | @Override |
| | | public boolean equals(final Object obj) |
| | | { |
| | | if (this == obj) |
| | | { |
| | |
| | | /** |
| | | * {@inheritDoc} |
| | | */ |
| | | @Override |
| | | public int hashCode() |
| | | { |
| | | return intValue; |
| | |
| | | |
| | | |
| | | /** |
| | | * Returns the integer value of this search scope as defined in RFC |
| | | * 4511 section 4.5.1.2. |
| | | * Returns the integer value of this search scope as defined in RFC 4511 |
| | | * section 4.5.1.2. |
| | | * |
| | | * @return The integer value of this search scope. |
| | | */ |
| | |
| | | |
| | | |
| | | /** |
| | | * Returns the string representation of this search scope as defined |
| | | * in RFC 4516. |
| | | * Returns the string representation of this search scope as defined in RFC |
| | | * 4516. |
| | | * |
| | | * @return The string representation of this search scope. |
| | | */ |
| | | @Override |
| | | public String toString() |
| | | { |
| | | return name; |