|
@ -304,7 +304,7 @@ class AbstractChannel(Logger, ABC): |
|
|
# we must not trust the server with unconfirmed transactions, |
|
|
# we must not trust the server with unconfirmed transactions, |
|
|
# because the state transition is irreversible. if the remote |
|
|
# because the state transition is irreversible. if the remote |
|
|
# force closed, we remain OPEN until the closing tx is confirmed |
|
|
# force closed, we remain OPEN until the closing tx is confirmed |
|
|
self.force_close_detected = True |
|
|
self.closing_detected = True |
|
|
if self.lnworker: |
|
|
if self.lnworker: |
|
|
util.trigger_callback('channel', self.lnworker.wallet, self) |
|
|
util.trigger_callback('channel', self.lnworker.wallet, self) |
|
|
|
|
|
|
|
@ -339,8 +339,8 @@ class AbstractChannel(Logger, ABC): |
|
|
|
|
|
|
|
|
def get_state_for_GUI(self) -> str: |
|
|
def get_state_for_GUI(self) -> str: |
|
|
cs = self.get_state() |
|
|
cs = self.get_state() |
|
|
if cs < ChannelState.CLOSED and self.force_close_detected: |
|
|
if cs == ChannelState.OPEN and self.closing_detected: |
|
|
return 'FORCE_CLOSING' |
|
|
return 'FORCE-CLOSING' |
|
|
return cs.name |
|
|
return cs.name |
|
|
|
|
|
|
|
|
@abstractmethod |
|
|
@abstractmethod |
|
@ -419,7 +419,7 @@ class ChannelBackup(AbstractChannel): |
|
|
self.config = {} |
|
|
self.config = {} |
|
|
if self.is_imported: |
|
|
if self.is_imported: |
|
|
self.init_config(cb) |
|
|
self.init_config(cb) |
|
|
self.force_close_detected = False # not a state, only for GUI |
|
|
self.closing_detected = False # not a state, only for GUI |
|
|
|
|
|
|
|
|
def init_config(self, cb): |
|
|
def init_config(self, cb): |
|
|
self.config[LOCAL] = LocalConfig.from_seed( |
|
|
self.config[LOCAL] = LocalConfig.from_seed( |
|
@ -553,7 +553,7 @@ class Channel(AbstractChannel): |
|
|
self._receive_fail_reasons = {} # type: Dict[int, (bytes, OnionRoutingFailure)] |
|
|
self._receive_fail_reasons = {} # type: Dict[int, (bytes, OnionRoutingFailure)] |
|
|
self._ignore_max_htlc_value = False # used in tests |
|
|
self._ignore_max_htlc_value = False # used in tests |
|
|
self.should_request_force_close = False |
|
|
self.should_request_force_close = False |
|
|
self.force_close_detected = False # not a state, only for GUI |
|
|
self.closing_detected = False # not a state, only for GUI |
|
|
|
|
|
|
|
|
def has_onchain_backup(self): |
|
|
def has_onchain_backup(self): |
|
|
return self.storage.get('has_onchain_backup', False) |
|
|
return self.storage.get('has_onchain_backup', False) |
|
@ -735,7 +735,7 @@ class Channel(AbstractChannel): |
|
|
|
|
|
|
|
|
def get_state_for_GUI(self): |
|
|
def get_state_for_GUI(self): |
|
|
cs_name = super().get_state_for_GUI() |
|
|
cs_name = super().get_state_for_GUI() |
|
|
if self.is_closed() or self.force_close_detected: |
|
|
if self.is_closed() or self.closing_detected: |
|
|
return cs_name |
|
|
return cs_name |
|
|
ps = self.peer_state |
|
|
ps = self.peer_state |
|
|
if ps != PeerState.GOOD: |
|
|
if ps != PeerState.GOOD: |
|
|