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

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

package com.firefly.codec.http2.stream;

import com.firefly.codec.http2.frame.DataFrame;
import com.firefly.codec.http2.frame.HeadersFrame;
import com.firefly.codec.http2.frame.PushPromiseFrame;
import com.firefly.codec.http2.frame.ResetFrame;
import com.firefly.utils.concurrent.Callback;
import com.firefly.utils.concurrent.Promise;

/**
 * 

* A {@link Stream} represents a bidirectional exchange of data on top of a * {@link Session}. *

*

* Differently from socket streams, where the input and output streams are * permanently associated with the socket (and hence with the connection that * the socket represents), there can be multiple HTTP/2 streams present * concurrent for a HTTP/2 session. *

*

* A {@link Stream} maps to a HTTP request/response cycle, and after the * request/response cycle is completed, the stream is closed and removed from * the session. *

*

* Like {@link Session}, {@link Stream} is the active part and by calling its * API applications can generate events on the stream; conversely, * {@link Stream.Listener} is the passive part, and its callbacks are invoked * when events happen on the stream. *

* * @see Stream.Listener */ public interface Stream { /** * @return the stream unique id */ public int getId(); /** * @return the session this stream is associated to */ public Session getSession(); /** *

* Sends the given HEADERS {@code frame} representing a HTTP response. *

* * @param frame * the HEADERS frame to send * @param callback * the callback that gets notified when the frame has been sent */ public void headers(HeadersFrame frame, Callback callback); /** *

* Sends the given PUSH_PROMISE {@code frame}. *

* * @param frame * the PUSH_PROMISE frame to send * @param promise * the promise that gets notified of the pushed stream creation * @param listener * the listener that gets notified of stream events */ public void push(PushPromiseFrame frame, Promise promise, Listener listener); /** *

* Sends the given DATA {@code frame}. *

* * @param frame * the DATA frame to send * @param callback * the callback that gets notified when the frame has been sent */ public void data(DataFrame frame, Callback callback); /** *

* Sends the given RST_STREAM {@code frame}. *

* * @param frame * the RST_FRAME to send * @param callback * the callback that gets notified when the frame has been sent */ public void reset(ResetFrame frame, Callback callback); /** * @param key * the attribute key * @return an arbitrary object associated with the given key to this stream * or null if no object can be found for the given key. * @see #setAttribute(String, Object) */ public Object getAttribute(String key); /** * @param key * the attribute key * @param value * an arbitrary object to associate with the given key to this * stream * @see #getAttribute(String) * @see #removeAttribute(String) */ public void setAttribute(String key, Object value); /** * @param key * the attribute key * @return the arbitrary object associated with the given key to this stream * @see #setAttribute(String, Object) */ public Object removeAttribute(String key); /** * @return whether this stream has been reset */ public boolean isReset(); /** * @return whether this stream is closed, both locally and remotely. */ public boolean isClosed(); /** * @return the stream idle timeout * @see #setIdleTimeout(long) */ public long getIdleTimeout(); /** * @param idleTimeout * the stream idle timeout * @see #getIdleTimeout() * @see Stream.Listener#onTimeout(Stream, Throwable) */ public void setIdleTimeout(long idleTimeout); /** *

* A {@link Stream.Listener} is the passive counterpart of a {@link Stream} * and receives events happening on a HTTP/2 stream. *

* * @see Stream */ public interface Listener { /** *

* Callback method invoked when a HEADERS frame representing the HTTP * response has been received. *

* * @param stream * the stream * @param frame * the HEADERS frame received */ public void onHeaders(Stream stream, HeadersFrame frame); /** *

* Callback method invoked when a PUSH_PROMISE frame has been received. *

* * @param stream * the stream * @param frame * the PUSH_PROMISE frame received * @return a {@link Stream.Listener} that will be notified of pushed * stream events */ public Listener onPush(Stream stream, PushPromiseFrame frame); /** *

* Callback method invoked when a DATA frame has been received. *

* * @param stream * the stream * @param frame * the DATA frame received * @param callback * the callback to complete when the bytes of the DATA frame * have been consumed */ public void onData(Stream stream, DataFrame frame, Callback callback); /** *

* Callback method invoked when a RST_STREAM frame has been received for * this stream. *

* * @param stream * the stream * @param frame * the RST_FRAME received * @see Session.Listener#onReset(Session, ResetFrame) */ public void onReset(Stream stream, ResetFrame frame); /** *

* Callback method invoked when the stream exceeds its idle timeout. *

* * @param stream * the stream * @param x * the timeout failure * @see #getIdleTimeout() */ public void onTimeout(Stream stream, Throwable x); /** *

* Empty implementation of {@link Listener} *

*/ public static class Adapter implements Listener { @Override public void onHeaders(Stream stream, HeadersFrame frame) { } @Override public Listener onPush(Stream stream, PushPromiseFrame frame) { return null; } @Override public void onData(Stream stream, DataFrame frame, Callback callback) { callback.succeeded(); } @Override public void onReset(Stream stream, ResetFrame frame) { } @Override public void onTimeout(Stream stream, Throwable x) { } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy