package com.hwlcn.ldap.ldap.protocol; import com.hwlcn.ldap.asn1.ASN1Buffer; import com.hwlcn.ldap.asn1.ASN1BufferSequence; import com.hwlcn.ldap.asn1.ASN1Element; import com.hwlcn.ldap.asn1.ASN1OctetString; import com.hwlcn.ldap.asn1.ASN1Sequence; import com.hwlcn.ldap.asn1.ASN1StreamReader; import com.hwlcn.ldap.asn1.ASN1StreamReaderSequence; import com.hwlcn.ldap.ldap.sdk.Control; import com.hwlcn.ldap.ldap.sdk.ExtendedRequest; import com.hwlcn.ldap.ldap.sdk.LDAPException; import com.hwlcn.ldap.ldap.sdk.ResultCode; import com.hwlcn.core.annotation.NotMutable; import com.hwlcn.core.annotation.InternalUseOnly; import com.hwlcn.core.annotation.ThreadSafety; import com.hwlcn.ldap.util.ThreadSafetyLevel; import static com.hwlcn.ldap.ldap.protocol.ProtocolMessages.*; import static com.hwlcn.ldap.util.Debug.*; import static com.hwlcn.ldap.util.StaticUtils.*; import static com.hwlcn.ldap.util.Validator.*; @InternalUseOnly() @NotMutable() @ThreadSafety(level=ThreadSafetyLevel.COMPLETELY_THREADSAFE) public final class ExtendedRequestProtocolOp implements ProtocolOp { public static final byte TYPE_OID = (byte) 0x80; public static final byte TYPE_VALUE = (byte) 0x81; private static final long serialVersionUID = -5343424210200494377L; private final ASN1OctetString value; private final String oid; public ExtendedRequestProtocolOp(final String oid, final ASN1OctetString value) { this.oid = oid; if (value == null) { this.value = null; } else { this.value = new ASN1OctetString(TYPE_VALUE, value.getValue()); } } public ExtendedRequestProtocolOp(final ExtendedRequest request) { oid = request.getOID(); value = request.getValue(); } ExtendedRequestProtocolOp(final ASN1StreamReader reader) throws LDAPException { try { final ASN1StreamReaderSequence opSequence = reader.beginSequence(); oid = reader.readString(); ensureNotNull(oid); if (opSequence.hasMoreElements()) { value = new ASN1OctetString(TYPE_VALUE, reader.readBytes()); } else { value = null; } } catch (Exception e) { debugException(e); throw new LDAPException(ResultCode.DECODING_ERROR, ERR_EXTENDED_REQUEST_CANNOT_DECODE.get(getExceptionMessage(e)), e); } } public String getOID() { return oid; } public ASN1OctetString getValue() { return value; } public byte getProtocolOpType() { return LDAPMessage.PROTOCOL_OP_TYPE_EXTENDED_REQUEST; } public ASN1Element encodeProtocolOp() { if (value == null) { return new ASN1Sequence(LDAPMessage.PROTOCOL_OP_TYPE_EXTENDED_REQUEST, new ASN1OctetString(TYPE_OID, oid)); } else { return new ASN1Sequence(LDAPMessage.PROTOCOL_OP_TYPE_EXTENDED_REQUEST, new ASN1OctetString(TYPE_OID, oid), value); } } public static ExtendedRequestProtocolOp decodeProtocolOp( final ASN1Element element) throws LDAPException { try { final ASN1Element[] elements = ASN1Sequence.decodeAsSequence(element).elements(); final String oid = ASN1OctetString.decodeAsOctetString(elements[0]).stringValue(); final ASN1OctetString value; if (elements.length == 1) { value = null; } else { value = ASN1OctetString.decodeAsOctetString(elements[1]); } return new ExtendedRequestProtocolOp(oid, value); } catch (final Exception e) { debugException(e); throw new LDAPException(ResultCode.DECODING_ERROR, ERR_EXTENDED_REQUEST_CANNOT_DECODE.get(getExceptionMessage(e)), e); } } public void writeTo(final ASN1Buffer buffer) { final ASN1BufferSequence opSequence = buffer.beginSequence(LDAPMessage.PROTOCOL_OP_TYPE_EXTENDED_REQUEST); buffer.addOctetString(TYPE_OID, oid); if (value != null) { buffer.addOctetString(TYPE_VALUE, value.getValue()); } opSequence.end(); } public ExtendedRequest toExtendedRequest(final Control... controls) { return new ExtendedRequest(oid, value, controls); } @Override() public String toString() { final StringBuilder buffer = new StringBuilder(); toString(buffer); return buffer.toString(); } public void toString(final StringBuilder buffer) { buffer.append("ExtendedRequestProtocolOp(oid='"); buffer.append(oid); buffer.append("')"); } }