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

Mark Craig
20.58.2012 1e74b0f8f046cc9e69ba9eddbc180bf10ab83e06
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
/*
 * 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 2012 ForgeRock AS.
 */
 
package org.forgerock.opendj.ldap.responses;
 
import java.util.List;
 
import org.forgerock.opendj.ldap.ByteString;
import org.forgerock.opendj.ldap.DecodeException;
import org.forgerock.opendj.ldap.DecodeOptions;
import org.forgerock.opendj.ldap.ResultCode;
import org.forgerock.opendj.ldap.controls.Control;
import org.forgerock.opendj.ldap.controls.ControlDecoder;
 
/**
 * A Extended result indicates the status of an Extended operation and any
 * additional information associated with the Extended operation, including the
 * optional response name and value. These can be retrieved using the
 * {@link #getOID} and {@link #getValue} methods respectively.
 */
public interface ExtendedResult extends Result {
    /**
     * {@inheritDoc}
     */
    ExtendedResult addControl(Control control);
 
    /**
     * {@inheritDoc}
     */
    ExtendedResult addReferralURI(String uri);
 
    /**
     * {@inheritDoc}
     */
    Throwable getCause();
 
    /**
     * {@inheritDoc}
     */
    <C extends Control> C getControl(ControlDecoder<C> decoder, DecodeOptions options)
            throws DecodeException;
 
    /**
     * {@inheritDoc}
     */
    List<Control> getControls();
 
    /**
     * {@inheritDoc}
     */
    String getDiagnosticMessage();
 
    /**
     * {@inheritDoc}
     */
    String getMatchedDN();
 
    /**
     * Returns the numeric OID, if any, associated with this extended result.
     *
     * @return The numeric OID associated with this extended result, or
     *         {@code null} if there is no OID.
     */
    String getOID();
 
    /**
     * {@inheritDoc}
     */
    List<String> getReferralURIs();
 
    /**
     * {@inheritDoc}
     */
    ResultCode getResultCode();
 
    /**
     * Returns the value, if any, associated with this extended result. Its
     * format is defined by the specification of this extended result.
     *
     * @return The value associated with this extended result, or {@code null}
     *         if there is no value.
     */
    ByteString getValue();
 
    /**
     * Returns {@code true} if this extended result has a value. In some
     * circumstances it may be useful to determine if a extended result has a
     * value, without actually calculating the value and incurring any
     * performance costs.
     *
     * @return {@code true} if this extended result has a value, or
     *         {@code false} if there is no value.
     */
    boolean hasValue();
 
    /**
     * {@inheritDoc}
     */
    boolean isReferral();
 
    /**
     * {@inheritDoc}
     */
    boolean isSuccess();
 
    /**
     * {@inheritDoc}
     */
    ExtendedResult setCause(Throwable cause);
 
    /**
     * {@inheritDoc}
     */
    ExtendedResult setDiagnosticMessage(String message);
 
    /**
     * {@inheritDoc}
     */
    ExtendedResult setMatchedDN(String dn);
 
    /**
     * {@inheritDoc}
     */
    ExtendedResult setResultCode(ResultCode resultCode);
}