#lightning #syncing #interface #sync #confirm #ldk #async

lightning-transaction-sync

Utilities for syncing LDK via the transaction-based Confirm interface

22 releases

0.0.125 Oct 14, 2024
0.0.124-rc1 Aug 29, 2024
0.0.123 May 9, 2024
0.0.121 Jan 23, 2024
0.0.114 Mar 4, 2023

#3 in #ldk

Download history 882/week @ 2024-08-29 536/week @ 2024-09-05 758/week @ 2024-09-12 782/week @ 2024-09-19 641/week @ 2024-09-26 830/week @ 2024-10-03 1666/week @ 2024-10-10 1251/week @ 2024-10-17 721/week @ 2024-10-24 975/week @ 2024-10-31 1284/week @ 2024-11-07 1085/week @ 2024-11-14 788/week @ 2024-11-21 1036/week @ 2024-11-28 926/week @ 2024-12-05 898/week @ 2024-12-12

3,844 downloads per month
Used in 2 crates

MIT/Apache

7MB
114K SLoC

Provides utilities for syncing LDK via the transaction-based Confirm interface.

The provided synchronization clients need to be registered with a ChainMonitor via the Filter interface. Then, the respective fn sync needs to be called with the Confirm implementations to be synchronized, i.e., usually instances of ChannelManager and ChainMonitor.

Features and Backend Support

  • esplora-blocking enables syncing against an Esplora backend based on a blocking client.
  • esplora-async enables syncing against an Esplora backend based on an async client.
  • esplora-async-https enables the async Esplora client with support for HTTPS.

Version Compatibility

Currently this crate is compatible with LDK version 0.0.114 and above using channels which were created on LDK version 0.0.113 and above.

Usage Example:

let tx_sync = Arc::new(EsploraSyncClient::new(
	esplora_server_url,
	Arc::clone(&some_logger),
));

let chain_monitor = Arc::new(ChainMonitor::new(
	Some(Arc::clone(&tx_sync)),
	Arc::clone(&some_broadcaster),
	Arc::clone(&some_logger),
	Arc::clone(&some_fee_estimator),
	Arc::clone(&some_persister),
));

let channel_manager = Arc::new(ChannelManager::new(
	Arc::clone(&some_fee_estimator),
	Arc::clone(&chain_monitor),
	Arc::clone(&some_broadcaster),
	Arc::clone(&some_router),
	Arc::clone(&some_logger),
	Arc::clone(&some_entropy_source),
	Arc::clone(&some_node_signer),
	Arc::clone(&some_signer_provider),
	user_config,
	chain_params,
));

let confirmables = vec![
	&*channel_manager as &(dyn Confirm + Sync + Send),
	&*chain_monitor as &(dyn Confirm + Sync + Send),
];

tx_sync.sync(confirmables).unwrap();

Dependencies

~9–24MB
~266K SLoC