BuildTimeoutSetEvent

Struct BuildTimeoutSetEvent 

Source
pub struct BuildTimeoutSetEvent {
    pub set_type: TimeoutSetType,
    pub total_times: Option<u32>,
    pub timeout: Option<u32>,
    pub xm: Option<u32>,
    pub alpha: Option<f64>,
    pub quantile: Option<f64>,
    pub timeout_rate: Option<f64>,
    pub close_timeout: Option<u32>,
    pub close_rate: Option<f64>,
    /* private fields */
}
Expand description

Event indicating that the circuit build timeout has changed.

Tor dynamically adjusts its circuit build timeout based on observed circuit construction times. This event is emitted when the timeout value changes, providing insight into network performance.

§Timeout Calculation

Tor uses a Pareto distribution to model circuit build times:

  • xm - The Pareto Xm parameter (minimum value)
  • alpha - The Pareto alpha parameter (shape)
  • quantile - The CDF cutoff quantile

§Set Types

The set_type indicates why the timeout changed:

§Example

use stem_rs::events::BuildTimeoutSetEvent;

fn handle_timeout(event: &BuildTimeoutSetEvent) {
    if let Some(timeout) = event.timeout {
        println!("Circuit timeout set to {}ms ({:?})", timeout, event.set_type);
    }
    if let Some(rate) = event.timeout_rate {
        println!("Timeout rate: {:.2}%", rate * 100.0);
    }
}

§See Also

Fields§

§set_type: TimeoutSetType

Type of timeout change.

§total_times: Option<u32>

Number of circuit build times used to calculate timeout.

§timeout: Option<u32>

Circuit build timeout in milliseconds.

§xm: Option<u32>

Pareto Xm parameter in milliseconds.

§alpha: Option<f64>

Pareto alpha parameter.

§quantile: Option<f64>

CDF quantile cutoff point.

§timeout_rate: Option<f64>

Ratio of circuits that timed out.

§close_timeout: Option<u32>

Duration to keep measurement circuits in milliseconds.

§close_rate: Option<f64>

Ratio of measurement circuits that were closed.

Implementations§

Source§

impl BuildTimeoutSetEvent

Source

pub fn parse(content: &str) -> Result<Self, Error>

Parses a build timeout set event from raw control protocol content.

§Arguments
  • content - The event content after the event type
§Event Format
SetType [TOTAL_TIMES=...] [TIMEOUT_MS=...] [XM=...] [ALPHA=...]
[CUTOFF_QUANTILE=...] [TIMEOUT_RATE=...] [CLOSE_MS=...] [CLOSE_RATE=...]
§Errors

Returns Error::Protocol if:

  • The set type is missing or unrecognized
  • Numeric values cannot be parsed

Trait Implementations§

Source§

impl Clone for BuildTimeoutSetEvent

Source§

fn clone(&self) -> BuildTimeoutSetEvent

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for BuildTimeoutSetEvent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Event for BuildTimeoutSetEvent

Source§

fn event_type(&self) -> EventType

Returns the type of this event. Read more
Source§

fn raw_content(&self) -> &str

Returns the raw, unparsed content of the event. Read more
Source§

fn arrived_at(&self) -> Instant

Returns the instant when this event was received. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.