breez_sdk_core::lightning::routing::gossip

Struct NetworkGraph

pub struct NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,
{ /* private fields */ }
Expand description

Represents the network as nodes and channels between them

Implementations§

§

impl<L> NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

pub fn handle_network_update(&self, network_update: &NetworkUpdate)

Handles any network updates originating from Events. Note that this will skip applying any NetworkUpdate::ChannelUpdateMessage to avoid leaking possibly identifying information of the sender to the public network.

pub fn get_chain_hash(&self) -> ChainHash

Gets the chain hash for this network graph.

§

impl<L> NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

pub fn new(network: Network, logger: L) -> NetworkGraph<L>

Creates a new, empty, network graph.

pub fn read_only(&self) -> ReadOnlyNetworkGraph<'_>

Returns a read-only view of the network graph.

pub fn get_last_rapid_gossip_sync_timestamp(&self) -> Option<u32>

The unix timestamp provided by the most recent rapid gossip sync. It will be set by the rapid sync process after every sync completion.

pub fn set_last_rapid_gossip_sync_timestamp( &self, last_rapid_gossip_sync_timestamp: u32, )

Update the unix timestamp provided by the most recent rapid gossip sync. This should be done automatically by the rapid sync process after every sync completion.

pub fn update_node_from_announcement( &self, msg: &NodeAnnouncement, ) -> Result<(), LightningError>

For an already known node (from channel announcements), update its stored properties from a given node announcement.

You probably don’t want to call this directly, instead relying on a P2PGossipSync’s RoutingMessageHandler implementation to call it indirectly. This may be useful to accept routing messages from a source using a protocol other than the lightning P2P protocol.

pub fn update_node_from_unsigned_announcement( &self, msg: &UnsignedNodeAnnouncement, ) -> Result<(), LightningError>

For an already known node (from channel announcements), update its stored properties from a given node announcement without verifying the associated signatures. Because we aren’t given the associated signatures here we cannot relay the node announcement to any of our peers.

pub fn update_channel_from_announcement<U>( &self, msg: &ChannelAnnouncement, utxo_lookup: &Option<U>, ) -> Result<(), LightningError>
where U: Deref, <U as Deref>::Target: UtxoLookup,

Store or update channel info from a channel announcement.

You probably don’t want to call this directly, instead relying on a P2PGossipSync’s RoutingMessageHandler implementation to call it indirectly. This may be useful to accept routing messages from a source using a protocol other than the lightning P2P protocol.

If a UtxoLookup object is provided via utxo_lookup, it will be called to verify the corresponding UTXO exists on chain and is correctly-formatted.

pub fn update_channel_from_announcement_no_lookup( &self, msg: &ChannelAnnouncement, ) -> Result<(), LightningError>

Store or update channel info from a channel announcement.

You probably don’t want to call this directly, instead relying on a P2PGossipSync’s RoutingMessageHandler implementation to call it indirectly. This may be useful to accept routing messages from a source using a protocol other than the lightning P2P protocol.

This will skip verification of if the channel is actually on-chain.

pub fn update_channel_from_unsigned_announcement<U>( &self, msg: &UnsignedChannelAnnouncement, utxo_lookup: &Option<U>, ) -> Result<(), LightningError>
where U: Deref, <U as Deref>::Target: UtxoLookup,

Store or update channel info from a channel announcement without verifying the associated signatures. Because we aren’t given the associated signatures here we cannot relay the channel announcement to any of our peers.

If a UtxoLookup object is provided via utxo_lookup, it will be called to verify the corresponding UTXO exists on chain and is correctly-formatted.

pub fn add_channel_from_partial_announcement( &self, short_channel_id: u64, timestamp: u64, features: Features<ChannelContext>, node_id_1: PublicKey, node_id_2: PublicKey, ) -> Result<(), LightningError>

Update channel from partial announcement data received via rapid gossip sync

timestamp: u64: Timestamp emulating the backdated original announcement receipt (by the rapid gossip sync server)

All other parameters as used in msgs::UnsignedChannelAnnouncement fields.

pub fn channel_failed_permanent(&self, short_channel_id: u64)

Marks a channel in the graph as failed permanently.

The channel and any node for which this was their last channel are removed from the graph.

pub fn node_failed_permanent(&self, node_id: &PublicKey)

Marks a node in the graph as permanently failed, effectively removing it and its channels from local storage.

pub fn remove_stale_channels_and_tracking(&self)

Removes information about channels that we haven’t heard any updates about in some time. This can be used regularly to prune the network graph of channels that likely no longer exist.

