Package org.opends.server.protocols.ldap
Class LdapClientConnection
- java.lang.Object
- 
- org.opends.server.api.ClientConnection
- 
- org.opends.server.protocols.ldap.LdapClientConnection
 
 
- 
- All Implemented Interfaces:
- RequestHandler,- TLSCapableConnection
 
 public final class LdapClientConnection extends ClientConnection implements TLSCapableConnection This class defines an LDAP client connection, which is a type of client connection that will be accepted by an instance of the LDAP connection handler and have its requests decoded by an LDAP request handler.
- 
- 
Field Summary- 
Fields inherited from class org.opends.server.api.ClientConnectionauthenticationInfo, bindInProgress, saslBindInProgress, startTLSInProgress
 
- 
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voiddisconnect(DisconnectReason disconnectReason, boolean sendNotification, LocalizableMessage message)Closes the connection to the client, optionally sending it a message indicating the reason for the closure.StringgetClientAddress()Retrieves a string representation of the address of the client.Certificate[]getClientCertificateChain()Return the certificate chain array associated with a connection.intgetClientPort()Retrieves the port number for this connection on the client system if available.ConnectionHandler<?>getConnectionHandler()Retrieves the connection handler that accepted this client connection.longgetConnectionID()Retrieves the unique identifier that has been assigned to this connection.longgetIdleTime()Retrieves the length of time in milliseconds that this client connection has been idle.longgetMaxBlockedWriteTimeLimit()Retrieves the maximum length of time in milliseconds that attempts to write data to the client should be allowed to block.JsonValuegetMonitorSummary()Returns a summary of this client connection in JSON (format that is both human readable and machine parseable).OperationgetOperationInProgress(int messageID)Retrieves the operation in progress with the specified message ID.StringgetProtocol()Retrieves the protocol that the client is using to communicate with the Directory Server.InetAddressgetRemoteAddress()Retrieves theInetAddressassociated with the remote client system.StringgetServerAddress()Retrieves a string representation of the address on the server to which the client connected.intgetServerPort()Retrieves the port number for this connection on the server system if available.intgetSSF()Return the Security Strength Factor of a client connection.StringgetTlsCipher()Return the TLS cipher suite of a client connection.StringgetTlsProtocol()Return the TLS protocol of a client connection.Flowable<Response>handle(org.forgerock.services.context.Context context, Request request)Processes the provided request in a reactive way.booleanisConnectionValid()Returns whether the Directory Server believes this connection to be valid and available for communication.booleanisSecure()Indicates whether this client connection is currently using a secure mechanism to communicate with the server.booleanmustLogTlsHandshake()Returns whether TLS information must be logged by the caller.booleanprepareTLS(LocalizableMessageBuilder unavailableReason)Prepares this connection for using TLS and returns whether TLS protection is actually available for the underlying client connection.voidremoveOperationInProgress(int messageID)Removes the provided operation from the set of operations in progress for this client connection.protected booleansendIntermediateResponseMessage(Operation operation, IntermediateResponse intermediateResponse)Sends the provided intermediate response message to the client.voidsendResponse(Operation operation)Removes the provided operation from the set of operations in progress of this client connection and sends a response to the client based on the information in the provided operation.voidsendSearchEntry(SearchOperation searchOperation, SearchResultEntry searchEntry)Sends the provided search result entry to the client.booleansendSearchReference(SearchOperation searchOperation, SearchResultReference searchReference)Sends the provided search result reference to the client.voidtoString(StringBuilder buffer)Appends a string representation of this client connection to the provided buffer.- 
Methods inherited from class org.opends.server.api.ClientConnectionderegisterPersistentSearch, finalizeConnectionInternal, finishBind, finishSaslBind, finishStartTLS, getAuthenticationInfo, getClientHostPort, getConnectTimeString, getIdleTimeLimit, getKeyManagerProviderDN, getMaxCandidateSetSize, getPersistentSearches, getSASLAuthStateInfo, getServerContext, getServerHostPort, getSizeLimit, getTimeLimit, hasAllPrivileges, hasPrivilege, hasPrivilege, isInnerConnection, mustChangePassword, registerPersistentSearch, sendResponse, setAuthenticationInfo, setIdleTimeLimit, setMaxCandidateSetSize, setMustChangePassword, setResourceLimits, setSASLAuthStateInfo, setSizeLimit, setTimeLimit, setUnauthenticated, toString, updateAuthenticationInfo, updatePrivileges, writeTimeLimitExceeded
 
- 
 
- 
- 
- 
Method Detail- 
getConnectionIDpublic long getConnectionID() Description copied from class:ClientConnectionRetrieves the unique identifier that has been assigned to this connection.- Specified by:
- getConnectionIDin class- ClientConnection
- Returns:
- The unique identifier that has been assigned to this connection.
 
 - 
getConnectionHandlerpublic ConnectionHandler<?> getConnectionHandler() Description copied from class:ClientConnectionRetrieves the connection handler that accepted this client connection.- Specified by:
- getConnectionHandlerin class- ClientConnection
- Returns:
- The connection handler that accepted this client connection.
 
 - 
