@@ -38,7 +38,10 @@ use crate::chain::transaction::{OutPoint, TransactionData};
38
38
use crate :: chain:: { ChannelMonitorUpdateStatus , Filter , WatchedOutput } ;
39
39
use crate :: events:: { self , Event , EventHandler , ReplayEvent } ;
40
40
use 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) ]
42
45
use crate :: ln:: our_peer_storage:: { DecryptedOurPeerStorage , PeerStorageMonitorHolder } ;
43
46
use crate :: ln:: types:: ChannelId ;
44
47
use crate :: prelude:: * ;
@@ -53,6 +56,8 @@ use crate::util::persist::MonitorName;
53
56
use crate :: util:: ser:: { VecWriter , Writeable } ;
54
57
use crate :: util:: wakers:: { Future , Notifier } ;
55
58
use bitcoin:: secp256k1:: PublicKey ;
59
+ #[ cfg( peer_storage) ]
60
+ use core:: iter:: Cycle ;
56
61
use core:: ops:: Deref ;
57
62
use core:: sync:: atomic:: { AtomicUsize , Ordering } ;
58
63
@@ -268,7 +273,8 @@ pub struct ChainMonitor<
268
273
logger : L ,
269
274
fee_estimator : F ,
270
275
persister : P ,
271
- entropy_source : ES ,
276
+
277
+ _entropy_source : ES ,
272
278
/// "User-provided" (ie persistence-completion/-failed) [`MonitorEvent`]s. These came directly
273
279
/// from the user and not from a [`ChannelMonitor`].
274
280
pending_monitor_events : Mutex < Vec < ( OutPoint , ChannelId , Vec < MonitorEvent > , PublicKey ) > > ,
@@ -282,6 +288,7 @@ pub struct ChainMonitor<
282
288
/// Messages to send to the peer. This is currently used to distribute PeerStorage to channel partners.
283
289
pending_send_only_events : Mutex < Vec < MessageSendEvent > > ,
284
290
291
+ #[ cfg( peer_storage) ]
285
292
our_peerstorage_encryption_key : PeerStorageKey ,
286
293
}
287
294
@@ -481,7 +488,7 @@ where
481
488
/// [`ChannelManager`]: crate::ln::channelmanager::ChannelManager
482
489
pub fn new (
483
490
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 ,
485
492
) -> Self {
486
493
Self {
487
494
monitors : RwLock :: new ( new_hash_map ( ) ) ,
@@ -490,12 +497,13 @@ where
490
497
logger,
491
498
fee_estimator : feeest,
492
499
persister,
493
- entropy_source ,
500
+ _entropy_source ,
494
501
pending_monitor_events : Mutex :: new ( Vec :: new ( ) ) ,
495
502
highest_chain_height : AtomicUsize :: new ( 0 ) ,
496
503
event_notifier : Notifier :: new ( ) ,
497
504
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,
499
507
}
500
508
}
501
509
@@ -808,59 +816,80 @@ where
808
816
809
817
/// This function collects the counterparty node IDs from all monitors into a `HashSet`,
810
818
/// ensuring unique IDs are returned.
819
+ #[ cfg( peer_storage) ]
811
820
fn all_counterparty_node_ids ( & self ) -> HashSet < PublicKey > {
812
821
let mon = self . monitors . read ( ) . unwrap ( ) ;
813
822
mon. values ( ) . map ( |monitor| monitor. monitor . get_counterparty_node_id ( ) ) . collect ( )
814
823
}
815
824
816
825
#[ cfg( peer_storage) ]
817
826
fn send_peer_storage ( & self , their_node_id : PublicKey ) {
818
- #[ allow( unused_mut) ]
819
827
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 ( ) ;
821
829
822
830
const MAX_PEER_STORAGE_SIZE : usize = 65531 ;
823
831
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
+ }
833
856
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)
836
858
{
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
+ } ;
840
868
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 ( ) ;
844
872
{
845
- let chan_mon = mon . monitor . inner . lock ( ) . unwrap ( ) ;
873
+ let inner_lock = monitor_holder . monitor . inner . lock ( ) . unwrap ( ) ;
846
874
847
- write_chanmon_internal ( & chan_mon , true , & mut ser_chan )
875
+ write_chanmon_internal ( & inner_lock , true , & mut serialized_channel )
848
876
. expect ( "can not write Channel Monitor for peer storage message" ) ;
849
877
}
850
878
let peer_storage_monitor = PeerStorageMonitorHolder {
851
- channel_id : * cid ,
879
+ channel_id,
852
880
min_seen_secret,
853
881
counterparty_node_id,
854
- monitor_bytes : ser_chan . 0 ,
882
+ monitor_bytes : serialized_channel . 0 ,
855
883
} ;
856
884
857
- // Adding size of peer_storage_monitor.
858
- curr_size += peer_storage_monitor. serialized_length ( ) ;
885
+ let serialized_length = peer_storage_monitor. serialized_length ( ) ;
859
886
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) ;
862
892
}
863
- monitors_list. push ( peer_storage_monitor) ;
864
893
}
865
894
866
895
let serialised_channels = monitors_list. encode ( ) ;
@@ -870,7 +899,7 @@ where
870
899
log_debug ! ( self . logger, "Sending Peer Storage to {}" , log_pubkey!( their_node_id) ) ;
871
900
let send_peer_storage_event = MessageSendEvent :: SendPeerStorage {
872
901
node_id : their_node_id,
873
- msg : msgs :: PeerStorage { data : cipher. into_vec ( ) } ,
902
+ msg : PeerStorage { data : cipher. into_vec ( ) } ,
874
903
} ;
875
904
876
905
self . pending_send_only_events . lock ( ) . unwrap ( ) . push ( send_peer_storage_event)
0 commit comments