Class HTTP2Session
- All Implemented Interfaces:
Session, Parser.Listener, Dumpable, LifeCycle
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classstatic interfaceListener for processable HTTP/2 frames that have been received.static interfaceListener for open/closeSessionevents.Nested classes/interfaces inherited from class AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface LifeCycle
LifeCycle.ListenerNested classes/interfaces inherited from interface Parser.Listener
Parser.Listener.WrapperNested classes/interfaces inherited from interface Session
Session.Listener -
Field Summary
-
Constructor Summary
ConstructorsConstructorDescriptionHTTP2Session(Scheduler scheduler, EndPoint endPoint, Parser parser, Generator generator, Session.Listener listener, FlowControlStrategy flowControl, int initialStreamId) -
Method Summary
Modifier and TypeMethodDescriptionbooleanaddEventListener(EventListener listener) booleanInvoked internally and by applications to send a GO_AWAY frame to the other peer.protected HTTP2StreamcreateLocalStream(int streamId, MetaData.Request request, Consumer<Throwable> failFn) protected HTTP2StreamcreateRemoteStream(int streamId, MetaData.Request request) voiddata(HTTP2Stream stream, DataFrame frame, Callback callback) voidprotected voiddoStop()Method to override to stop the lifecyclevoiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.voidframes(HTTP2Stream stream, List<? extends Frame> frames, Callback callback) longintintprotected intintintintintintintgetStream(int streamId) Retrieves the stream with the givenstreamId.intlonglonglongintbooleangoAway(GoAwayFrame frame, Callback callback) protected static booleanisClientStream(int streamId) booleanisClosed()booleanbooleanprotected booleanisLocalStreamClosed(int streamId) booleanprotected booleanisRemoteStreamClosed(int streamId) protected HTTP2StreamnewStream(int streamId, MetaData.Request request, boolean local) voidnewStream(HeadersFrame frame, Promise<Stream> promise, Stream.Listener listener) Sends the given HEADERSframeto create a newStream.voidnewStream(HTTP2Stream.FrameList frames, Promise<Stream> promise, Stream.Listener listener) newUpgradeStream(HeadersFrame frame, Stream.Listener listener, Consumer<Throwable> failFn) Creates a new stream allocating a stream id if the given HEADERS frame does not have one.protected voidnotifyClose(Session session, GoAwayFrame frame, Callback callback) protected voidnotifyFailure(Session session, Throwable failure, Callback callback) protected voidnotifyGoAway(Session session, GoAwayFrame frame) protected booleannotifyIdleTimeout(Session session) voidprotected Stream.ListenernotifyNewStream(Stream stream, HeadersFrame frame) voidnotifyOutgoingFrames(Collection<HTTP2Session.Entry> entries) protected voidnotifyPing(Session session, PingFrame frame) protected voidnotifyReset(Session session, ResetFrame frame) protected voidnotifySettings(Session session, SettingsFrame frame) voidonConnectionFailure(int error, String reason) voidonData(Stream.Data data) voidvoidvoidonGoAway(GoAwayFrame frame) This method is called when receiving a GO_AWAY from the other peer.voidonHeaders(HeadersFrame frame) booleanThis method is invoked when the idle timeout expires.voidvoidonPriority(PriorityFrame frame) voidonPushPromise(PushPromiseFrame frame) voidonReset(ResetFrame frame) protected voidvoidonSettings(SettingsFrame frame) voidonSettings(SettingsFrame frame, boolean reply) voidThis method is called when the TCP FIN is received from the remote peer.voidonStreamFailure(int streamId, int error, String reason) protected voidonStreamFailure(Stream stream, int error, String reason, Throwable failure, Callback callback) protected final voidonStreamOpened(Stream stream) voidonWindowUpdate(WindowUpdateFrame frame) voidonWindowUpdate(HTTP2Stream stream, WindowUpdateFrame frame) voidonWriteFailure(Throwable failure) voidSends the given PINGframe.intpriority(PriorityFrame frame, Callback callback) Sends the given PRIORITYframe.voidpush(Stream stream, Promise<Stream> promise, PushPromiseFrame frame, Stream.Listener listener) booleanremoveEventListener(EventListener listener) booleanremoveStream(Stream stream) voidsetConnectProtocolEnabled(boolean connectProtocolEnabled) voidsetInitialSessionRecvWindow(int initialSessionRecvWindow) voidsetMaxEncoderTableCapacity(int maxEncoderTableCapacity) voidsetMaxLocalStreams(int maxLocalStreams) voidsetMaxRemoteStreams(int maxRemoteStreams) voidsetMaxTotalLocalStreams(int maxTotalLocalStreams) voidsetStreamIdleTimeout(long streamIdleTimeout) voidsettings(SettingsFrame frame, Callback callback) Sends the given SETTINGSframeto configure the session.voidsetWriteThreshold(int writeThreshold) shutdown()Gracefully closes the session, returning aCompletableFuturethat is completed when all the streams currently being processed are completed.toString()protected voidupdateLastRemoteStreamId(int streamId) intupdateRecvWindow(int delta) intupdateSendWindow(int delta) Methods inherited from class AbstractLifeCycle
doStart, getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stop
-
Constructor Details
-
HTTP2Session
public HTTP2Session(Scheduler scheduler, EndPoint endPoint, Parser parser, Generator generator, Session.Listener listener, FlowControlStrategy flowControl, int initialStreamId)
-
-
Method Details
-
addEventListener
- Specified by:
addEventListenerin interfaceLifeCycle- Overrides:
addEventListenerin classAbstractLifeCycle
-
removeEventListener
- Specified by:
removeEventListenerin interfaceLifeCycle- Overrides:
removeEventListenerin classAbstractLifeCycle
-
doStop
Description copied from class:AbstractLifeCycleMethod to override to stop the lifecycle- Overrides:
doStopin classAbstractLifeCycle- Throws:
Exception- If there was a problem stopping. Will cause a transition to FAILED state
-
getFrameQueueSize
public int getFrameQueueSize() -
getFlowControlStrategy
@ManagedAttribute(value="The flow control strategy", readonly=true) public FlowControlStrategy getFlowControlStrategy() -
getStreamsOpened
@ManagedAttribute(value="The total number of streams opened", readonly=true) public long getStreamsOpened() -
getStreamsClosed
@ManagedAttribute(value="The total number of streams closed", readonly=true) public long getStreamsClosed() -
getMaxLocalStreams
-
setMaxLocalStreams
public void setMaxLocalStreams(int maxLocalStreams) -
getMaxTotalLocalStreams
@ManagedAttribute("The maximum number of local streams that can be opened") public int getMaxTotalLocalStreams() -
setMaxTotalLocalStreams
public void setMaxTotalLocalStreams(int maxTotalLocalStreams) -
getMaxRemoteStreams
@ManagedAttribute("The maximum number of concurrent remote streams") public int getMaxRemoteStreams() -
setMaxRemoteStreams
public void setMaxRemoteStreams(int maxRemoteStreams) -
getStreamIdleTimeout
-
setStreamIdleTimeout
public void setStreamIdleTimeout(long streamIdleTimeout) -
getInitialSessionRecvWindow
@ManagedAttribute("The initial size of session's flow control receive window") public int getInitialSessionRecvWindow() -
setInitialSessionRecvWindow
public void setInitialSessionRecvWindow(int initialSessionRecvWindow) -
getWriteThreshold
-
setWriteThreshold
public void setWriteThreshold(int writeThreshold) -
getMaxEncoderTableCapacity
@ManagedAttribute("The HPACK encoder dynamic table maximum capacity") public int getMaxEncoderTableCapacity() -
setMaxEncoderTableCapacity
public void setMaxEncoderTableCapacity(int maxEncoderTableCapacity) -
getEndPoint
-
getParser
-
getGenerator
-
getBytesWritten
public long getBytesWritten() -
onData
- Specified by:
onDatain interfaceParser.Listener
-
onData
-
isLocalStreamClosed
protected boolean isLocalStreamClosed(int streamId) -
isRemoteStreamClosed
protected boolean isRemoteStreamClosed(int streamId) -
onHeaders
- Specified by:
onHeadersin interfaceParser.Listener
-
onPriority
- Specified by:
onPriorityin interfaceParser.Listener
-
onReset
- Specified by:
onResetin interfaceParser.Listener
-
onResetForUnknownStream
-
onSettings
- Specified by:
onSettingsin interfaceParser.Listener
-
onSettings
-
onPushPromise
- Specified by:
onPushPromisein interfaceParser.Listener
-
onPing
- Specified by:
onPingin interfaceParser.Listener
-
onGoAway
This method is called when receiving a GO_AWAY from the other peer.
- Specified by:
onGoAwayin interfaceParser.Listener- Parameters:
frame- the GO_AWAY frame that has been received.- See Also:
-
onWindowUpdate
- Specified by:
onWindowUpdatein interfaceParser.Listener
-
onWindowUpdate
-
onStreamFailure
- Specified by:
onStreamFailurein interfaceParser.Listener
-
onStreamFailure
-
onConnectionFailure
- Specified by:
onConnectionFailurein interfaceParser.Listener
-
onWriteFailure
-
newStream
-
newStream
public void newStream(HTTP2Stream.FrameList frames, Promise<Stream> promise, Stream.Listener listener) -
newUpgradeStream
public Stream newUpgradeStream(HeadersFrame frame, Stream.Listener listener, Consumer<Throwable> failFn) Creates a new stream allocating a stream id if the given HEADERS frame does not have one.
- Parameters:
frame- the HEADERS frame that triggered the stream creation allocated stream id, or null if not interested in the modified headers framelistener- the listener that gets notified of stream events
-
newStream
-
priority
Description copied from interface:SessionSends the given PRIORITY
frame.If the
framereferences astreamIdthat does not exist (for example0), then a newstreamIdwill be allocated, to support unused anchor streams that act as parent for other streams. -
push
public void push(Stream stream, Promise<Stream> promise, PushPromiseFrame frame, Stream.Listener listener) -
settings
Description copied from interface:SessionSends the given SETTINGS
frameto configure the session. -
ping
Description copied from interface:SessionSends the given PING
frame.PING frames may be used to test the connection integrity and to measure round-trip time.
-
close
Invoked internally and by applications to send a GO_AWAY frame to the other peer.
-
shutdown
Description copied from interface:SessionGracefully closes the session, returning a
CompletableFuturethat is completed when all the streams currently being processed are completed.Implementation is idempotent, i.e. calling this method a second time or concurrently results in a no-operation.
-
goAway
-
isClosed
-
getCloseState
-
frames
-
data
-
createLocalStream
protected HTTP2Stream createLocalStream(int streamId, MetaData.Request request, Consumer<Throwable> failFn) -
createRemoteStream
-
removeStream
-
getStreams
- Specified by:
getStreamsin interfaceSession- Returns:
- a snapshot of all the streams currently belonging to this session
-
getStreamCount
-
getStream
Description copied from interface:SessionRetrieves the stream with the given
streamId. -
getLocalAddress
- Specified by:
getLocalAddressin interfaceSession- Returns:
- the local network address this session is bound to,
or
nullif this session is not bound to a network address
-
getLocalSocketAddress
- Specified by:
getLocalSocketAddressin interfaceSession- Returns:
- the local network address this session is bound to,
or
nullif this session is not bound to a network address
-
getRemoteAddress
- Specified by:
getRemoteAddressin interfaceSession- Returns:
- the remote network address this session is connected to,
or
nullif this session is not connected to a network address
-
getRemoteSocketAddress
- Specified by:
getRemoteSocketAddressin interfaceSession- Returns:
- the remote network address this session is connected to,
or
nullif this session is not connected to a network address
-
getSendWindow
-
getRecvWindow
@ManagedAttribute(value="The flow control receive window", readonly=true) public int getRecvWindow() -
updateSendWindow
public int updateSendWindow(int delta) -
updateRecvWindow
public int updateRecvWindow(int delta) -
isPushEnabled
@ManagedAttribute(value="Whether HTTP/2 push is enabled", readonly=true) public boolean isPushEnabled()- Specified by:
isPushEnabledin interfaceSession- Returns:
- whether the push functionality is enabled
-
isConnectProtocolEnabled
@ManagedAttribute(value="Whether CONNECT requests supports a protocol", readonly=true) public boolean isConnectProtocolEnabled() -
setConnectProtocolEnabled
public void setConnectProtocolEnabled(boolean connectProtocolEnabled) -
onShutdown
public void onShutdown()This method is called when the TCP FIN is received from the remote peer.
- See Also:
-
onIdleTimeout
public boolean onIdleTimeout()This method is invoked when the idle timeout expires.
- Returns:
- true if the session should be closed, false otherwise
- See Also:
-
onFrame
-
onStreamOpened
-
disconnect
public void disconnect() -
isDisconnected
public boolean isDisconnected() -
getLastRemoteStreamId
protected int getLastRemoteStreamId() -
updateLastRemoteStreamId
protected void updateLastRemoteStreamId(int streamId) -
notifyLifeCycleOpen
public void notifyLifeCycleOpen() -
notifyOutgoingFrames
-
notifyNewStream
-
notifySettings
-
notifyPing
-
notifyReset
-
notifyGoAway
-
notifyClose
-
notifyIdleTimeout
-
notifyFailure
-
isClientStream
protected static boolean isClientStream(int streamId) -
dump
Description copied from interface:DumpableDump this object (and children) into an Appendable using the provided indent after any new lines. The indent should not be applied to the first object dumped.- Specified by:
dumpin interfaceDumpable- Parameters:
out- The appendable to dump toindent- The indent to apply after any new lines.- Throws:
IOException- if unable to write to Appendable
-
toString
- Overrides:
toStringin classAbstractLifeCycle
-