mirror of https://github.com/OpenIdentityPlatform/OpenDJ.git

Jean-Noel Rouvignac
04.33.2013 87944ee88ce027a9115ed536b8ff9762c0872bf8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License, Version 1.0 only
 * (the "License").  You may not use this file except in compliance
 * with the License.
 *
 * You can obtain a copy of the license at legal-notices/CDDLv1_0.txt
 * or http://forgerock.org/license/CDDLv1.0.html.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at legal-notices/CDDLv1_0.txt.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information:
 *      Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 *
 *
 *      Copyright 2009 Sun Microsystems, Inc.
 *      Portions Copyright 2013 ForgeRock AS
 */
package org.forgerock.opendj.ldap;
 
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
 
/**
 * 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/draft-sermersheim-ldap-subordinate-scope">
 *      draft-sermersheim-ldap-subordinate-scope - Subordinate Subtree Search
 *      Scope for LDAP </a>
 */
public final class SearchScope {
    private static final SearchScope[] ELEMENTS = new SearchScope[4];
 
    private static final List<SearchScope> IMMUTABLE_ELEMENTS = Collections.unmodifiableList(Arrays
            .asList(ELEMENTS));
 
    /**
     * The scope is constrained to the search base entry.
     */
    public static final SearchScope BASE_OBJECT = register(0, "base");
 
    /**
     * The scope is constrained to the immediate subordinates of the search base
     * entry.
     */
    public static final SearchScope SINGLE_LEVEL = register(1, "one");
 
    /**
     * The scope is constrained to the search base entry and to all its
     * subordinates.
     */
    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).
     */
    public static final SearchScope SUBORDINATES = register(3, "subordinates");
 
    /**
     * 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}.
     */
    public static SearchScope valueOf(final int intValue) {
        if (intValue < 0 || intValue >= ELEMENTS.length) {
            return null;
        }
        return ELEMENTS[intValue];
    }
 
    /**
     * Returns the search scope having the specified name as defined in RFC 4511
     * section 4.5.1.2.
     *
     * @param name
     *          the name of the search scope to return
     * @return The search scope, or {@code null} if there was no search scope
     *         associated with {@code name}.
     * @throws NullPointerException
     *           if name is null
     */
    public static SearchScope valueOf(String name) {
        for (SearchScope searchScope : ELEMENTS) {
            if (searchScope.name.equals(name)) {
                return searchScope;
            }
        }
        return null;
    }
 
    /**
     * 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.
     */
    public static List<SearchScope> values() {
        return IMMUTABLE_ELEMENTS;
    }
 
    /**
     * 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(final int intValue, final String name) {
        this.intValue = intValue;
        this.name = name;
    }
 
    /**
     * {@inheritDoc}
     */
    @Override
    public boolean equals(final Object obj) {
        if (this == obj) {
            return true;
        } else if (obj instanceof SearchScope) {
            return this.intValue == ((SearchScope) obj).intValue;
        } else {
            return false;
        }
    }
 
    /**
     * {@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.
     *
     * @return The integer value of this search scope.
     */
    public int intValue() {
        return intValue;
    }
 
    /**
     * 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;
    }
}