OrConnEvent

Struct OrConnEvent 

Source
pub struct OrConnEvent {
    pub id: Option<String>,
    pub status: OrStatus,
    pub target: String,
    pub reason: Option<OrClosureReason>,
    pub num_circuits: Option<u32>,
    /* private fields */
}
Expand description

Event indicating that an OR (Onion Router) connection status has changed.

OR connection events track the status of connections between Tor relays. These are the TLS connections that carry circuit traffic between nodes in the Tor network.

§Connection Lifecycle

OR connections progress through these states:

  1. OrStatus::New - Connection initiated
  2. OrStatus::Launched - Connection attempt in progress
  3. OrStatus::Connected - TLS handshake completed
  4. OrStatus::Failed or OrStatus::Closed - Connection terminated

§Example

use stem_rs::events::OrConnEvent;
use stem_rs::OrStatus;

fn handle_orconn(event: &OrConnEvent) {
    match event.status {
        OrStatus::Connected => {
            println!("Connected to relay: {}", event.target);
        }
        OrStatus::Failed | OrStatus::Closed => {
            println!("Connection to {} ended: {:?}", event.target, event.reason);
        }
        _ => {}
    }
}

§See Also

Fields§

§id: Option<String>

Connection identifier (may be None for older Tor versions).

§status: OrStatus

Current status of the OR connection.

§target: String

Target relay address (IP:port or fingerprint).

§reason: Option<OrClosureReason>

Reason for connection closure.

§num_circuits: Option<u32>

Number of circuits using this connection.

Implementations§

Source§

impl OrConnEvent

Source

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

Parses an OR connection event from raw control protocol content.

§Arguments
  • content - The event content after the event type
§Event Format
Target Status [REASON=...] [NCIRCS=...] [ID=...]
§Errors

Returns Error::Protocol if:

  • Required fields are missing
  • The status is not a recognized value

Trait Implementations§

Source§

impl Clone for OrConnEvent

Source§

fn clone(&self) -> OrConnEvent

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 OrConnEvent

Source§

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

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

impl Event for OrConnEvent

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.