rust-lightning/ARCH.md
Jeffrey Czyz 98bc46beb9
Replace WatchEventProvider with chain::Filter
WatchEventProvider served as a means for replacing ChainWatchInterface.
However, it requires users to explicitly fetch WatchEvents, even if not
interested in them. Replace WatchEventProvider by chain::Filter, which
is an optional member of ChainMonitor. If set, interesting transactions
and output spends are registered such that blocks containing them can be
retrieved from a chain source in an efficient manner.

This is useful when the chain source is not a full node. For Electrum,
it allows for pre-filtered blocks. For BIP157/158, it serves as a means
to match against compact filters.
2020-09-30 22:40:33 -07:00

4.0 KiB

Rust-Lightning is broken into a number of high-level structures with APIs to hook them together, as well as APIs for you, the user, to provide external data.

The two most important structures which nearly every application of Rust-Lightning will need to use are ChannelManager and ChannelMonitor. ChannelManager holds multiple channels, routes payments between them, and exposes a simple API to make and receive payments. Individual ChannelMonitors monitor the on-chain state of a channel, punish counterparties if they misbehave, and force-close channels if they contain unresolved HTLCs which are near expiration. The chain::Watch interface provides a way for you to receive ChannelMonitorUpdates from ChannelManager and persist them to disk before the channel steps forward.

There are two additional important structures that you may use either on the same device as the ChannelManager or on a separate one. NetGraphMsgHandler handles receiving channel and node announcements, which are then used to calculate routes by get_route for sending payments. PeerManager handles the authenticated and encrypted communication protocol, monitoring for liveness of peers, routing messages to ChannelManager and NetGraphMsgHandler instances directly, and receiving messages from them via the EventsProvider interface.

These structs communicate with each other using a public API, so that you can easily add a proxy in between for special handling. Further, APIs for key generation, transaction broadcasting, block fetching, and fee estimation must be implemented and the data provided by you, the user.

The library does not rely on the presence of a runtime environment outside of access to heap, atomic integers, and basic Mutex primitives. This means the library will never spawn threads or take any action whatsoever except when you call into it. Thus, ChannelManager and PeerManager have public functions which you should call on a timer, network reads and writes are external and provided by you, and the library relies only on block time for current time knowledge.

At a high level, some of the common interfaces fit together as follows:


                     -----------------
                     | KeysInterface |  --------------
                     -----------------  | UserConfig |
         --------------------       |   --------------
  /------| MessageSendEvent |       |   |     ----------------
 |       --------------------       |   |     | FeeEstimator | <-----------------------
 |   (as MessageSendEventsProvider) |   |     ----------------                         \
 |                         ^        |   |    /                 ------------------------ |
 |                          \       |   |   /      ---------> | BroadcasterInterface |  |
 |                           \      |   |  /      /           ------------------------  |
 |                            \     v   v v      /                          ^           |
 |    (as                      ------------------       ----------------    |           |
 |    ChannelMessageHandler)-> | ChannelManager | ----> | chain::Watch |    |           |
 v               /             ------------------       ----------------    |           |
--------------- /                  (as EventsProvider)         ^            |           |
| PeerManager |-                             \                 |            |           |
---------------                               \                | (is-a)     |           |
 |                    -----------------        \       _----------------   /           /
 |                    | chain::Access |         \     / | ChainMonitor |---------------
 |                    -----------------          \   /  ----------------
 |                            |                   \ /          |
(as RoutingMessageHandler)    v                    v           v
  \                   --------------------     ---------   -----------------
   -----------------> | NetGraphMsgHandler |   | Event |   | chain::Filter |
                      --------------------     ---------   -----------------