Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * Copyright 2013 Red Hat, Inc., and individual contributors
   * as indicated by the @author tags.
   *
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
  *     http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
 package io.undertow.conduits;
 
 
Conduit that adds support to close a channel once for a specified time no reads and no writes were performed.

Author(s):
Norman Maurer
 
     private volatile XnioExecutor.Key handle;
     private static final AtomicReferenceFieldUpdater<IdleTimeoutConduitXnioExecutor.KeyKEY_UPDATER = AtomicReferenceFieldUpdater.newUpdater(IdleTimeoutConduit.classXnioExecutor.Key.class"handle");
 
     private volatile long idleTimeout;
 
     private final StreamSinkConduit sink;
     private final StreamSourceConduit source;
 
     private volatile WriteReadyHandler writeReadyHandler;
     private volatile ReadReadyHandler readReadyHandler;
 
     private final Runnable timeoutCommand = new Runnable() {
         @Override
         public void run() {
             ..tracef("Timing out channel %s due to inactivity");
             safeClose();
             safeClose();
             if (.isWriteResumed()) {
                 if( != null) {
                     .writeReady();
                 }
             }
             if (.isReadResumed()) {
                 if( != null) {
                     .readReady();
                 }
             }
         }
     };
 
     public IdleTimeoutConduit(StreamSinkConduit sinkStreamSourceConduit source) {
         this. = sink;
         this. = source;
     }
 
     private void handleIdleTimeout() {
         long idleTimeout = this.;
         XnioExecutor.Key key = ;
         if (key != null) {
             key.remove();
         }
         if (idleTimeout > 0) {
             XnioExecutor.Key k = .getWriteThread().executeAfter(idleTimeout.);
             if (!.compareAndSet(thiskeyk)) {
                 k.remove();
             }
         }
     }
 
     @Override
     public int write(ByteBuffer srcthrows IOException {
         int w = .write(src);
         handleIdleTimeout();
         return w;
     }
 
    @Override
    public long write(ByteBuffer[] srcsint offsetint lengththrows IOException {
        long w = .write(srcsoffsetlength);
        handleIdleTimeout();
        return w;
    }
    @Override
    public int writeFinal(ByteBuffer srcthrows IOException {
        int w = .writeFinal(src);
        handleIdleTimeout();
        return w;
    }
    @Override
    public long writeFinal(ByteBuffer[] srcsint offsetint lengththrows IOException {
        long w = .writeFinal(srcsoffsetlength);
        handleIdleTimeout();
        return w;
    }
    @Override
    public long transferTo(long positionlong countFileChannel targetthrows IOException {
        long w = .transferTo(positioncounttarget);
        handleIdleTimeout();
        return w;
    }
    @Override
    public long transferTo(long countByteBuffer throughBufferStreamSinkChannel targetthrows IOException {
        long w = .transferTo(countthroughBuffertarget);
        handleIdleTimeout();
        return w;
    }
    @Override
    public long read(ByteBuffer[] dstsint offsetint lengththrows IOException {
        long r = .read(dstsoffsetlength);
        handleIdleTimeout();
        return r;
    }
    @Override
    public int read(ByteBuffer dstthrows IOException {
        int r = .read(dst);
        handleIdleTimeout();
        return r;
    }
    @Override
    public long transferFrom(FileChannel srclong positionlong countthrows IOException {
        long r = .transferFrom(srcpositioncount);
        handleIdleTimeout();
        return r;
    }
    @Override
    public long transferFrom(StreamSourceChannel sourcelong countByteBuffer throughBufferthrows IOException {
        long r = .transferFrom(sourcecountthroughBuffer);
        handleIdleTimeout();
        return r;
    }
    @Override
    public void suspendReads() {
        .suspendReads();
    }
    @Override
    public void terminateReads() throws IOException {
        .terminateReads();
    }
    @Override
    public boolean isReadShutdown() {
        return .isReadShutdown();
    }
    @Override
    public void resumeReads() {
        .resumeReads();
    }
    @Override
    public boolean isReadResumed() {
        return .isReadResumed();
    }
    @Override
    public void wakeupReads() {
        .wakeupReads();
    }
    @Override
    public void awaitReadable() throws IOException {
        .awaitReadable();
    }
    @Override
    public void awaitReadable(long timeTimeUnit timeUnitthrows IOException {
        .awaitReadable(timetimeUnit);
    }
    @Override
    public XnioIoThread getReadThread() {
        return .getReadThread();
    }
    @Override
    public void setReadReadyHandler(ReadReadyHandler handler) {
        this. = handler;
        .setReadReadyHandler(handler);
    }
    private static void safeClose(final StreamSourceConduit sink) {
        try {
            sink.terminateReads();
        } catch (IOException e) {
        }
    }
    private static void safeClose(final StreamSinkConduit sink) {
        try {
            sink.truncateWrites();
        } catch (IOException e) {
        }
    }
    @Override
    public void terminateWrites() throws IOException {
        .terminateWrites();
    }
    @Override
    public boolean isWriteShutdown() {
        return .isWriteShutdown();
    }
    @Override
    public void resumeWrites() {
        .resumeWrites();
    }
    @Override
    public void suspendWrites() {
        .suspendWrites();
    }
    @Override
    public void wakeupWrites() {
        .wakeupWrites();
    }
    @Override
    public boolean isWriteResumed() {
        return .isWriteResumed();
    }
    @Override
    public void awaitWritable() throws IOException {
        .awaitWritable();
    }
    @Override
    public void awaitWritable(long timeTimeUnit timeUnitthrows IOException {
        .awaitWritable();
    }
    @Override
    public XnioIoThread getWriteThread() {
        return .getWriteThread();
    }
    @Override
    public void setWriteReadyHandler(WriteReadyHandler handler) {
        this. = handler;
        .setWriteReadyHandler(handler);
    }
    @Override
    public void truncateWrites() throws IOException {
        .truncateWrites();
    }
    @Override
    public boolean flush() throws IOException {
        return .flush();
    }
    @Override
    public XnioWorker getWorker() {
        return .getWorker();
    }
    public long getIdleTimeout() {
        return ;
    }
    public void setIdleTimeout(long idleTimeout) {
        this. = idleTimeout;
        XnioExecutor.Key key = ;
        if (key != null) {
            key.remove();
        }
        if (idleTimeout > 0) {
            XnioExecutor.Key k = .getWriteThread().executeAfter(idleTimeout.);
            if (!.compareAndSet(thiskeyk)) {
                k.remove();
            }
        }
    }
New to GrepCode? Check out our FAQ X