@@ -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,6 +273,8 @@ pub struct ChainMonitor<
268
273
logger : L ,
269
274
fee_estimator : F ,
270
275
persister : P ,
276
+
277
+ #[ cfg( peer_storage) ]
271
278
entropy_source : ES ,
272
279
/// "User-provided" (ie persistence-completion/-failed) [`MonitorEvent`]s. These came directly
273
280
/// from the user and not from a [`ChannelMonitor`].
@@ -282,7 +289,9 @@ pub struct ChainMonitor<
282
289
/// Messages to send to the peer. This is currently used to distribute PeerStorage to channel partners.
283
290
pending_send_only_events : Mutex < Vec < MessageSendEvent > > ,
284
291
292
+ #[ cfg( peer_storage) ]
285
293
our_peerstorage_encryption_key : PeerStorageKey ,
294
+ _phantom : std:: marker:: PhantomData < ES > ,
286
295
}
287
296
288
297
impl <
@@ -481,7 +490,7 @@ where
481
490
/// [`ChannelManager`]: crate::ln::channelmanager::ChannelManager
482
491
pub fn new (
483
492
chain_source : Option < C > , broadcaster : T , logger : L , feeest : F , persister : P ,
484
- entropy_source : ES , our_peerstorage_encryption_key : PeerStorageKey ,
493
+ _entropy_source : ES , _our_peerstorage_encryption_key : PeerStorageKey ,
485
494
) -> Self {
486
495
Self {
487
496
monitors : RwLock :: new ( new_hash_map ( ) ) ,
@@ -490,12 +499,15 @@ where
490
499
logger,
491
500
fee_estimator : feeest,
492
501
persister,
493
- entropy_source,
502
+ #[ cfg( peer_storage) ]
503
+ entropy_source : _entropy_source,
494
504
pending_monitor_events : Mutex :: new ( Vec :: new ( ) ) ,
495
505
highest_chain_height : AtomicUsize :: new ( 0 ) ,
496
506
event_notifier : Notifier :: new ( ) ,
497
507
pending_send_only_events : Mutex :: new ( Vec :: new ( ) ) ,
498
- our_peerstorage_encryption_key,
508
+ #[ cfg( peer_storage) ]
509
+ our_peerstorage_encryption_key : _our_peerstorage_encryption_key,
510
+ _phantom : std:: marker:: PhantomData ,
499
511
}
500
512
}
501
513
@@ -808,59 +820,80 @@ where
808
820
809
821
/// This function collects the counterparty node IDs from all monitors into a `HashSet`,
810
822
/// ensuring unique IDs are returned.
823
+ #[ cfg( peer_storage) ]
811
824
fn all_counterparty_node_ids ( & self ) -> HashSet < PublicKey > {
812
825
let mon = self . monitors . read ( ) . unwrap ( ) ;
813
826
mon. values ( ) . map ( |monitor| monitor. monitor . get_counterparty_node_id ( ) ) . collect ( )
814
827
}
815
828
816
829
#[ cfg( peer_storage) ]
817
830
fn send_peer_storage ( & self , their_node_id : PublicKey ) {
818
- #[ allow( unused_mut) ]
819
831
let mut monitors_list: Vec < PeerStorageMonitorHolder > = Vec :: new ( ) ;
820
832
let random_bytes = self . entropy_source . get_secure_random_bytes ( ) ;
821
833
822
834
const MAX_PEER_STORAGE_SIZE : usize = 65531 ;
823
835
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 ;
836
+ let mut random_bytes_cycle_iter = random_bytes. iter ( ) . cycle ( ) ;
837
+
838
+ let mut current_size = 0 ;
839
+ let monitors_lock = self . monitors . read ( ) . unwrap ( ) ;
840
+ let mut channel_ids = monitors_lock. keys ( ) . copied ( ) . collect ( ) ;
841
+
842
+ fn next_random_id (
843
+ channel_ids : & mut Vec < ChannelId > ,
844
+ random_bytes_cycle_iter : & mut Cycle < core:: slice:: Iter < u8 > > ,
845
+ ) -> Option < ChannelId > {
846
+ if channel_ids. is_empty ( ) {
847
+ return None ;
848
+ }
849
+ let random_idx = {
850
+ let mut usize_bytes = [ 0u8 ; USIZE_LEN ] ;
851
+ usize_bytes. iter_mut ( ) . for_each ( |b| {
852
+ * b = * random_bytes_cycle_iter. next ( ) . expect ( "A cycle never ends" )
853
+ } ) ;
854
+ // Take one more to introduce a slight misalignment.
855
+ random_bytes_cycle_iter. next ( ) . expect ( "A cycle never ends" ) ;
856
+ usize:: from_le_bytes ( usize_bytes) % channel_ids. len ( )
857
+ } ;
858
+ Some ( channel_ids. swap_remove ( random_idx) )
859
+ }
833
860
834
- while curr_size < MAX_PEER_STORAGE_SIZE
835
- && * stored_chanmon_idx. last ( ) . unwrap_or ( & zero) < monitors. len ( )
861
+ while let Some ( channel_id) = next_random_id ( & mut channel_ids, & mut random_bytes_cycle_iter)
836
862
{
837
- let idx = random_usize % monitors. len ( ) ;
838
- stored_chanmon_idx. insert ( idx + 1 ) ;
839
- let ( cid, mon) = monitors. iter ( ) . skip ( idx) . next ( ) . unwrap ( ) ;
863
+ let monitor_holder = if let Some ( monitor_holder) = monitors_lock. get ( & channel_id) {
864
+ monitor_holder
865
+ } else {
866
+ debug_assert ! (
867
+ false ,
868
+ "Tried to access non-existing monitor, this should never happen"
869
+ ) ;
870
+ break ;
871
+ } ;
840
872
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 ( ) ;
873
+ let mut serialized_channel = VecWriter ( Vec :: new ( ) ) ;
874
+ let min_seen_secret = monitor_holder . monitor . get_min_seen_secret ( ) ;
875
+ let counterparty_node_id = monitor_holder . monitor . get_counterparty_node_id ( ) ;
844
876
{
845
- let chan_mon = mon . monitor . inner . lock ( ) . unwrap ( ) ;
877
+ let inner_lock = monitor_holder . monitor . inner . lock ( ) . unwrap ( ) ;
846
878
847
- write_chanmon_internal ( & chan_mon , true , & mut ser_chan )
879
+ write_chanmon_internal ( & inner_lock , true , & mut serialized_channel )
848
880
. expect ( "can not write Channel Monitor for peer storage message" ) ;
849
881
}
850
882
let peer_storage_monitor = PeerStorageMonitorHolder {
851
- channel_id : * cid ,
883
+ channel_id,
852
884
min_seen_secret,
853
885
counterparty_node_id,
854
- monitor_bytes : ser_chan . 0 ,
886
+ monitor_bytes : serialized_channel . 0 ,
855
887
} ;
856
888
857
- // Adding size of peer_storage_monitor.
858
- curr_size += peer_storage_monitor. serialized_length ( ) ;
889
+ let serialized_length = peer_storage_monitor. serialized_length ( ) ;
859
890
860
- if curr_size > MAX_PEER_STORAGE_SIZE {
861
- break ;
891
+ if current_size + serialized_length > MAX_PEER_STORAGE_SIZE {
892
+ continue ;
893
+ } else {
894
+ current_size += serialized_length;
895
+ monitors_list. push ( peer_storage_monitor) ;
862
896
}
863
- monitors_list. push ( peer_storage_monitor) ;
864
897
}
865
898
866
899
let serialised_channels = monitors_list. encode ( ) ;
@@ -870,7 +903,7 @@ where
870
903
log_debug ! ( self . logger, "Sending Peer Storage to {}" , log_pubkey!( their_node_id) ) ;
871
904
let send_peer_storage_event = MessageSendEvent :: SendPeerStorage {
872
905
node_id : their_node_id,
873
- msg : msgs :: PeerStorage { data : cipher. into_vec ( ) } ,
906
+ msg : PeerStorage { data : cipher. into_vec ( ) } ,
874
907
} ;
875
908
876
909
self . pending_send_only_events . lock ( ) . unwrap ( ) . push ( send_peer_storage_event)
0 commit comments