| | |
| | | * CDDL HEADER END |
| | | * |
| | | * |
| | | * Portions Copyright 2006 Sun Microsystems, Inc. |
| | | * Portions Copyright 2006-2007 Sun Microsystems, Inc. |
| | | */ |
| | | package org.opends.server.protocols.ldap; |
| | | |
| | |
| | | import org.opends.server.protocols.asn1.ASN1OctetString; |
| | | import org.opends.server.protocols.asn1.ASN1Sequence; |
| | | import org.opends.server.types.DN; |
| | | import org.opends.server.types.DebugLogLevel; |
| | | |
| | | import static org.opends.server.loggers.Debug.*; |
| | | import static org.opends.server.loggers.debug.DebugLogger.debugCought; |
| | | import static org.opends.server.loggers.debug.DebugLogger.debugEnabled; |
| | | import static org.opends.server.messages.MessageHandler.*; |
| | | import static org.opends.server.messages.ProtocolMessages.*; |
| | | import static org.opends.server.protocols.ldap.LDAPConstants.*; |
| | |
| | | public class SearchResultDoneProtocolOp |
| | | extends ProtocolOp |
| | | { |
| | | /** |
| | | * The fully-qualified name of this class to use for debugging purposes. |
| | | */ |
| | | private static final String CLASS_NAME = |
| | | "org.opends.server.protocols.ldap.SearchResultDoneProtocolOp"; |
| | | |
| | | |
| | | |
| | |
| | | */ |
| | | public SearchResultDoneProtocolOp(int resultCode) |
| | | { |
| | | assert debugConstructor(CLASS_NAME, String.valueOf(resultCode)); |
| | | |
| | | this.resultCode = resultCode; |
| | | |
| | |
| | | */ |
| | | public SearchResultDoneProtocolOp(int resultCode, String errorMessage) |
| | | { |
| | | assert debugEnter(CLASS_NAME, String.valueOf(resultCode), |
| | | String.valueOf(errorMessage)); |
| | | |
| | | this.resultCode = resultCode; |
| | | this.errorMessage = errorMessage; |
| | |
| | | public SearchResultDoneProtocolOp(int resultCode, String errorMessage, |
| | | DN matchedDN, List<String> referralURLs) |
| | | { |
| | | assert debugEnter(CLASS_NAME, String.valueOf(resultCode), |
| | | String.valueOf(errorMessage), String.valueOf(matchedDN), |
| | | String.valueOf(referralURLs)); |
| | | |
| | | this.resultCode = resultCode; |
| | | this.errorMessage = errorMessage; |
| | |
| | | */ |
| | | public int getResultCode() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getResultCode"); |
| | | |
| | | return resultCode; |
| | | } |
| | |
| | | */ |
| | | public void setResultCode(int resultCode) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setResultCode", String.valueOf(resultCode)); |
| | | |
| | | this.resultCode = resultCode; |
| | | } |
| | |
| | | */ |
| | | public String getErrorMessage() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getErrorMessage"); |
| | | |
| | | return errorMessage; |
| | | } |
| | |
| | | */ |
| | | public void setErrorMessage(String errorMessage) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setErrorMessage", |
| | | String.valueOf(errorMessage)); |
| | | |
| | | this.errorMessage = errorMessage; |
| | | } |
| | |
| | | */ |
| | | public DN getMatchedDN() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getMatchedDN"); |
| | | |
| | | return matchedDN; |
| | | } |
| | |
| | | */ |
| | | public void setMatchedDN(DN matchedDN) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setMatchedDN", String.valueOf(matchedDN)); |
| | | |
| | | this.matchedDN = matchedDN; |
| | | } |
| | |
| | | */ |
| | | public List<String> getReferralURLs() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getReferralURLs"); |
| | | |
| | | return referralURLs; |
| | | } |
| | |
| | | */ |
| | | public void setReferralURLs(List<String> referralURLs) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setReferralURLs", |
| | | String.valueOf(referralURLs)); |
| | | |
| | | this.referralURLs = referralURLs; |
| | | } |
| | |
| | | */ |
| | | public byte getType() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getType"); |
| | | |
| | | return OP_TYPE_SEARCH_RESULT_DONE; |
| | | } |
| | |
| | | */ |
| | | public String getProtocolOpName() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getProtocolOpName"); |
| | | |
| | | return "Search Result Done"; |
| | | } |
| | |
| | | */ |
| | | public ASN1Element encode() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "encode"); |
| | | |
| | | ArrayList<ASN1Element> elements = new ArrayList<ASN1Element>(4); |
| | | elements.add(new ASN1Enumerated(resultCode)); |
| | |
| | | element) |
| | | throws LDAPException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "decodeSearchDone", |
| | | String.valueOf(element)); |
| | | |
| | | ArrayList<ASN1Element> elements; |
| | | try |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "decodeSearchDone", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_SEQUENCE; |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_SEQUENCE; |
| | | String message = getMessage(msgID, String.valueOf(e)); |
| | | throw new LDAPException(PROTOCOL_ERROR, msgID, message, e); |
| | | } |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "decodeSearchDone", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_RESULT_CODE; |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_RESULT_CODE; |
| | | String message = getMessage(msgID, String.valueOf(e)); |
| | | throw new LDAPException(PROTOCOL_ERROR, msgID, message, e); |
| | | } |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "decodeSearchDone", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_MATCHED_DN; |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_MATCHED_DN; |
| | | String message = getMessage(msgID, String.valueOf(e)); |
| | | throw new LDAPException(PROTOCOL_ERROR, msgID, message, e); |
| | | } |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "decodeSearchDone", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_ERROR_MESSAGE; |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_ERROR_MESSAGE; |
| | | String message = getMessage(msgID, String.valueOf(e)); |
| | | throw new LDAPException(PROTOCOL_ERROR, msgID, message, e); |
| | | } |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "decodeSearchDone", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_REFERRALS; |
| | | int msgID = MSGID_LDAP_RESULT_DECODE_REFERRALS; |
| | | String message = getMessage(msgID, String.valueOf(e)); |
| | | throw new LDAPException(PROTOCOL_ERROR, msgID, message, e); |
| | | } |
| | |
| | | */ |
| | | public void toString(StringBuilder buffer) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toString", "java.lang.StringBuilder"); |
| | | |
| | | buffer.append("SearchResultDone(resultCode="); |
| | | buffer.append(resultCode); |
| | |
| | | */ |
| | | public void toString(StringBuilder buffer, int indent) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toString", "java.lang.StringBuilder", |
| | | String.valueOf(indent)); |
| | | |
| | | StringBuilder indentBuf = new StringBuilder(indent); |
| | | for (int i=0 ; i < indent; i++) |