All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.firefly.codec.http2.stream.StreamSPI Maven / Gradle / Ivy

The newest version!
package com.firefly.codec.http2.stream;

import java.io.Closeable;

import com.firefly.codec.http2.frame.Frame;
import com.firefly.utils.concurrent.Callback;

/**
 * 

* The SPI interface for implementing a HTTP/2 stream. *

*

* This class extends {@link Stream} by adding the methods required to implement * the HTTP/2 stream functionalities. *

*/ public interface StreamSPI extends Stream, Closeable { /** *

* The constant used as attribute key to store/retrieve the HTTP channel * associated with this stream *

* * @see #setAttribute(String, Object) */ public static final String CHANNEL_ATTRIBUTE = StreamSPI.class.getName() + ".channel"; /** * @return whether this stream is local or remote */ public boolean isLocal(); @Override public SessionSPI getSession(); /** * @return the associated with this stream */ public Listener getListener(); /** * @param listener * the associated with this stream */ public void setListener(Listener listener); /** *

* Processes the given {@code frame}, belonging to this stream. *

* * @param frame * the frame to process * @param callback * the callback to complete when frame has been processed */ public void process(Frame frame, Callback callback); /** *

* Updates the close state of this stream. *

* * @param update * whether to update the close state * @param local * whether the update comes from a local operation (such as * sending a frame that ends the stream) or a remote operation * (such as receiving a frame * @return whether the stream has been fully closed by this invocation */ public boolean updateClose(boolean update, boolean local); /** *

* Forcibly closes this stream. *

*/ @Override public void close(); /** *

* Updates the stream send window by the given {@code delta}. *

* * @param delta * the delta value (positive or negative) to add to the stream * send window * @return the previous value of the stream send window */ public int updateSendWindow(int delta); /** *

* Updates the stream receive window by the given {@code delta}. *

* * @param delta * the delta value (positive or negative) to add to the stream * receive window * @return the previous value of the stream receive window */ public int updateRecvWindow(int delta); /** *

* Marks this stream as not idle *

*/ public void notIdle(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy