Class AprEndpoint.AprSocketWrapper

    • Constructor Detail

      • AprSocketWrapper

        public AprSocketWrapper​(java.lang.Long socket,
                                AprEndpoint endpoint)
    • Method Detail

      • getBlockingStatus

        public boolean getBlockingStatus()
      • setBlockingStatus

        public void setBlockingStatus​(boolean blockingStatus)
      • getBlockingStatusReadLock

        public java.util.concurrent.locks.Lock getBlockingStatusReadLock()
      • getBlockingStatusWriteLock

        public java.util.concurrent.locks.ReentrantReadWriteLock.WriteLock getBlockingStatusWriteLock()
      • read

        public int read​(boolean block,
                        byte[] b,
                        int off,
                        int len)
                 throws java.io.IOException
        Specified by:
        read in class SocketWrapperBase<java.lang.Long>
        Throws:
        java.io.IOException
      • read

        public int read​(boolean block,
                        java.nio.ByteBuffer to)
                 throws java.io.IOException
        Specified by:
        read in class SocketWrapperBase<java.lang.Long>
        Throws:
        java.io.IOException
      • isReadyForRead

        public boolean isReadyForRead()
                               throws java.io.IOException
        Specified by:
        isReadyForRead in class SocketWrapperBase<java.lang.Long>
        Throws:
        java.io.IOException
      • doClose

        protected void doClose()
        Description copied from class: SocketWrapperBase
        Perform the actual close. The closed atomic boolean guarantees this will be called only once per wrapper.
        Specified by:
        doClose in class SocketWrapperBase<java.lang.Long>
      • flushNonBlocking

        protected boolean flushNonBlocking()
                                    throws java.io.IOException
        Description copied from class: SocketWrapperBase
        Writes as much data as possible from any that remains in the buffers.
        Specified by:
        flushNonBlocking in class SocketWrapperBase<java.lang.Long>
        Returns:
        true if data remains to be flushed after this method completes, otherwise false.
        Throws:
        java.io.IOException - If an IO error occurs during the write
      • doWrite

        protected void doWrite​(boolean block,
                               java.nio.ByteBuffer from)
                        throws java.io.IOException
        Description copied from class: SocketWrapperBase
        Write the contents of the ByteBuffer to the socket. For blocking writes either then entire contents of the buffer will be written or an IOException will be thrown. Partial blocking writes will not occur.
        Specified by:
        doWrite in class SocketWrapperBase<java.lang.Long>
        Parameters:
        block - Should the write be blocking or not?
        from - the ByteBuffer containing the data to be written
        Throws:
        java.io.IOException - If an I/O error such as a timeout occurs during the write
      • processSendfile

        public SendfileState processSendfile​(SendfileDataBase sendfileData)
        Description copied from class: SocketWrapperBase
        Starts the sendfile process. It is expected that if the sendfile process does not complete during this call and does not report an error, that the caller will not add the socket to the poller (or equivalent). That is the responsibility of this method.
        Specified by:
        processSendfile in class SocketWrapperBase<java.lang.Long>
        Parameters:
        sendfileData - Data representing the file to send
        Returns:
        The state of the sendfile process after the first write.
      • getSslSupport

        public SSLSupport getSslSupport​(java.lang.String clientCertProvider)
        Description copied from class: SocketWrapperBase
        Obtain an SSLSupport instance for this socket.
        Overrides:
        getSslSupport in class SocketWrapperBase<java.lang.Long>
        Parameters:
        clientCertProvider - The name of the client certificate provider to use. Only used by APR/native.
        Returns:
        An SSLSupport instance for this socket.
      • doClientAuth

        public void doClientAuth​(SSLSupport sslSupport)
                          throws java.io.IOException
        Description copied from class: SocketWrapperBase
        Require the client to perform CLIENT-CERT authentication if it hasn't already done so.
        Specified by:
        doClientAuth in class SocketWrapperBase<java.lang.Long>
        Parameters:
        sslSupport - The SSL/TLS support instance currently being used by the connection that may need updating after the client authentication
        Throws:
        java.io.IOException - If authentication is required then there will be I/O with the client and this exception will be thrown if that goes wrong