getProtocolpublic String getProtocol() Description copied from class:ClientConnectionRetrieves the protocol that the client is using to communicate with the Directory Server.- Specified by:
- getProtocolin class- ClientConnection
- Returns:
- The protocol that the client is using to communicate with the Directory Server.
 
 - 
getClientAddresspublic String getClientAddress() Description copied from class:ClientConnectionRetrieves a string representation of the address of the client.- Specified by:
- getClientAddressin class- ClientConnection
- Returns:
- A string representation of the address of the client.
 
 - 
getClientPortpublic int getClientPort() Description copied from class:ClientConnectionRetrieves the port number for this connection on the client system if available.- Specified by:
- getClientPortin class- ClientConnection
- Returns:
- The port number for this connection on the client system or -1 if there is no client port associated with this connection (e.g. internal client).
 
 - 
getServerAddresspublic String getServerAddress() Description copied from class:ClientConnectionRetrieves a string representation of the address on the server to which the client connected.- Specified by:
- getServerAddressin class- ClientConnection
- Returns:
- A string representation of the address on the server to which the client connected.
 
 - 
getServerPortpublic int getServerPort() Description copied from class:ClientConnectionRetrieves the port number for this connection on the server system if available.- Specified by:
- getServerPortin class- ClientConnection
- Returns:
- The port number for this connection on the server system or -1 if there is no server port associated with this connection (e.g. internal client).
 
 - 
getRemoteAddresspublic InetAddress getRemoteAddress() Description copied from class:ClientConnectionRetrieves theInetAddressassociated with the remote client system.- Specified by:
- getRemoteAddressin class- ClientConnection
- Returns:
- The InetAddressassociated with the remote client system. It may benullif the client is not connected over an IP-based connection.
 
 - 
isConnectionValidpublic boolean isConnectionValid() Description copied from class:ClientConnectionReturns whether the Directory Server believes this connection to be valid and available for communication.- Specified by:
- isConnectionValidin class- ClientConnection
- Returns:
- true if the connection is valid, false otherwise
 
 - 
isSecurepublic boolean isSecure() Description copied from class:ClientConnectionIndicates whether this client connection is currently using a secure mechanism to communicate with the server. Note that this may change over time based on operations performed by the client or server (e.g., it may go fromfalsetotrueif the client uses the StartTLS extended operation).- Specified by:
- isSecurein class- ClientConnection
- Returns:
- trueif the client connection is currently using a secure mechanism to communicate with the server, or- falseif not.
 
 - 
sendResponsepublic void sendResponse(Operation operation) Description copied from class:ClientConnectionRemoves the provided operation from the set of operations in progress of this client connection and sends a response to the client based on the information in the provided operation.Note that this does not make any attempt to cancel any processing that may already be in progress for the operation. - Overrides:
- sendResponsein class- ClientConnection
- Parameters:
- operation- The operation for which to send the response
 
 - 
sendSearchEntrypublic void sendSearchEntry(SearchOperation searchOperation, SearchResultEntry searchEntry) Description copied from class:ClientConnectionSends the provided search result entry to the client.- Specified by:
- sendSearchEntryin class- ClientConnection
- Parameters:
- searchOperation- The search operation with which the entry is associated.
- searchEntry- The search result entry to be sent to the client.
 
 - 
sendSearchReferencepublic boolean sendSearchReference(SearchOperation searchOperation, SearchResultReference searchReference) Description copied from class:ClientConnectionSends the provided search result reference to the client.- Specified by:
- sendSearchReferencein class- ClientConnection
- Parameters:
- searchOperation- The search operation with which the reference is associated.
- searchReference- The search result reference to be sent to the client.
- Returns:
- trueif the client is able to accept referrals, or- falseif the client cannot handle referrals and no more attempts should be made to send them for the associated search operation.
 
 - 
sendIntermediateResponseMessageprotected boolean sendIntermediateResponseMessage(Operation operation, IntermediateResponse intermediateResponse) Description copied from class:ClientConnectionSends the provided intermediate response message to the client.- Specified by:
- sendIntermediateResponseMessagein class- ClientConnection
- Parameters:
- operation- The operation with which the intermediate response is associated.
- intermediateResponse- The intermediate response message to be sent.
- Returns:
- trueif processing on the associated operation should continue, or- falseif not.
 
 - 
disconnectpublic void disconnect(DisconnectReason disconnectReason, boolean sendNotification, LocalizableMessage message) Description copied from class:ClientConnectionCloses the connection to the client, optionally sending it a message indicating the reason for the closure. Note that the ability to send a notice of disconnection may not be available for all protocols or under all circumstances. Also note that when attempting to disconnect a client connection as a part of operation processing (e.g., within a plugin or other extension), thedisconnectClientmethod within that operation should be called rather than invoking this method directly.All subclasses must invoke the finalizeConnectionInternalmethod during the course of processing this method.- Specified by:
- disconnectin class- ClientConnection
- Parameters:
- disconnectReason- The disconnect reason that provides the generic cause for the disconnect.
- sendNotification- Indicates whether to try to provide notification to the client that the connection will be closed.
- message- The message to send to the client. It may be- nullif no notification is to be sent.
 
 - 
