pub(crate) struct StreamTarget {
pub(crate) hop: Option<HopLocation>,
pub(crate) stream_id: StreamId,
pub(crate) relay_cell_format: RelayCellFormat,
pub(crate) rate_limit_stream: Receiver<StreamRateLimit>,
pub(crate) tx: Sender<AnyRelayMsg, MpscSpec>,
pub(crate) tunnel: Tunnel,
}Expand description
Internal handle, used to implement a stream on a particular tunnel.
The reader and the writer for a stream should hold a StreamTarget for the stream;
the reader should additionally hold an mpsc::Receiver to get
relay messages for the stream.
When all the StreamTargets for a stream are dropped, the Reactor will
close the stream by sending an END message to the other side.
You can close a stream earlier by using StreamTarget::close
or StreamTarget::close_pending.
Fields§
§hop: Option<HopLocation>Which hop of the circuit this stream is with.
stream_id: StreamIdReactor ID for this stream.
relay_cell_format: RelayCellFormatEncoding to use for relay cells sent on this stream.
This is mostly irrelevant, except when deciding how many bytes we can pack in a DATA message.
rate_limit_stream: Receiver<StreamRateLimit>A Stream that provides updates to the rate limit for sending data.
tx: Sender<AnyRelayMsg, MpscSpec>Channel to send cells down.
tunnel: TunnelReference to the tunnel that this stream is on.
Implementations§
Source§impl StreamTarget
impl StreamTarget
Sourcepub(crate) async fn send(&mut self, msg: AnyRelayMsg) -> Result<()>
pub(crate) async fn send(&mut self, msg: AnyRelayMsg) -> Result<()>
Deliver a relay message for the stream that owns this StreamTarget.
The StreamTarget will set the correct stream ID and pick the right hop, but will not validate that the message is well-formed or meaningful in context.
Sourcepub(crate) fn close_pending(
&self,
message: CloseStreamBehavior,
) -> Result<Receiver<Result<()>>>
pub(crate) fn close_pending( &self, message: CloseStreamBehavior, ) -> Result<Receiver<Result<()>>>
Close the pending stream that owns this StreamTarget, delivering the specified END message (if any)
The stream is closed by sending a control message (CtrlMsg::ClosePendingStream)
to the reactor.
Returns a oneshot::Receiver that can be used to await the reactor’s response.
The StreamTarget will set the correct stream ID and pick the right hop, but will not validate that the message is well-formed or meaningful in context.
Note that in many cases, the actual contents of an END message can leak unwanted
information. Please consider carefully before sending anything but an
End::new_misc() message over a ClientTunnel.
(For onion services, we send DONE )
In addition to sending the END message, this function also ensures the state of the stream map entry of this stream is updated accordingly.
Normally, you shouldn’t need to call this function, as streams are implicitly closed by the
reactor when their corresponding StreamTarget is dropped. The only valid use of this
function is for closing pending incoming streams (a stream is said to be pending if we have
received the message initiating the stream but have not responded to it yet).
NOTE: This function should be called at most once per request. Calling it twice is an error.
Sourcepub(crate) fn close(&mut self)
pub(crate) fn close(&mut self)
Queue a “close” for the stream corresponding to this StreamTarget.
Unlike close_pending, this method does not allow the caller to provide an END message.
Once this method has been called, no more messages may be sent with StreamTarget::send,
on this `StreamTarget`` or any clone of it.
The reactor will try to flush any already-send messages before it closes the stream.
You don’t need to call this method if the stream is closing because all of its StreamTargets have been dropped.
Sourcepub(crate) fn protocol_error(&mut self)
pub(crate) fn protocol_error(&mut self)
Called when a circuit-level protocol error has occurred and the tunnel needs to shut down.
Sourcepub(crate) fn send_sendme(&mut self) -> Result<()>
pub(crate) fn send_sendme(&mut self) -> Result<()>
Request to send a SENDME cell for this stream.
This sends a request to the circuit reactor to send a stream-level SENDME, but it does not block or wait for a response from the circuit reactor. An error is only returned if we are unable to send the request. This means that if the circuit reactor is unable to send the SENDME, we are not notified of this here and an error will not be returned.
Sourcepub(crate) fn drain_rate_update(&mut self, rate: XonKbpsEwma) -> Result<()>
pub(crate) fn drain_rate_update(&mut self, rate: XonKbpsEwma) -> Result<()>
Inform the circuit reactor that there has been a change in the drain rate for this stream.
Typically the circuit reactor would send this new rate in an XON message to the other end of the stream. But it may decide not to, and may discard this update. For example the stream may have a large amount of buffered data, and the reactor may not want to send an XON while the buffer is large.
This sends a message to inform the circuit reactor of the new drain rate, but it does not block or wait for a response from the reactor. An error is only returned if we are unable to send the update.
Sourcepub(crate) fn tunnel(&self) -> &Tunnel
pub(crate) fn tunnel(&self) -> &Tunnel
Return a reference to the tunnel that this StreamTarget is using.
Sourcepub(crate) fn relay_cell_format(&self) -> RelayCellFormat
pub(crate) fn relay_cell_format(&self) -> RelayCellFormat
Return the kind of relay cell in use on this StreamTarget.
Sourcepub(crate) fn rate_limit_stream(&self) -> &Receiver<StreamRateLimit>
pub(crate) fn rate_limit_stream(&self) -> &Receiver<StreamRateLimit>
A Stream that provides updates to the rate limit for sending data.
Trait Implementations§
Source§impl Clone for StreamTarget
impl Clone for StreamTarget
Source§fn clone(&self) -> StreamTarget
fn clone(&self) -> StreamTarget
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl !Freeze for StreamTarget
impl !RefUnwindSafe for StreamTarget
impl Send for StreamTarget
impl Sync for StreamTarget
impl Unpin for StreamTarget
impl UnsafeUnpin for StreamTarget
impl !UnwindSafe for StreamTarget
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> PossiblyOption<T> for T
impl<T> PossiblyOption<T> for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.