Skip to main content

PeerChange

Struct PeerChange 

Source
pub struct PeerChange {
    pub id: Id,
    pub derp_region: Option<RegionId>,
    pub cap: Option<CapabilityVersion>,
    pub cap_map: Option<NodeCapMap>,
    pub underlay_addresses: Option<Vec<SocketAddr>>,
    pub node_key: Option<NodePublicKey>,
    pub key_signature: Option<Vec<u8>>,
    pub disco_key: Option<DiscoPublicKey>,
    pub node_key_expiry: Option<DateTime<Utc>>,
    pub online: Option<bool>,
    pub last_seen: Option<DateTime<Utc>>,
}
Expand description

An incremental update to a single already-known peer Node, carried in MapResponse::peers_changed_patch.

Control sends a patch (rather than a full node in peers_changed) when only a peer’s reachability changes mid-session — most importantly its UDP endpoints and home derp_region when an idle peer re-establishes connectivity. Every field is Option: a patch sets only the fields it carries and leaves the rest of the target node unchanged (see PeerTracker::apply_peer_update for the merge). Owned counterpart of the borrow-bound ts_control_serde::PeerChange; the fields that map onto a domain Node field are retained, including control’s online/last_seen liveness deltas — the dominant channel by which peer online transitions are delivered (see Node::online).

Fields§

§id: Id

The Node::id of the peer being mutated. If no peer with this id is in the current netmap, the patch is ignored (the wire contract — a patch never creates a node).

§derp_region: Option<RegionId>

If Some, the peer’s new home DERP region.

§cap: Option<CapabilityVersion>

If Some, the peer’s new advertised capability version.

§cap_map: Option<NodeCapMap>

If Some, the peer’s new capability map (replaces the prior map wholesale).

§underlay_addresses: Option<Vec<SocketAddr>>

If Some, the peer’s new UDP underlay endpoints (Endpoints in Go; replaces the prior set). This is the field that lets magicsock re-handshake a peer that moved.

§node_key: Option<NodePublicKey>

If Some, the peer’s new WireGuard public key (key rotation).

§key_signature: Option<Vec<u8>>

If Some, the marshalled TKA signature over the new node key. Re-verified at the peer-trust chokepoint when tailnet-lock enforcement is active.

§disco_key: Option<DiscoPublicKey>

If Some, the peer’s new disco public key.

§node_key_expiry: Option<DateTime<Utc>>

If Some, the peer’s new node-key expiry (KeyExpiry in Go). Maps to Node::node_key_expiry; carried so an expiry-only patch isn’t lost until the next full resync.

§online: Option<bool>

If Some, the peer’s new online status (PeerChange.Online). None here means “this patch did not touch online”, not “offline” — the merge sets Node::online only when present.

§last_seen: Option<DateTime<Utc>>

If Some, the peer’s new last-seen time (PeerChange.LastSeen). Maps to Node::last_seen.

Trait Implementations§

Source§

impl Clone for PeerChange

Source§

fn clone(&self) -> PeerChange

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for PeerChange

Source§

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

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

impl Eq for PeerChange

Source§

impl From<&PeerChange<'_>> for PeerChange

Source§

fn from(value: &PeerChange<'_>) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for PeerChange

Source§

fn eq(&self, other: &PeerChange) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for PeerChange

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more