@@ -38,7 +38,10 @@ use crate::chain::transaction::{OutPoint, TransactionData};
3838use crate :: chain:: { ChannelMonitorUpdateStatus , Filter , WatchedOutput } ;
3939use crate :: events:: { self , Event , EventHandler , ReplayEvent } ;
4040use crate :: ln:: channel_state:: ChannelDetails ;
41- use crate :: ln:: msgs:: { self , BaseMessageHandler , Init , MessageSendEvent , SendOnlyMessageHandler } ;
41+ #[ cfg( peer_storage) ]
42+ use crate :: ln:: msgs:: PeerStorage ;
43+ use crate :: ln:: msgs:: { BaseMessageHandler , Init , MessageSendEvent , SendOnlyMessageHandler } ;
44+ #[ cfg( peer_storage) ]
4245use crate :: ln:: our_peer_storage:: { DecryptedOurPeerStorage , PeerStorageMonitorHolder } ;
4346use crate :: ln:: types:: ChannelId ;
4447use crate :: prelude:: * ;
@@ -53,6 +56,8 @@ use crate::util::persist::MonitorName;
5356use crate :: util:: ser:: { VecWriter , Writeable } ;
5457use crate :: util:: wakers:: { Future , Notifier } ;
5558use bitcoin:: secp256k1:: PublicKey ;
59+ #[ cfg( peer_storage) ]
60+ use core:: iter:: Cycle ;
5661use core:: ops:: Deref ;
5762use core:: sync:: atomic:: { AtomicUsize , Ordering } ;
5863
@@ -268,7 +273,8 @@ pub struct ChainMonitor<
268273 logger : L ,
269274 fee_estimator : F ,
270275 persister : P ,
271- entropy_source : ES ,
276+
277+ _entropy_source : ES ,
272278 /// "User-provided" (ie persistence-completion/-failed) [`MonitorEvent`]s. These came directly
273279 /// from the user and not from a [`ChannelMonitor`].
274280 pending_monitor_events : Mutex < Vec < ( OutPoint , ChannelId , Vec < MonitorEvent > , PublicKey ) > > ,
@@ -282,6 +288,7 @@ pub struct ChainMonitor<
282288 /// Messages to send to the peer. This is currently used to distribute PeerStorage to channel partners.
283289 pending_send_only_events : Mutex < Vec < MessageSendEvent > > ,
284290
291+ #[ cfg( peer_storage) ]
285292 our_peerstorage_encryption_key : PeerStorageKey ,
286293}
287294
@@ -481,7 +488,7 @@ where
481488 /// [`ChannelManager`]: crate::ln::channelmanager::ChannelManager
482489 pub fn new (
483490 chain_source : Option < C > , broadcaster : T , logger : L , feeest : F , persister : P ,
484- entropy_source : ES , our_peerstorage_encryption_key : PeerStorageKey ,
491+ _entropy_source : ES , _our_peerstorage_encryption_key : PeerStorageKey ,
485492 ) -> Self {
486493 Self {
487494 monitors : RwLock :: new ( new_hash_map ( ) ) ,
@@ -490,12 +497,13 @@ where
490497 logger,
491498 fee_estimator : feeest,
492499 persister,
493- entropy_source ,
500+ _entropy_source ,
494501 pending_monitor_events : Mutex :: new ( Vec :: new ( ) ) ,
495502 highest_chain_height : AtomicUsize :: new ( 0 ) ,
496503 event_notifier : Notifier :: new ( ) ,
497504 pending_send_only_events : Mutex :: new ( Vec :: new ( ) ) ,
498- our_peerstorage_encryption_key,
505+ #[ cfg( peer_storage) ]
506+ our_peerstorage_encryption_key : _our_peerstorage_encryption_key,
499507 }
500508 }
501509
@@ -808,59 +816,80 @@ where
808816
809817 /// This function collects the counterparty node IDs from all monitors into a `HashSet`,
810818 /// ensuring unique IDs are returned.
819+ #[ cfg( peer_storage) ]
811820 fn all_counterparty_node_ids ( & self ) -> HashSet < PublicKey > {
812821 let mon = self . monitors . read ( ) . unwrap ( ) ;
813822 mon. values ( ) . map ( |monitor| monitor. monitor . get_counterparty_node_id ( ) ) . collect ( )
814823 }
815824
816825 #[ cfg( peer_storage) ]
817826 fn send_peer_storage ( & self , their_node_id : PublicKey ) {
818- #[ allow( unused_mut) ]
819827 let mut monitors_list: Vec < PeerStorageMonitorHolder > = Vec :: new ( ) ;
820- let random_bytes = self . entropy_source . get_secure_random_bytes ( ) ;
828+ let random_bytes = self . _entropy_source . get_secure_random_bytes ( ) ;
821829
822830 const MAX_PEER_STORAGE_SIZE : usize = 65531 ;
823831 const USIZE_LEN : usize = core:: mem:: size_of :: < usize > ( ) ;
824- let mut usize_bytes = [ 0u8 ; USIZE_LEN ] ;
825- usize_bytes. copy_from_slice ( & random_bytes[ 0 ..USIZE_LEN ] ) ;
826- let random_usize = usize:: from_le_bytes ( usize_bytes) ;
827-
828- let mut curr_size = 0 ;
829- let monitors = self . monitors . read ( ) . unwrap ( ) ;
830- let mut stored_chanmon_idx = alloc:: collections:: BTreeSet :: < usize > :: new ( ) ;
831- // Used as a fallback reference if the set is empty
832- let zero = 0 ;
832+ let mut random_bytes_cycle_iter = random_bytes. iter ( ) . cycle ( ) ;
833+
834+ let mut current_size = 0 ;
835+ let monitors_lock = self . monitors . read ( ) . unwrap ( ) ;
836+ let mut channel_ids = monitors_lock. keys ( ) . copied ( ) . collect ( ) ;
837+
838+ fn next_random_id (
839+ channel_ids : & mut Vec < ChannelId > ,
840+ random_bytes_cycle_iter : & mut Cycle < core:: slice:: Iter < u8 > > ,
841+ ) -> Option < ChannelId > {
842+ if channel_ids. is_empty ( ) {
843+ return None ;
844+ }
845+ let random_idx = {
846+ let mut usize_bytes = [ 0u8 ; USIZE_LEN ] ;
847+ usize_bytes. iter_mut ( ) . for_each ( |b| {
848+ * b = * random_bytes_cycle_iter. next ( ) . expect ( "A cycle never ends" )
849+ } ) ;
850+ // Take one more to introduce a slight misalignment.
851+ random_bytes_cycle_iter. next ( ) . expect ( "A cycle never ends" ) ;
852+ usize:: from_le_bytes ( usize_bytes) % channel_ids. len ( )
853+ } ;
854+ Some ( channel_ids. swap_remove ( random_idx) )
855+ }
833856
834- while curr_size < MAX_PEER_STORAGE_SIZE
835- && * stored_chanmon_idx. last ( ) . unwrap_or ( & zero) < monitors. len ( )
857+ while let Some ( channel_id) = next_random_id ( & mut channel_ids, & mut random_bytes_cycle_iter)
836858 {
837- let idx = random_usize % monitors. len ( ) ;
838- stored_chanmon_idx. insert ( idx + 1 ) ;
839- let ( cid, mon) = monitors. iter ( ) . skip ( idx) . next ( ) . unwrap ( ) ;
859+ let monitor_holder = if let Some ( monitor_holder) = monitors_lock. get ( & channel_id) {
860+ monitor_holder
861+ } else {
862+ debug_assert ! (
863+ false ,
864+ "Tried to access non-existing monitor, this should never happen"
865+ ) ;
866+ break ;
867+ } ;
840868
841- let mut ser_chan = VecWriter ( Vec :: new ( ) ) ;
842- let min_seen_secret = mon . monitor . get_min_seen_secret ( ) ;
843- let counterparty_node_id = mon . monitor . get_counterparty_node_id ( ) ;
869+ let mut serialized_channel = VecWriter ( Vec :: new ( ) ) ;
870+ let min_seen_secret = monitor_holder . monitor . get_min_seen_secret ( ) ;
871+ let counterparty_node_id = monitor_holder . monitor . get_counterparty_node_id ( ) ;
844872 {
845- let chan_mon = mon . monitor . inner . lock ( ) . unwrap ( ) ;
873+ let inner_lock = monitor_holder . monitor . inner . lock ( ) . unwrap ( ) ;
846874
847- write_chanmon_internal ( & chan_mon , true , & mut ser_chan )
875+ write_chanmon_internal ( & inner_lock , true , & mut serialized_channel )
848876 . expect ( "can not write Channel Monitor for peer storage message" ) ;
849877 }
850878 let peer_storage_monitor = PeerStorageMonitorHolder {
851- channel_id : * cid ,
879+ channel_id,
852880 min_seen_secret,
853881 counterparty_node_id,
854- monitor_bytes : ser_chan . 0 ,
882+ monitor_bytes : serialized_channel . 0 ,
855883 } ;
856884
857- // Adding size of peer_storage_monitor.
858- curr_size += peer_storage_monitor. serialized_length ( ) ;
885+ let serialized_length = peer_storage_monitor. serialized_length ( ) ;
859886
860- if curr_size > MAX_PEER_STORAGE_SIZE {
861- break ;
887+ if current_size + serialized_length > MAX_PEER_STORAGE_SIZE {
888+ continue ;
889+ } else {
890+ current_size += serialized_length;
891+ monitors_list. push ( peer_storage_monitor) ;
862892 }
863- monitors_list. push ( peer_storage_monitor) ;
864893 }
865894
866895 let serialised_channels = monitors_list. encode ( ) ;
@@ -870,7 +899,7 @@ where
870899 log_debug ! ( self . logger, "Sending Peer Storage to {}" , log_pubkey!( their_node_id) ) ;
871900 let send_peer_storage_event = MessageSendEvent :: SendPeerStorage {
872901 node_id : their_node_id,
873- msg : msgs :: PeerStorage { data : cipher. into_vec ( ) } ,
902+ msg : PeerStorage { data : cipher. into_vec ( ) } ,
874903 } ;
875904
876905 self . pending_send_only_events . lock ( ) . unwrap ( ) . push ( send_peer_storage_event)
0 commit comments