@@ -4229,55 +4229,27 @@ where
4229
4229
}
4230
4230
4231
4231
fn internal_funding_created ( & self , counterparty_node_id : & PublicKey , msg : & msgs:: FundingCreated ) -> Result < ( ) , MsgHandleErrInternal > {
4232
+ let best_block = * self . best_block . read ( ) . unwrap ( ) ;
4233
+
4232
4234
let per_peer_state = self . per_peer_state . read ( ) . unwrap ( ) ;
4233
4235
let peer_state_mutex_opt = per_peer_state. get ( counterparty_node_id) ;
4234
4236
if let None = peer_state_mutex_opt {
4235
4237
return Err ( MsgHandleErrInternal :: send_err_msg_no_close ( format ! ( "Can't find a peer matching the passed counterparty node_id {}" , counterparty_node_id) , msg. temporary_channel_id ) )
4236
4238
}
4237
- let ( ( funding_msg , monitor , mut channel_ready ) , mut chan ) = {
4238
- let best_block = * self . best_block . read ( ) . unwrap ( ) ;
4239
- let mut peer_state_lock = peer_state_mutex_opt . unwrap ( ) . lock ( ) . unwrap ( ) ;
4240
- let peer_state = & mut * peer_state_lock ;
4239
+
4240
+ let mut peer_state_lock = peer_state_mutex_opt . unwrap ( ) . lock ( ) . unwrap ( ) ;
4241
+ let peer_state = & mut * peer_state_lock ;
4242
+ let ( ( funding_msg , monitor ) , chan ) =
4241
4243
match peer_state. channel_by_id . entry ( msg. temporary_channel_id ) {
4242
4244
hash_map:: Entry :: Occupied ( mut chan) => {
4243
4245
( try_chan_entry ! ( self , chan. get_mut( ) . funding_created( msg, best_block, & self . keys_manager, & self . logger) , chan) , chan. remove ( ) )
4244
4246
} ,
4245
4247
hash_map:: Entry :: Vacant ( _) => return Err ( MsgHandleErrInternal :: send_err_msg_no_close ( format ! ( "Got a message for a channel from the wrong node! No such channel for the passed counterparty_node_id {}" , counterparty_node_id) , msg. temporary_channel_id ) )
4246
- }
4247
- } ;
4248
- // Because we have exclusive ownership of the channel here we can release the peer_state
4249
- // lock before watch_channel
4250
- match self . chain_monitor . watch_channel ( monitor. get_funding_txo ( ) . 0 , monitor) {
4251
- ChannelMonitorUpdateStatus :: Completed => { } ,
4252
- ChannelMonitorUpdateStatus :: PermanentFailure => {
4253
- // Note that we reply with the new channel_id in error messages if we gave up on the
4254
- // channel, not the temporary_channel_id. This is compatible with ourselves, but the
4255
- // spec is somewhat ambiguous here. Not a huge deal since we'll send error messages for
4256
- // any messages referencing a previously-closed channel anyway.
4257
- // We do not propagate the monitor update to the user as it would be for a monitor
4258
- // that we didn't manage to store (and that we don't care about - we don't respond
4259
- // with the funding_signed so the channel can never go on chain).
4260
- let ( _monitor_update, failed_htlcs) = chan. force_shutdown ( false ) ;
4261
- assert ! ( failed_htlcs. is_empty( ) ) ;
4262
- return Err ( MsgHandleErrInternal :: send_err_msg_no_close ( "ChannelMonitor storage failure" . to_owned ( ) , funding_msg. channel_id ) ) ;
4263
- } ,
4264
- ChannelMonitorUpdateStatus :: InProgress => {
4265
- // There's no problem signing a counterparty's funding transaction if our monitor
4266
- // hasn't persisted to disk yet - we can't lose money on a transaction that we haven't
4267
- // accepted payment from yet. We do, however, need to wait to send our channel_ready
4268
- // until we have persisted our monitor.
4269
- chan. monitor_updating_paused ( false , false , channel_ready. is_some ( ) , Vec :: new ( ) , Vec :: new ( ) , Vec :: new ( ) ) ;
4270
- channel_ready = None ; // Don't send the channel_ready now
4271
- } ,
4272
- }
4273
- // It's safe to unwrap as we've held the `per_peer_state` read lock since checking that the
4274
- // peer exists, despite the inner PeerState potentially having no channels after removing
4275
- // the channel above.
4276
- let mut peer_state_lock = peer_state_mutex_opt. unwrap ( ) . lock ( ) . unwrap ( ) ;
4277
- let peer_state = & mut * peer_state_lock;
4248
+ } ;
4249
+
4278
4250
match peer_state. channel_by_id . entry ( funding_msg. channel_id ) {
4279
4251
hash_map:: Entry :: Occupied ( _) => {
4280
- return Err ( MsgHandleErrInternal :: send_err_msg_no_close ( "Already had channel with the new channel_id" . to_owned ( ) , funding_msg. channel_id ) )
4252
+ Err ( MsgHandleErrInternal :: send_err_msg_no_close ( "Already had channel with the new channel_id" . to_owned ( ) , funding_msg. channel_id ) )
4281
4253
} ,
4282
4254
hash_map:: Entry :: Vacant ( e) => {
4283
4255
let mut id_to_peer = self . id_to_peer . lock ( ) . unwrap ( ) ;
@@ -4291,17 +4263,34 @@ where
4291
4263
i_e. insert ( chan. get_counterparty_node_id ( ) ) ;
4292
4264
}
4293
4265
}
4266
+
4267
+ // There's no problem signing a counterparty's funding transaction if our monitor
4268
+ // hasn't persisted to disk yet - we can't lose money on a transaction that we haven't
4269
+ // accepted payment from yet. We do, however, need to wait to send our channel_ready
4270
+ // until we have persisted our monitor.
4294
4271
peer_state. pending_msg_events . push ( events:: MessageSendEvent :: SendFundingSigned {
4295
4272
node_id : counterparty_node_id. clone ( ) ,
4296
4273
msg : funding_msg,
4297
4274
} ) ;
4298
- if let Some ( msg) = channel_ready {
4299
- send_channel_ready ! ( self , peer_state. pending_msg_events, chan, msg) ;
4275
+
4276
+ let monitor_res = self . chain_monitor . watch_channel ( monitor. get_funding_txo ( ) . 0 , monitor) ;
4277
+
4278
+ let chan = e. insert ( chan) ;
4279
+ let mut res = handle_new_monitor_update ! ( self , monitor_res, 0 , peer_state_lock, peer_state, chan, MANUALLY_REMOVING , 42 ) ;
4280
+
4281
+ // Note that we reply with the new channel_id in error messages if we gave up on the
4282
+ // channel, not the temporary_channel_id. This is compatible with ourselves, but the
4283
+ // spec is somewhat ambiguous here. Not a huge deal since we'll send error messages for
4284
+ // any messages referencing a previously-closed channel anyway.
4285
+ // We do not propagate the monitor update to the user as it would be for a monitor
4286
+ // that we didn't manage to store (and that we don't care about - we don't respond
4287
+ // with the funding_signed so the channel can never go on chain).
4288
+ if let Err ( MsgHandleErrInternal { shutdown_finish : Some ( ( res, _) ) , .. } ) = & mut res {
4289
+ res. 0 = None ;
4300
4290
}
4301
- e . insert ( chan ) ;
4291
+ res
4302
4292
}
4303
4293
}
4304
- Ok ( ( ) )
4305
4294
}
4306
4295
4307
4296
fn internal_funding_signed ( & self , counterparty_node_id : & PublicKey , msg : & msgs:: FundingSigned ) -> Result < ( ) , MsgHandleErrInternal > {
0 commit comments