Browse Source

ln: fix reestablishing channel with no mined funding tx

dependabot/pip/contrib/deterministic-build/ecdsa-0.13.3
Janus 7 years ago
committed by ThomasV
parent
commit
f169bff89e
  1. 28
      lib/lnbase.py
  2. 12
      lib/tests/test_lnhtlc.py

28
lib/lnbase.py

@ -880,15 +880,15 @@ class Peer(PrintError):
local_config=local_config, local_config=local_config,
remote_config=remote_config, remote_config=remote_config,
remote_state=RemoteState( remote_state=RemoteState(
ctn = 0, ctn = -1,
next_per_commitment_point=None, next_per_commitment_point=remote_per_commitment_point,
last_per_commitment_point=remote_per_commitment_point, last_per_commitment_point=None,
amount_msat=remote_amount, amount_msat=remote_amount,
revocation_store=their_revocation_store, revocation_store=their_revocation_store,
next_htlc_id = 0 next_htlc_id = 0
), ),
local_state=LocalState( local_state=LocalState(
ctn = 0, ctn = -1,
per_commitment_secret_seed=per_commitment_secret_seed, per_commitment_secret_seed=per_commitment_secret_seed,
amount_msat=local_amount, amount_msat=local_amount,
next_htlc_id = 0, next_htlc_id = 0,
@ -896,11 +896,7 @@ class Peer(PrintError):
), ),
constraints=ChannelConstraints(capacity=funding_sat, feerate=local_feerate, is_initiator=True, funding_txn_minimum_depth=funding_txn_minimum_depth) constraints=ChannelConstraints(capacity=funding_sat, feerate=local_feerate, is_initiator=True, funding_txn_minimum_depth=funding_txn_minimum_depth)
) )
m = HTLCStateMachine(chan._replace( m = HTLCStateMachine(chan)
local_state=chan.local_state._replace(ctn=-1),
remote_state=chan.remote_state._replace(
next_per_commitment_point=remote_per_commitment_point,
last_per_commitment_point=None, ctn=-1)))
sig_64, _ = m.sign_next_commitment() sig_64, _ = m.sign_next_commitment()
self.send_message(gen_msg("funding_created", self.send_message(gen_msg("funding_created",
temporary_channel_id=temp_channel_id, temporary_channel_id=temp_channel_id,
@ -914,7 +910,7 @@ class Peer(PrintError):
# broadcast funding tx # broadcast funding tx
success, _txid = self.network.broadcast_transaction(funding_tx) success, _txid = self.network.broadcast_transaction(funding_tx)
assert success, success assert success, success
return chan return chan._replace(remote_state=chan.remote_state._replace(ctn=0),local_state=chan.local_state._replace(ctn=0))
def reestablish_channel(self, chan): def reestablish_channel(self, chan):
self.channel_state[chan.channel_id] = 'REESTABLISHING' self.channel_state[chan.channel_id] = 'REESTABLISHING'
@ -939,10 +935,14 @@ class Peer(PrintError):
local_ctn = int.from_bytes(channel_reestablish_msg["next_remote_revocation_number"], 'big') local_ctn = int.from_bytes(channel_reestablish_msg["next_remote_revocation_number"], 'big')
if local_ctn != chan.local_state.ctn: if local_ctn != chan.local_state.ctn:
raise Exception("expected local ctn {}, got {}".format(chan.local_state.ctn, local_ctn)) raise Exception("expected local ctn {}, got {}".format(chan.local_state.ctn, local_ctn))
if channel_reestablish_msg["my_current_per_commitment_point"] != chan.remote_state.last_per_commitment_point: our = channel_reestablish_msg["my_current_per_commitment_point"]
raise Exception("Remote PCP mismatch") their = chan.remote_state.last_per_commitment_point
if their is None:
their = chan.remote_state.next_per_commitment_point
if our != their:
raise Exception("Remote PCP mismatch: {} {}".format(bh2u(our), bh2u(their)))
self.channel_state[chan_id] = 'OPENING' self.channel_state[chan_id] = 'OPENING'
if chan.local_state.funding_locked_received: if chan.local_state.funding_locked_received and chan.short_channel_id:
self.mark_open(chan) self.mark_open(chan)
self.network.trigger_callback('channel', chan) self.network.trigger_callback('channel', chan)
@ -961,7 +961,7 @@ class Peer(PrintError):
if not chan: if not chan:
raise Exception("Got unknown funding_locked", channel_id) raise Exception("Got unknown funding_locked", channel_id)
short_channel_id = chan.short_channel_id short_channel_id = chan.short_channel_id
new_remote_state = chan.remote_state._replace(next_per_commitment_point=payload["next_per_commitment_point"]) new_remote_state = chan.remote_state._replace(next_per_commitment_point=payload["next_per_commitment_point"], last_per_commitment_point=chan.remote_state.next_per_commitment_point)
new_local_state = chan.local_state._replace(funding_locked_received = True) new_local_state = chan.local_state._replace(funding_locked_received = True)
chan = chan._replace(short_channel_id=short_channel_id, remote_state=new_remote_state, local_state=new_local_state) chan = chan._replace(short_channel_id=short_channel_id, remote_state=new_remote_state, local_state=new_local_state)
self.lnworker.save_channel(chan) self.lnworker.save_channel(chan)

12
lib/tests/test_lnhtlc.py

@ -176,12 +176,12 @@ class TestLNBaseHTLCStateMachine(unittest.TestCase):
aliceSent = 0 aliceSent = 0
bobSent = 0 bobSent = 0
self.assertEqual(alice_channel.total_msat_sent, aliceSent, "alice has incorrect milli-satoshis sent: %s vs %s"% (alice_channel.total_msat_sent, aliceSent)) self.assertEqual(alice_channel.total_msat_sent, aliceSent, "alice has incorrect milli-satoshis sent")
self.assertEqual(alice_channel.total_msat_received, bobSent, "alice has incorrect milli-satoshis received %s vs %s"% (alice_channel.total_msat_received, bobSent)) self.assertEqual(alice_channel.total_msat_received, bobSent, "alice has incorrect milli-satoshis received")
self.assertEqual(bob_channel.total_msat_sent, bobSent, "bob has incorrect milli-satoshis sent %s vs %s"% (bob_channel.total_msat_sent, bobSent)) self.assertEqual(bob_channel.total_msat_sent, bobSent, "bob has incorrect milli-satoshis sent")
self.assertEqual(bob_channel.total_msat_received, aliceSent, "bob has incorrect milli-satoshis received %s vs %s"% (bob_channel.total_msat_received, aliceSent)) self.assertEqual(bob_channel.total_msat_received, aliceSent, "bob has incorrect milli-satoshis received")
self.assertEqual(bob_channel.state.local_state.ctn, 1, "bob has incorrect commitment height, %s vs %s"% (bob_channel.state.local_state.ctn, 1)) self.assertEqual(bob_channel.state.local_state.ctn, 1, "bob has incorrect commitment height")
self.assertEqual(alice_channel.state.local_state.ctn, 1, "alice has incorrect commitment height, %s vs %s"% (alice_channel.state.local_state.ctn, 1)) self.assertEqual(alice_channel.state.local_state.ctn, 1, "alice has incorrect commitment height")
# Both commitment transactions should have three outputs, and one of # Both commitment transactions should have three outputs, and one of
# them should be exactly the amount of the HTLC. # them should be exactly the amount of the HTLC.

Loading…
Cancel
Save