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.StopException
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.Listener
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainer
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.Listener
Nested classes/interfaces inherited from interface org.eclipse.jetty.http2.parser.Parser.Listener
Parser.Listener.Adapter, Parser.Listener.Wrapper
Nested classes/interfaces inherited from interface org.eclipse.jetty.http2.api.Session
Session.Listener
-
Field Summary
-
Constructor Summary
ConstructorDescriptionHTTP2Session
(Scheduler scheduler, EndPoint endPoint, Parser parser, Generator generator, Session.Listener listener, FlowControlStrategy flowControl, int initialStreamId) -
Method Summary
Modifier and TypeMethodDescriptionprotected void
boolean
Invoked internally and by applications to send a GO_AWAY frame to the other peer.protected IStream
createLocalStream
(int streamId, MetaData.Request request, Consumer<Throwable> failFn) protected IStream
createRemoteStream
(int streamId, MetaData.Request request) void
Enqueues the given DATA frame to be written to the connection.void
protected void
doStop()
Stops the managed lifecycle beans in the reverse order they were added.void
dump
(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.void
Enqueues the given frames to be written to the connection.long
int
protected int
int
int
int
int
int
getStream
(int streamId) Retrieves the stream with the givenstreamId
.int
long
long
long
int
boolean
goAway
(GoAwayFrame frame, Callback callback) protected static boolean
isClientStream
(int streamId) boolean
isClosed()
boolean
boolean
protected boolean
isLocalStreamClosed
(int streamId) boolean
protected boolean
isRemoteStreamClosed
(int streamId) protected IStream
newStream
(int streamId, MetaData.Request request, boolean local) void
newStream
(HeadersFrame frame, Promise<Stream> promise, Stream.Listener listener) Sends the given HEADERSframe
to create a newStream
.void
newStream
(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 void
notifyClose
(Session session, GoAwayFrame frame, Callback callback) protected void
notifyFailure
(Session session, Throwable failure, Callback callback) protected void
notifyGoAway
(Session session, GoAwayFrame frame) protected void
notifyHeaders
(IStream stream, HeadersFrame frame) protected boolean
notifyIdleTimeout
(Session session) protected Stream.Listener
notifyNewStream
(Stream stream, HeadersFrame frame) protected void
notifyPing
(Session session, PingFrame frame) protected void
notifyReset
(Session session, ResetFrame frame) protected void
notifySettings
(Session session, SettingsFrame frame) void
onConnectionFailure
(int error, String reason) void
void
Callback method invoked when a DATA frame is received.void
onFlushed
(long bytes) Callback method invoked when bytes are flushed to the network.void
Callback method invoked during an HTTP/1.1 to HTTP/2 upgrade requests to process the given synthetic frame.void
onGoAway
(GoAwayFrame frame) This method is called when receiving a GO_AWAY from the other peer.abstract void
onHeaders
(HeadersFrame frame) boolean
This method is invoked when the idle timeout expires.void
void
onPriority
(PriorityFrame frame) void
onReset
(ResetFrame frame) protected void
void
onSettings
(SettingsFrame frame) void
onSettings
(SettingsFrame frame, boolean reply) void
This method is called when the TCP FIN is received from the remote peer.void
onStreamFailure
(int streamId, int error, String reason) protected final void
onStreamOpened
(IStream stream) void
onWindowUpdate
(WindowUpdateFrame frame) void
onWindowUpdate
(IStream stream, WindowUpdateFrame frame) Callback method invoked when a WINDOW_UPDATE frame has been received.void
Sends the given PINGframe
.int
priority
(PriorityFrame frame, Callback callback) Sends the given PRIORITYframe
.void
push
(IStream stream, Promise<Stream> promise, PushPromiseFrame frame, Stream.Listener listener) Enqueues the given PUSH_PROMISE frame to be written to the connection.boolean
removeStream
(IStream stream) Removes the givenstream
.void
setConnectProtocolEnabled
(boolean connectProtocolEnabled) void
setInitialSessionRecvWindow
(int initialSessionRecvWindow) void
setMaxEncoderTableCapacity
(int maxEncoderTableCapacity) void
setMaxLocalStreams
(int maxLocalStreams) void
setMaxRemoteStreams
(int maxRemoteStreams) void
setStreamIdleTimeout
(long streamIdleTimeout) void
settings
(SettingsFrame frame, Callback callback) Sends the given SETTINGSframe
to configure the session.void
setWriteThreshold
(int writeThreshold) shutdown()
Gracefully closes the session, returning aCompletableFuture
that is completed when all the streams currently being processed are completed.toString()
protected void
updateLastRemoteStreamId
(int streamId) int
updateRecvWindow
(int delta) Updates the session receive window by the givendelta
.int
updateSendWindow
(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, updateBeans
Methods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stop
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.eclipse.jetty.util.component.Container
getCachedBeans, getEventListeners
Methods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpable
Methods 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:ContainerLifeCycle
Stops the managed lifecycle beans in the reverse order they were added.- Overrides:
doStop
in 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:
getBytesWritten
in interfaceISession
- Returns:
- the number of bytes written by this session
-
onData
- Specified by:
onData
in interfaceParser.Listener
-
onData
Description copied from interface:ISession
Callback method invoked when a DATA frame is received.
-
isLocalStreamClosed
protected boolean isLocalStreamClosed(int streamId) -
isRemoteStreamClosed
protected boolean isRemoteStreamClosed(int streamId) -
onHeaders
- Specified by:
onHeaders
in interfaceParser.Listener
-
onPriority
- Specified by:
onPriority
in interfaceParser.Listener
-
onReset
- Specified by:
onReset
in interfaceParser.Listener
-
onResetForUnknownStream
-
onSettings
- Specified by:
onSettings
in interfaceParser.Listener
-
onSettings
-
onPing
- Specified by:
onPing
in interfaceParser.Listener
-
onGoAway
This method is called when receiving a GO_AWAY from the other peer.
- Specified by:
onGoAway
in interfaceParser.Listener
- Parameters:
frame
- the GO_AWAY frame that has been received.- See Also:
-
onWindowUpdate
- Specified by:
onWindowUpdate
in interfaceParser.Listener
-
onWindowUpdate
Description copied from interface:ISession
Callback method invoked when a WINDOW_UPDATE frame has been received.
- Specified by:
onWindowUpdate
in 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:
onStreamFailure
in interfaceParser.Listener
-
onConnectionFailure
- Specified by:
onConnectionFailure
in interfaceParser.Listener
-
abort
-
newStream
Description copied from interface:Session
Sends the given HEADERS
frame
to create a newStream
. -
newStream
Description copied from interface:ISession
Sends 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:Session
Sends the given PRIORITY
frame
.If the
frame
references astreamId
that does not exist (for example0
), then a newstreamId
will 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:ISession
Enqueues 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:Session
Sends the given SETTINGS
frame
to configure the session. -
ping
Description copied from interface:Session
Sends 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:ISession
Gracefully closes the session, returning a
CompletableFuture
that 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:ISession
Enqueues the given frames to be written to the connection.
-
data
Description copied from interface:ISession
Enqueues 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:ISession
Removes the given
stream
.- Specified by:
removeStream
in interfaceISession
- Parameters:
stream
- the stream to remove- Returns:
- whether the stream was removed
-
getStreams
- Specified by:
getStreams
in interfaceSession
- Returns:
- a snapshot of all the streams currently belonging to this session
-
getStreamCount
-
getStream
Description copied from interface:Session
Retrieves the stream with the given
streamId
. -
getLocalAddress
- Specified by:
getLocalAddress
in interfaceSession
- Returns:
- the local network address this session is bound to,
or
null
if this session is not bound to a network address
-
getLocalSocketAddress
- Specified by:
getLocalSocketAddress
in interfaceSession
- Returns:
- the local network address this session is bound to,
or
null
if this session is not bound to a network address
-
getRemoteAddress
- Specified by:
getRemoteAddress
in interfaceSession
- Returns:
- the remote network address this session is connected to,
or
null
if this session is not connected to a network address
-
getRemoteSocketAddress
- Specified by:
getRemoteSocketAddress
in interfaceSession
- Returns:
- the remote network address this session is connected to,
or
null
if 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:ISession
Updates the session send window by the given
delta
.- Specified by:
updateSendWindow
in 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:ISession
Updates the session receive window by the given
delta
.- Specified by:
updateRecvWindow
in 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:
isPushEnabled
in 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:
onShutdown
in interfaceISession
- See Also:
-
onIdleTimeout
public boolean onIdleTimeout()This method is invoked when the idle timeout expires.
- Specified by:
onIdleTimeout
in interfaceISession
- Returns:
- true if the session should be closed, false otherwise
- See Also:
-
onFrame
Description copied from interface:ISession
Callback method invoked during an HTTP/1.1 to HTTP/2 upgrade requests to process the given synthetic frame.
-
onStreamOpened
-
onFlushed
Description copied from interface:ISession
Callback method invoked when bytes are flushed to the network.
- Specified by:
onFlushed
in 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:Dumpable
Dump 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:
dump
in interfaceDumpable
- Overrides:
dump
in 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:
toString
in classAbstractLifeCycle
-