SimulatedChannel

Struct SimulatedChannel 

Source
pub struct SimulatedChannel { /* private fields */ }
Expand description

Represents a simulated channel, and is responsible for managing addition and removal of HTLCs from the channel and sanity checks. Channel state is tracked unidirectionally for each participant in the channel.

Each node represented in the channel tracks only its outgoing HTLCs, and balance is transferred between the two nodes as they settle or fail. Given some channel: node_1 <––> node_2:

  • HTLC sent node_1 -> node_2: added to in-flight outgoing htlcs on node_1.
  • HTLC sent node_2 -> node_1: added to in-flight outgoing htlcs on node_2.

Rules for managing balance are as follows:

  • When an HTLC is in flight, the channel’s local outgoing liquidity decreases (as it’s locked up).
  • When an HTLC fails, the balance is returned to the local node (the one that it was in-flight / outgoing on).
  • When an HTLC succeeds, the balance is sent to the remote node (the one that did not track it as in-flight).

With each state transition, the simulated channel checks that the sum of its local balances and in-flight equal the total channel capacity. Failure of this sanity check represents a critical failure in the state machine.

Implementations§

Source§

impl SimulatedChannel

Source

pub fn new( capacity_msat: u64, short_channel_id: ShortChannelID, node_1: ChannelPolicy, node_2: ChannelPolicy, ) -> Self

Creates a new channel with the capacity and policies provided. The total capacity of the channel is evenly split between the channel participants (this is an arbitrary decision).

Trait Implementations§

Source§

impl Clone for SimulatedChannel

Source§

fn clone(&self) -> SimulatedChannel

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

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> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
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> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
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> 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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