@NotMutable @ThreadSafety(level=COMPLETELY_THREADSAFE) public final class ExtendedSchemaInfoRequestControl extends Control
NOTE: This class, and other classes within the
com.unboundid.ldap.sdk.unboundidds
package structure, are only
supported for use against Ping Identity, UnboundID, and
Nokia/Alcatel-Lucent 8661 server products. These classes provide support
for proprietary functionality or for external specifications that are not
considered stable or mature enough to be guaranteed to work in an
interoperable way with other types of LDAP servers.
LDAPInterface.getSchema
and Schema.getSchema
convenience
methods cannot be used because they do not allow you to include controls in
the request.
String schemaDN = Schema.getSubschemaSubentryDN(connection, ""); SearchRequest searchRequest = new SearchRequest(schemaDN, SearchScope.BASE, Filter.createPresenceFilter("objectClass"), "*", "+"); searchRequest.addControl(new ExtendedSchemaInfoRequestControl()); SearchResult searchResult = connection.search(searchRequest); Schema schema = null; if (searchResult.getEntryCount() == 1) { schema = new Schema(searchResult.getSearchEntries().get(0)); }
Modifier and Type | Field and Description |
---|---|
static java.lang.String |
EXTENDED_SCHEMA_INFO_REQUEST_OID
The OID (1.3.6.1.4.1.30221.2.5.12) for the extended schema info request
control.
|
Constructor and Description |
---|
ExtendedSchemaInfoRequestControl()
Creates a new extended schema info request control.
|
ExtendedSchemaInfoRequestControl(boolean isCritical)
Creates a new extended schema info request control with the specified
criticality.
|
ExtendedSchemaInfoRequestControl(Control control)
Creates a new extended schema info request control which is decoded from
the provided generic control.
|
Modifier and Type | Method and Description |
---|---|
static ExtendedSchemaInfoRequestControl |
decodeJSONControl(JSONObject controlObject,
boolean strict)
Attempts to decode the provided object as a JSON representation of an
extended schema info request control.
|
java.lang.String |
getControlName()
Retrieves the user-friendly name for this control, if available.
|
JSONObject |
toJSONControl()
Retrieves a representation of this extended schema info request control as
a JSON object.
|
void |
toString(java.lang.StringBuilder buffer)
Appends a string representation of this LDAP control to the provided
buffer.
|
decode, decode, decodeControls, decodeJSONControl, deregisterDecodeableControl, encode, encodeControls, equals, getOID, getValue, hashCode, hasValue, isCritical, readFrom, registerDecodeableControl, registerDecodeableControl, toString, writeTo
@NotNull public static final java.lang.String EXTENDED_SCHEMA_INFO_REQUEST_OID
public ExtendedSchemaInfoRequestControl()
public ExtendedSchemaInfoRequestControl(boolean isCritical)
isCritical
- Indicates whether this control should be marked
critical.public ExtendedSchemaInfoRequestControl(@NotNull Control control) throws LDAPException
control
- The generic control to be decoded as an extended schema
info request control.LDAPException
- If the provided control cannot be decoded as an
extended schema info request control.@NotNull public java.lang.String getControlName()
getControlName
in class Control
@NotNull public JSONObject toJSONControl()
value-base64
nor
value-json
fields may be present):
oid
-- A mandatory string field whose value is the object
identifier for this control. For the extended scheam info request
control, the OID is "1.3.6.1.4.1.30221.2.5.12".
control-name
-- An optional string field whose value is a
human-readable name for this control. This field is only intended for
descriptive purposes, and when decoding a control, the oid
field should be used to identify the type of control.
criticality
-- A mandatory Boolean field used to indicate
whether this control is considered critical.
toJSONControl
in class Control
@NotNull public static ExtendedSchemaInfoRequestControl decodeJSONControl(@NotNull JSONObject controlObject, boolean strict) throws LDAPException
controlObject
- The JSON object to be decoded. It must not be
null
.strict
- Indicates whether to use strict mode when decoding
the provided JSON object. If this is true
,
then this method will throw an exception if the
provided JSON object contains any unrecognized
fields. If this is false
, then unrecognized
fields will be ignored.LDAPException
- If the provided JSON object cannot be parsed as a
valid extended schema info request control.