getOperationInProgresspublic Operation getOperationInProgress(int messageID) Description copied from class:ClientConnectionRetrieves the operation in progress with the specified message ID.- Specified by:
- getOperationInProgressin class- ClientConnection
- Parameters:
- messageID- The message ID of the operation to retrieve.
- Returns:
- The operation in progress with the specified message ID, or nullif no such operation could be found.
 
 - 
removeOperationInProgresspublic void removeOperationInProgress(int messageID) Description copied from class:ClientConnectionRemoves the provided operation from the set of operations in progress for this client connection. Note that this does not make any attempt to cancel any processing that may already be in progress for the operation.- Specified by:
- removeOperationInProgressin class- ClientConnection
- Parameters:
- messageID- The message ID of the operation to remove from the set of operations in progress.
 
 - 
getMaxBlockedWriteTimeLimitpublic long getMaxBlockedWriteTimeLimit() Description copied from class:ClientConnectionRetrieves the maximum length of time in milliseconds that attempts to write data to the client should be allowed to block.- Overrides:
- getMaxBlockedWriteTimeLimitin class- ClientConnection
- Returns:
- The maximum length of time in milliseconds that attempts to write data to the client should be allowed to block.
 
 - 
handlepublic Flowable<Response> handle(org.forgerock.services.context.Context context, Request request) Processes the provided request in a reactive way.For most requests, this will include placing the operation in the work queue. Certain requests (in particular, abandons and unbinds) will be processed directly. - Specified by:
- handlein interface- RequestHandler
- Parameters:
- context- The context to process the request, which is expected to contain a- RequestContext
- request- The request to process.
- Returns:
- a stream of responses
 
 - 
getMonitorSummarypublic JsonValue getMonitorSummary() Description copied from class:ClientConnectionReturns a summary of this client connection in JSON (format that is both human readable and machine parseable).- Specified by:
- getMonitorSummaryin class- ClientConnection
- Returns:
- A summary of this client connection in JSON.
 
 - 
toStringpublic void toString(StringBuilder buffer) Description copied from class:ClientConnectionAppends a string representation of this client connection to the provided buffer.- Specified by:
- toStringin class- ClientConnection
- Parameters:
- buffer- The buffer to which the information should be appended.
 
 - 
prepareTLSpublic boolean prepareTLS(LocalizableMessageBuilder unavailableReason) Description copied from interface:TLSCapableConnectionPrepares this connection for using TLS and returns whether TLS protection is actually available for the underlying client connection. If there is any reason that TLS protection cannot be enabled on this client connection, then it should be appended to the provided buffer.- Specified by:
- prepareTLSin interface- TLSCapableConnection
- Parameters:
- unavailableReason- The buffer used to hold the reason that TLS is not available on the underlying client connection.
- Returns:
- trueif TLS is available on the underlying client connection, or- falseif it is not.
 
 - 
getIdleTimepublic long getIdleTime() Description copied from class:ClientConnectionRetrieves the length of time in milliseconds that this client connection has been idle.Note that the default implementation will always return zero. Subclasses associated with connection handlers should override this method if they wish to provided idle time limit functionality. - Overrides:
- getIdleTimein class- ClientConnection
- Returns:
- The length of time in milliseconds that this client connection has been idle.
 
 - 
getClientCertificateChainpublic Certificate[] getClientCertificateChain() Return the certificate chain array associated with a connection.- Returns:
- The array of certificates associated with a connection.
 
 - 
getSSFpublic int getSSF() Description copied from class:ClientConnectionReturn the Security Strength Factor of a client connection.- Specified by:
- getSSFin class- ClientConnection
- Returns:
- An integer representing the SSF value of a connection.
 
 - 
getTlsProtocolpublic String getTlsProtocol() Description copied from class:ClientConnectionReturn the TLS protocol of a client connection.- Overrides:
- getTlsProtocolin class- ClientConnection
- Returns:
- A string, or "NONE"if TLS handshake is not complete, ornullif TLS is not active.
 
 - 
getTlsCipherpublic String getTlsCipher() Description copied from class:ClientConnectionReturn the TLS cipher suite of a client connection.- Overrides:
- getTlsCipherin class- ClientConnection
- Returns:
- A cipher name, or "SSL_NULL_WITH_NULL_NULL"if TLS handshake is not complete, ornullif TLS is not active.
 
 - 
mustLogTlsHandshakepublic boolean mustLogTlsHandshake() Description copied from class:ClientConnectionReturns whether TLS information must be logged by the caller. This method relies on side-effects to ensure the TLS information is logged only once per connection, even in the face of concurrent requests.- Overrides:
- mustLogTlsHandshakein class- ClientConnection
- Returns:
- whether TLS information must be logged by the caller
 
 
- 
 
-