pub(crate) struct Reactor<R: Runtime, F: ForwardHandler, B: BackwardHandler> {
unique_id: UniqId,
forward: Option<ForwardReactor<R, F>>,
backward: Option<BackwardReactor<B>>,
control: UnboundedReceiver<CtrlMsg<F::CtrlMsg, B::CtrlMsg>>,
command: UnboundedReceiver<CtrlCmd<F::CtrlCmd, B::CtrlCmd>>,
fwd_ctrl: ReactorCtrl<CtrlCmd<F::CtrlCmd>, CtrlMsg<F::CtrlMsg>>,
bwd_ctrl: ReactorCtrl<CtrlCmd<B::CtrlCmd>, CtrlMsg<B::CtrlMsg>>,
}Expand description
The entry point of the circuit reactor subsystem.
Fields§
§unique_id: UniqIdThe process-unique identifier of this circuit.
Used for logging.
forward: Option<ForwardReactor<R, F>>The reactor for handling
- cells moving in the forward direction (from the client towards exit), if we are a relay
- incoming cells (coming from the guard), if we are a client
Optional so we can move it out of self in run().
backward: Option<BackwardReactor<B>>The reactor for handling
- cells moving in the backward direction (from the exit towards client), if we are a relay
- outgoing cells (moving towards the guard), if we are a client
Optional so we can move it out of self in run().
control: UnboundedReceiver<CtrlMsg<F::CtrlMsg, B::CtrlMsg>>Receiver for control messages for this reactor, sent by reactor handle objects.
command: UnboundedReceiver<CtrlCmd<F::CtrlCmd, B::CtrlCmd>>Receiver for command messages for this reactor, sent by reactor handle objects.
This MPSC channel is polled in run.
NOTE: this is a separate channel from control, because some messages
have higher priority and need to be handled even if the inbound_chan_tx is not
ready (whereas control messages are not read until the inbound_chan_tx sink
is ready to accept cells).
fwd_ctrl: ReactorCtrl<CtrlCmd<F::CtrlCmd>, CtrlMsg<F::CtrlMsg>>Control channels for the ForwardReactor.
Handles CtrlCmd::Forward and CtrlMsg::Forward messages.
bwd_ctrl: ReactorCtrl<CtrlCmd<B::CtrlCmd>, CtrlMsg<B::CtrlMsg>>Control channels for the BackwardReactor.
Handles CtrlCmd::Backward and CtrlMsg::Backward messages.
Implementations§
Source§impl<R: Runtime, F: ForwardHandler, B: BackwardHandler> Reactor<R, F, B>
impl<R: Runtime, F: ForwardHandler, B: BackwardHandler> Reactor<R, F, B>
Source§impl<R: Runtime, F: ForwardHandler + ControlHandler, B: BackwardHandler + ControlHandler> Reactor<R, F, B>
impl<R: Runtime, F: ForwardHandler + ControlHandler, B: BackwardHandler + ControlHandler> Reactor<R, F, B>
Sourcepub(crate) fn new(
runtime: R,
channel: &Arc<Channel>,
circ_id: CircId,
unique_id: UniqId,
inbound_chan_rx: Receiver<AnyChanMsg, MpscSpec>,
forward_impl: F,
backward_impl: B,
hop_mgr: HopMgr<R>,
padding_ctrl: PaddingController,
padding_event_stream: PaddingEventStream,
bwd_rx: Receiver<ReadyStreamMsg>,
fwd_events: Receiver<F::CircEvent>,
memquota: &CircuitAccount,
) -> (Self, CircReactorHandle<F, B>)
pub(crate) fn new( runtime: R, channel: &Arc<Channel>, circ_id: CircId, unique_id: UniqId, inbound_chan_rx: Receiver<AnyChanMsg, MpscSpec>, forward_impl: F, backward_impl: B, hop_mgr: HopMgr<R>, padding_ctrl: PaddingController, padding_event_stream: PaddingEventStream, bwd_rx: Receiver<ReadyStreamMsg>, fwd_events: Receiver<F::CircEvent>, memquota: &CircuitAccount, ) -> (Self, CircReactorHandle<F, B>)
Create a new circuit reactor.
The reactor will send outbound messages on channel, receive incoming
messages on inbound_chan_rx, and identify this circuit by the channel-local
CircId provided.
The internal unique identifier for this circuit will be unique_id.
Sourcefn handle_shutdown(&self) -> StdResult<(), ReactorError>
fn handle_shutdown(&self) -> StdResult<(), ReactorError>
Handle a shutdown request.
Sourcefn handle_command(
&mut self,
cmd: CtrlCmd<F::CtrlCmd, B::CtrlCmd>,
) -> StdResult<(), ReactorError>
fn handle_command( &mut self, cmd: CtrlCmd<F::CtrlCmd, B::CtrlCmd>, ) -> StdResult<(), ReactorError>
Handle a CtrlCmd.
Sourcefn handle_control(
&mut self,
cmd: CtrlMsg<F::CtrlMsg, B::CtrlMsg>,
) -> StdResult<(), ReactorError>
fn handle_control( &mut self, cmd: CtrlMsg<F::CtrlMsg, B::CtrlMsg>, ) -> StdResult<(), ReactorError>
Handle a CtrlMsg.
Auto Trait Implementations§
impl<R, F, B> Freeze for Reactor<R, F, B>
impl<R, F, B> !RefUnwindSafe for Reactor<R, F, B>
impl<R, F, B> Send for Reactor<R, F, B>where
F: Send,
B: Send,
<F as ForwardHandler>::CircEvent: Send,
<F as ControlHandler>::CtrlMsg: Send,
<B as ControlHandler>::CtrlMsg: Send,
<F as ControlHandler>::CtrlCmd: Send,
<B as ControlHandler>::CtrlCmd: Send,
impl<R, F, B> !Sync for Reactor<R, F, B>
impl<R, F, B> Unpin for Reactor<R, F, B>
impl<R, F, B> UnsafeUnpin for Reactor<R, F, B>
impl<R, F, B> !UnwindSafe for Reactor<R, F, B>
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> 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> 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.