Class HTTP2Session
- All Implemented Interfaces:
Session,ISession,Parser.Listener,Container,Destroyable,Dumpable,Dumpable.DumpableContainer,LifeCycle
- Direct Known Subclasses:
HTTP2ClientSession,HTTP2ServerSession
-
Nested Class Summary
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.ListenerNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.ListenerNested classes/interfaces inherited from interface org.eclipse.jetty.http2.parser.Parser.Listener
Parser.Listener.Adapter, Parser.Listener.WrapperNested classes/interfaces inherited from interface org.eclipse.jetty.http2.api.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 TypeMethodDescriptionprotected voidbooleanInvoked internally and by applications to send a GO_AWAY frame to the other peer.protected IStreamcreateLocalStream(int streamId, MetaData.Request request, Consumer<Throwable> failFn) protected IStreamcreateRemoteStream(int streamId, MetaData.Request request) voidEnqueues the given DATA frame to be written to the connection.voidprotected voiddoStop()Stops the managed lifecycle beans in the reverse order they were added.voiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.voidEnqueues the given frames to be written to the connection.longintprotected intintintintintintgetStream(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 IStreamnewStream(int streamId, MetaData.Request request, boolean local) voidnewStream(HeadersFrame frame, Promise<Stream> promise, Stream.Listener listener) Sends the given HEADERSframeto create a newStream.voidnewStream(IStream.FrameList frames, Promise<Stream> promise, Stream.Listener listener) Sends the given list of frames to create a newStream.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 voidnotifyHeaders(IStream stream, HeadersFrame frame) protected booleannotifyIdleTimeout(Session session) protected Stream.ListenernotifyNewStream(Stream stream, HeadersFrame frame) protected voidnotifyPing(Session session, PingFrame frame) protected voidnotifyReset(Session session, ResetFrame frame) protected voidnotifySettings(Session session, SettingsFrame frame) voidonConnectionFailure(int error, String reason) voidvoidCallback method invoked when a DATA frame is received.voidonFlushed(long bytes) Callback method invoked when bytes are flushed to the network.voidCallback method invoked during an HTTP/1.1 to HTTP/2 upgrade requests to process the given synthetic frame.voidonGoAway(GoAwayFrame frame) This method is called when receiving a GO_AWAY from the other peer.abstract voidonHeaders(HeadersFrame frame) booleanThis method is invoked when the idle timeout expires.voidvoidonPriority(PriorityFrame 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 final voidonStreamOpened(IStream stream) voidonWindowUpdate(WindowUpdateFrame frame) voidonWindowUpdate(IStream stream, WindowUpdateFrame frame) Callback method invoked when a WINDOW_UPDATE frame has been received.voidSends the given PINGframe.intpriority(PriorityFrame frame, Callback callback) Sends the given PRIORITYframe.voidpush(IStream stream, Promise<Stream> promise, PushPromiseFrame frame, Stream.Listener listener) Enqueues the given PUSH_PROMISE frame to be written to the connection.booleanremoveStream(IStream stream) Removes the givenstream.voidsetConnectProtocolEnabled(boolean connectProtocolEnabled) voidsetInitialSessionRecvWindow(int initialSessionRecvWindow) voidsetMaxEncoderTableCapacity(int maxEncoderTableCapacity) voidsetMaxLocalStreams(int maxLocalStreams) voidsetMaxRemoteStreams(int maxRemoteStreams) 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) Updates the session receive window by the givendelta.intupdateSendWindow(int delta) Updates the session send window by the givendelta.Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, destroy, doStart, dump, dump, dumpObjects, dumpStdErr, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, start, stop, unmanage, updateBean, updateBean, updateBeans, updateBeansMethods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stopMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.jetty.util.component.Container
getCachedBeans, getEventListenersMethods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpableMethods inherited from interface org.eclipse.jetty.http2.parser.Parser.Listener
onPushPromise
-
Constructor Details
-
HTTP2Session
public HTTP2Session(Scheduler scheduler, EndPoint endPoint, Parser parser, Generator generator, Session.Listener listener, FlowControlStrategy flowControl, int initialStreamId)
-
-
Method Details
-
doStop
Description copied from class:ContainerLifeCycleStops the managed lifecycle beans in the reverse order they were added.- Overrides:
doStopin classContainerLifeCycle- Throws:
Exception- If there was a problem stopping. Will cause a transition to FAILED state
-
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) -
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()- Specified by:
getBytesWrittenin interfaceISession- Returns:
- the number of bytes written by this session
-
onData
- Specified by:
onDatain interfaceParser.Listener
-
onData
Description copied from interface:ISessionCallback method invoked when a DATA frame is received.
-
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
-
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
Description copied from interface:ISessionCallback method invoked when a WINDOW_UPDATE frame has been received.
- Specified by:
onWindowUpdatein interfaceISession- Parameters:
stream- the stream the window update belongs to, or null if the window update belongs to the sessionframe- the WINDOW_UPDATE frame received
-
onStreamFailure
- Specified by:
onStreamFailurein interfaceParser.Listener
-
onConnectionFailure
- Specified by:
onConnectionFailurein interfaceParser.Listener
-
abort
-
newStream
Description copied from interface:SessionSends the given HEADERS
frameto create a newStream. -
newStream
Description copied from interface:ISessionSends the given list of frames to create a new
Stream. -
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(IStream stream, Promise<Stream> promise, PushPromiseFrame frame, Stream.Listener listener) Description copied from interface:ISessionEnqueues the given PUSH_PROMISE frame to be written to the connection.
Differently from
ISession.frames(IStream, List, Callback), this method generates atomically the stream id for the pushed stream. -
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:ISessionGracefully 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
public boolean isClosed() -
getCloseState
-
frames
Description copied from interface:ISessionEnqueues the given frames to be written to the connection.
-
data
Description copied from interface:ISessionEnqueues the given DATA frame to be written to the connection.
-
createLocalStream
protected IStream createLocalStream(int streamId, MetaData.Request request, Consumer<Throwable> failFn) -
createRemoteStream
-
removeStream
Description copied from interface:ISessionRemoves the given
stream.- Specified by:
removeStreamin interfaceISession- Parameters:
stream- the stream to remove- Returns:
- whether the stream was removed
-
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) Description copied from interface:ISessionUpdates the session send window by the given
delta.- Specified by:
updateSendWindowin interfaceISession- Parameters:
delta- the delta value (positive or negative) to add to the session send window- Returns:
- the previous value of the session send window
-
updateRecvWindow
public int updateRecvWindow(int delta) Description copied from interface:ISessionUpdates the session receive window by the given
delta.- Specified by:
updateRecvWindowin interfaceISession- Parameters:
delta- the delta value (positive or negative) to add to the session receive window- Returns:
- the previous value of the session receive window
-
isPushEnabled
@ManagedAttribute(value="Whether HTTP/2 push is enabled", readonly=true) public boolean isPushEnabled()- Specified by:
isPushEnabledin interfaceISession- 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.
- Specified by:
onShutdownin interfaceISession- See Also:
-
onIdleTimeout
public boolean onIdleTimeout()This method is invoked when the idle timeout expires.
- Specified by:
onIdleTimeoutin interfaceISession- Returns:
- true if the session should be closed, false otherwise
- See Also:
-
onFrame
Description copied from interface:ISessionCallback method invoked during an HTTP/1.1 to HTTP/2 upgrade requests to process the given synthetic frame.
-
onStreamOpened
-
onFlushed
Description copied from interface:ISessionCallback method invoked when bytes are flushed to the network.
- Specified by:
onFlushedin interfaceISession- Parameters:
bytes- the number of bytes flushed to the network- Throws:
IOException- if the flush should fail
-
disconnect
public void disconnect() -
isDisconnected
public boolean isDisconnected() -
getLastRemoteStreamId
protected int getLastRemoteStreamId() -
updateLastRemoteStreamId
protected void updateLastRemoteStreamId(int streamId) -
notifyNewStream
-
notifySettings
-
notifyPing
-
notifyReset
-
notifyGoAway
-
notifyClose
-
notifyIdleTimeout
-
notifyFailure
-
notifyHeaders
-
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- Overrides:
dumpin classContainerLifeCycle- 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
-