While there is no formal requirement that nodes regularly re-broadcast their channel updates every two weeks, the non-normative section of BOLT 7 currently suggests that pruning occur for updates which are at least two weeks old, which we implement here.

Note that for users of the lightning-background-processor crate this method may be automatically called regularly for you.

This method will also cause us to stop tracking removed nodes and channels if they have been in the map for a while so that these can be resynced from gossip in the future.

This method is only available with the std feature. See NetworkGraph::remove_stale_channels_and_tracking_with_time for no-std use.

pub fn remove_stale_channels_and_tracking_with_time( &self, current_time_unix: u64, )

Removes information about channels that we haven’t heard any updates about in some time. This can be used regularly to prune the network graph of channels that likely no longer exist.

While there is no formal requirement that nodes regularly re-broadcast their channel updates every two weeks, the non-normative section of BOLT 7 currently suggests that pruning occur for updates which are at least two weeks old, which we implement here.

This method will also cause us to stop tracking removed nodes and channels if they have been in the map for a while so that these can be resynced from gossip in the future.

This function takes the current unix time as an argument. For users with the std feature enabled, NetworkGraph::remove_stale_channels_and_tracking may be preferable.

pub fn update_channel(&self, msg: &ChannelUpdate) -> Result<(), LightningError>

For an already known (from announcement) channel, update info about one of the directions of the channel.

You probably don’t want to call this directly, instead relying on a P2PGossipSync’s RoutingMessageHandler implementation to call it indirectly. This may be useful to accept routing messages from a source using a protocol other than the lightning P2P protocol.

If built with no-std, any updates with a timestamp more than two weeks in the past or materially in the future will be rejected.

pub fn update_channel_unsigned( &self, msg: &UnsignedChannelUpdate, ) -> Result<(), LightningError>

For an already known (from announcement) channel, update info about one of the directions of the channel without verifying the associated signatures. Because we aren’t given the associated signatures here we cannot relay the channel update to any of our peers.

If built with no-std, any updates with a timestamp more than two weeks in the past or materially in the future will be rejected.

pub fn verify_channel_update( &self, msg: &ChannelUpdate, ) -> Result<(), LightningError>

For an already known (from announcement) channel, verify the given ChannelUpdate.

This checks whether the update currently is applicable by Self::update_channel.

If built with no-std, any updates with a timestamp more than two weeks in the past or materially in the future will be rejected.

Trait Implementations§

§

impl<L> Display for NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

§

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

Formats the value using the given formatter. Read more
§

impl<L> PartialEq for NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

§

fn eq(&self, other: &NetworkGraph<L>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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.
§

impl<L> ReadableArgs<L> for NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

§

fn read<R>(reader: &mut R, logger: L) -> Result<NetworkGraph<L>, DecodeError>
where R: Read,

Reads a Self in from the given Read.
§

impl<L> Writeable for NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

§

fn write<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Writer,

Writes self out to the given Writer.
§

fn encode(&self) -> Vec<u8>

Writes self out to a Vec<u8>.
§

fn serialized_length(&self) -> usize

Gets the length of this object after it has been serialized. This can be overridden to optimize cases where we prepend an object with its length.
§

impl<L> Eq for NetworkGraph<L>
where L: Deref, <L as Deref>::Target: Logger,

Auto Trait Implementations§

§

impl<L> !Freeze for NetworkGraph<L>

§

impl<L> RefUnwindSafe for NetworkGraph<L>
where L: RefUnwindSafe,

§

impl<L> Send for NetworkGraph<L>
where L: Send,

§

impl<L> Sync for NetworkGraph<L>
where L: Sync,

§

impl<L> Unpin for NetworkGraph<L>
where L: Unpin,

§

impl<L> UnwindSafe for NetworkGraph<L>
where L: UnwindSafe,

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
§

impl<T> Any for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

§

fn type_name(&self) -> &'static str

§

impl<T> AnySync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

§

impl<T> AsAny for T
where T: Any,

§

fn as_any(&self) -> &(dyn Any + 'static)

§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

§

fn type_name(&self) -> &'static str

Gets the type name of self
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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
§

impl<T> Downcast for T
where T: AsAny + ?Sized,

§

fn is<T>(&self) -> bool
where T: AsAny,

Returns true if the boxed type is the same as T. Read more
§

fn downcast_ref<T>(&self) -> Option<&T>
where T: AsAny,

Forward to the method defined on the type Any.
§

fn downcast_mut<T>(&mut self) -> Option<&mut T>
where T: AsAny,

Forward to the method defined on the type Any.
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.
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

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

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

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

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

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

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

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> DartSafe for T

§

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

§

impl<T> MaybeSendSync for T