Class HTTP2Stream
- All Implemented Interfaces:
Closeable,AutoCloseable,Stream,IStream,CyclicTimeouts.Expirable,Attachable,Callback,Dumpable,Invocable
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.Callback
Callback.Completable, Callback.Completing, Callback.NestedNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface org.eclipse.jetty.util.thread.Invocable
Invocable.InvocationType, Invocable.ReadyTask, Invocable.TaskNested classes/interfaces inherited from interface org.eclipse.jetty.http2.IStream
IStream.FrameListNested classes/interfaces inherited from interface org.eclipse.jetty.http2.api.Stream
Stream.Listener -
Field Summary
Fields inherited from interface org.eclipse.jetty.util.thread.Invocable
__nonBlocking -
Constructor Summary
ConstructorsConstructorDescriptionHTTP2Stream(ISession session, int streamId, MetaData.Request request, boolean local) HTTP2Stream(Scheduler scheduler, ISession session, int streamId, MetaData.Request request, boolean local) Deprecated. -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Forcibly closes this stream.voidcommit()Marks this stream as committed.voidSends the given DATAframe.intdataSize()voiddemand(long n) DemandsnmoreDATAframes for this stream.dump()voiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.booleanFail all data queued in the stream and reset demand to 0.voidCallback invoked when the operation fails.getAttribute(String key) longReturns the expiration time in nanoseconds.intgetId()longintintvoidheaders(HeadersFrame frame, Callback callback) Sends the given HEADERSframe.booleanisClosed()booleanbooleanisLocal()booleanbooleanisOpen()booleanbooleanisReset()booleanvoidnotIdle()Marks this stream as not idle so that theidle timeoutis postponed.voidonClose()protected voidonIdleExpired(TimeoutException timeout) voidProcesses the givenframe, belonging to this stream.voidpush(PushPromiseFrame frame, Promise<Stream> promise, Stream.Listener listener) Sends the given PUSH_PROMISEframe.removeAttribute(String key) voidreset(ResetFrame frame, Callback callback) Sends the given RST_STREAMframe.voidsend(IStream.FrameList frameList, Callback callback) Sends the given list of frames.voidsetAttachment(Object attachment) Attaches the given object to this stream for later retrieval.voidsetAttribute(String key, Object value) voidsetIdleTimeout(long idleTimeout) voidsetListener(Stream.Listener listener) voidCallback invoked when the operation completes.toString()booleanupdateClose(boolean update, CloseState.Event event) Updates the close state of this stream.intupdateRecvWindow(int delta) Updates the stream receive window by the givendelta.intupdateSendWindow(int delta) Updates the stream send window by the givendelta.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.jetty.util.Callback
completeWith
-
Constructor Details
-
HTTP2Stream
-
HTTP2Stream
@Deprecated public HTTP2Stream(Scheduler scheduler, ISession session, int streamId, MetaData.Request request, boolean local) Deprecated.
-
-
Method Details
-
getId
public int getId() -
getAttachment
- Specified by:
getAttachmentin interfaceAttachable- Returns:
- the object attached to this instance
- See Also:
-
setAttachment
Description copied from interface:AttachableAttaches the given object to this stream for later retrieval.- Specified by:
setAttachmentin interfaceAttachable- Parameters:
attachment- the object to attach to this instance
-
isLocal
public boolean isLocal() -
getSession
- Specified by:
getSessionin interfaceIStream- Specified by:
getSessionin interfaceStream- Returns:
- the session this stream is associated to
-
headers
Description copied from interface:StreamSends the given HEADERS
frame.Typically used to send an HTTP response or to send the HTTP response trailers.
-
send
Description copied from interface:IStreamSends the given list of frames.
Typically used to send HTTP headers along with content and possibly trailers.
-
push
Description copied from interface:StreamSends the given PUSH_PROMISE
frame. -
data
Description copied from interface:StreamSends the given DATA
frame. -
reset
Description copied from interface:StreamSends the given RST_STREAM
frame. -
getAttribute
- Specified by:
getAttributein interfaceStream- Parameters:
key- the attribute key- Returns:
- an arbitrary object associated with the given key to this stream or null if no object can be found for the given key.
- See Also:
-
setAttribute
- Specified by:
setAttributein interfaceStream- Parameters:
key- the attribute keyvalue- an arbitrary object to associate with the given key to this stream- See Also:
-
removeAttribute
- Specified by:
removeAttributein interfaceStream- Parameters:
key- the attribute key- Returns:
- the arbitrary object associated with the given key to this stream
- See Also:
-
isReset
public boolean isReset() -
isResetOrFailed
public boolean isResetOrFailed()- Specified by:
isResetOrFailedin interfaceIStream- Returns:
- whether this stream has been reset (locally or remotely) or has been failed
- See Also:
-
isClosed
public boolean isClosed() -
isRemotelyClosed
public boolean isRemotelyClosed()- Specified by:
isRemotelyClosedin interfaceIStream- Returns:
- whether the stream is closed remotely.
- See Also:
-
failAllData
Description copied from interface:IStreamFail all data queued in the stream and reset demand to 0.- Specified by:
failAllDatain interfaceIStream- Parameters:
x- the exception to fail the data with.- Returns:
- true if the end of the stream was reached, false otherwise.
-
isLocallyClosed
public boolean isLocallyClosed() -
commit
public void commit()Description copied from interface:IStreamMarks this stream as committed. -
isCommitted
public boolean isCommitted()- Specified by:
isCommittedin interfaceIStream- Returns:
- whether bytes for this stream have been sent to the remote peer.
- See Also:
-
dataSize
public int dataSize() -
isOpen
public boolean isOpen() -
notIdle
public void notIdle()Description copied from interface:IStreamMarks this stream as not idle so that the
idle timeoutis postponed. -
getExpireNanoTime
public long getExpireNanoTime()Description copied from interface:CyclicTimeouts.ExpirableReturns the expiration time in nanoseconds.
The value to return must be calculated taking into account the current nanoTime, for example:
expireNanoTime = NanoTime.now() + timeoutNanosReturning
Long.MAX_VALUEindicates that this entity does not expire.- Specified by:
getExpireNanoTimein interfaceCyclicTimeouts.Expirable- Returns:
- the expiration time in nanoseconds, or
Long.MAX_VALUEif this entity does not expire
-
getIdleTimeout
public long getIdleTimeout()- Specified by:
getIdleTimeoutin interfaceStream- Returns:
- the stream idle timeout
- See Also:
-
setIdleTimeout
public void setIdleTimeout(long idleTimeout) - Specified by:
setIdleTimeoutin interfaceStream- Parameters:
idleTimeout- the stream idle timeout- See Also:
-
onIdleExpired
-
getListener
- Specified by:
getListenerin interfaceIStream- Returns:
- the
Stream.Listenerassociated with this stream - See Also:
-
setListener
- Specified by:
setListenerin interfaceIStream- Parameters:
listener- theStream.Listenerassociated with this stream- See Also:
-
process
Description copied from interface:IStreamProcesses the given
frame, belonging to this stream. -
demand
public void demand(long n) Description copied from interface:StreamDemands
nmoreDATAframes for this stream. -
updateClose
Description copied from interface:IStreamUpdates the close state of this stream.
- Specified by:
updateClosein interfaceIStream- Parameters:
update- whether to update the close stateevent- the event that caused the close state update- Returns:
- whether the stream has been fully closed by this invocation
-
getSendWindow
public int getSendWindow() -
getRecvWindow
public int getRecvWindow() -
updateSendWindow
public int updateSendWindow(int delta) Description copied from interface:IStreamUpdates the stream send window by the given
delta.- Specified by:
updateSendWindowin interfaceIStream- Parameters:
delta- the delta value (positive or negative) to add to the stream send window- Returns:
- the previous value of the stream send window
-
updateRecvWindow
public int updateRecvWindow(int delta) Description copied from interface:IStreamUpdates the stream receive window by the given
delta.- Specified by:
updateRecvWindowin interfaceIStream- Parameters:
delta- the delta value (positive or negative) to add to the stream receive window- Returns:
- the previous value of the stream receive window
-
close
public void close()Description copied from interface:IStreamForcibly closes this stream.
-
onClose
public void onClose() -
succeeded
public void succeeded()Description copied from interface:CallbackCallback invoked when the operation completes.
-
failed
Description copied from interface:CallbackCallback invoked when the operation fails.
-
getInvocationType
- Specified by:
getInvocationTypein interfaceInvocable- Returns:
- The InvocationType of this object
-
dump
-
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
-