Fix xmr self bid.

This commit is contained in:
tecnovert 2022-11-14 21:47:07 +02:00
parent d08e85e73e
commit 8022ada01f
No known key found for this signature in database
GPG Key ID: 8ED6D8750C4E3F93
3 changed files with 44 additions and 25 deletions

View File

@ -1,3 +1,3 @@
name = "basicswap" name = "basicswap"
__version__ = "0.11.47" __version__ = "0.11.48"

View File

@ -374,6 +374,7 @@ class BasicSwap(BaseApp):
self.zmqContext.destroy() self.zmqContext.destroy()
self.swaps_in_progress.clear()
close_all_sessions() close_all_sessions()
self.engine.dispose() self.engine.dispose()
@ -1076,6 +1077,7 @@ class BasicSwap(BaseApp):
self.closeSession(use_session) self.closeSession(use_session)
def buildNotificationsCache(self, session): def buildNotificationsCache(self, session):
self._notifications_cache.clear()
q = session.execute(f'SELECT created_at, event_type, event_data FROM notifications WHERE active_ind=1 ORDER BY created_at ASC LIMIT {self._show_notifications}') q = session.execute(f'SELECT created_at, event_type, event_data FROM notifications WHERE active_ind=1 ORDER BY created_at ASC LIMIT {self._show_notifications}')
for entry in q: for entry in q:
self._notifications_cache[entry[0]] = (entry[1], json.loads(entry[2].decode('UTF-8'))) self._notifications_cache[entry[0]] = (entry[1], json.loads(entry[2].decode('UTF-8')))
@ -3040,11 +3042,12 @@ class BasicSwap(BaseApp):
if 'Transaction already in block chain' in str(ex): if 'Transaction already in block chain' in str(ex):
self.log.info('Found coin a lock refund tx for bid {}'.format(bid_id.hex())) self.log.info('Found coin a lock refund tx for bid {}'.format(bid_id.hex()))
txid = ci_from.getTxid(xmr_swap.a_lock_refund_tx) txid = ci_from.getTxid(xmr_swap.a_lock_refund_tx)
bid.txns[TxTypes.XMR_SWAP_A_LOCK_REFUND] = SwapTx( if TxTypes.XMR_SWAP_A_LOCK_REFUND not in bid.txns:
bid_id=bid_id, bid.txns[TxTypes.XMR_SWAP_A_LOCK_REFUND] = SwapTx(
tx_type=TxTypes.XMR_SWAP_A_LOCK_REFUND, bid_id=bid_id,
txid=txid, tx_type=TxTypes.XMR_SWAP_A_LOCK_REFUND,
) txid=txid,
)
self.saveBidInSession(bid_id, bid, session, xmr_swap) self.saveBidInSession(bid_id, bid, session, xmr_swap)
session.commit() session.commit()
return rv return rv
@ -4341,7 +4344,7 @@ class BasicSwap(BaseApp):
self.log.warning('XMR swap restore height clamped to {}'.format(wallet_restore_height)) self.log.warning('XMR swap restore height clamped to {}'.format(wallet_restore_height))
else: else:
ensure(bid.state == BidStates.BID_SENT, 'Wrong bid state: {}'.format(str(BidStates(bid.state)))) ensure(bid.state == BidStates.BID_SENT, 'Wrong bid state: {}'.format(str(BidStates(bid.state))))
bid.created_at = msg['sent'] # Don't update bid.created_at, it's been used to derive kaf
bid.expire_at = msg['sent'] + bid_data.time_valid bid.expire_at = msg['sent'] + bid_data.time_valid
bid.was_received = True bid.was_received = True
@ -4477,6 +4480,7 @@ class BasicSwap(BaseApp):
prevout_amount = ci_from.getLockRefundTxSwapOutputValue(bid, xmr_swap) prevout_amount = ci_from.getLockRefundTxSwapOutputValue(bid, xmr_swap)
xmr_swap.af_lock_refund_spend_tx_esig = ci_from.signTxOtVES(kaf, xmr_swap.pkasl, xmr_swap.a_lock_refund_spend_tx, 0, xmr_swap.a_lock_refund_tx_script, prevout_amount) xmr_swap.af_lock_refund_spend_tx_esig = ci_from.signTxOtVES(kaf, xmr_swap.pkasl, xmr_swap.a_lock_refund_spend_tx, 0, xmr_swap.a_lock_refund_tx_script, prevout_amount)
prevout_amount = ci_from.getLockTxSwapOutputValue(bid, xmr_swap) prevout_amount = ci_from.getLockTxSwapOutputValue(bid, xmr_swap)
xmr_swap.af_lock_refund_tx_sig = ci_from.signTx(kaf, xmr_swap.a_lock_refund_tx, 0, xmr_swap.a_lock_tx_script, prevout_amount) xmr_swap.af_lock_refund_tx_sig = ci_from.signTx(kaf, xmr_swap.a_lock_refund_tx, 0, xmr_swap.a_lock_tx_script, prevout_amount)
@ -4499,12 +4503,13 @@ class BasicSwap(BaseApp):
a_lock_tx_id = ci_from.getTxid(xmr_swap.a_lock_tx) a_lock_tx_id = ci_from.getTxid(xmr_swap.a_lock_tx)
a_lock_tx_vout = ci_from.getTxOutputPos(xmr_swap.a_lock_tx, xmr_swap.a_lock_tx_script) a_lock_tx_vout = ci_from.getTxOutputPos(xmr_swap.a_lock_tx, xmr_swap.a_lock_tx_script)
self.log.debug('Waiting for lock txn %s to %s chain for bid %s', a_lock_tx_id.hex(), ci_from.coin_name(), bid_id.hex()) self.log.debug('Waiting for lock txn %s to %s chain for bid %s', a_lock_tx_id.hex(), ci_from.coin_name(), bid_id.hex())
bid.xmr_a_lock_tx = SwapTx( if bid.xmr_a_lock_tx is None:
bid_id=bid_id, bid.xmr_a_lock_tx = SwapTx(
tx_type=TxTypes.XMR_SWAP_A_LOCK, bid_id=bid_id,
txid=a_lock_tx_id, tx_type=TxTypes.XMR_SWAP_A_LOCK,
vout=a_lock_tx_vout, txid=a_lock_tx_id,
) vout=a_lock_tx_vout,
)
bid.xmr_a_lock_tx.setState(TxStates.TX_NONE) bid.xmr_a_lock_tx.setState(TxStates.TX_NONE)
bid.setState(BidStates.XMR_SWAP_MSG_SCRIPT_LOCK_TX_SIGS) bid.setState(BidStates.XMR_SWAP_MSG_SCRIPT_LOCK_TX_SIGS)
@ -4557,12 +4562,13 @@ class BasicSwap(BaseApp):
self.log.debug('Submitted lock txn %s to %s chain for bid %s', txid_hex, ci_from.coin_name(), bid_id.hex()) self.log.debug('Submitted lock txn %s to %s chain for bid %s', txid_hex, ci_from.coin_name(), bid_id.hex())
bid.xmr_a_lock_tx = SwapTx( if bid.xmr_a_lock_tx is None:
bid_id=bid_id, bid.xmr_a_lock_tx = SwapTx(
tx_type=TxTypes.XMR_SWAP_A_LOCK, bid_id=bid_id,
txid=bytes.fromhex(txid_hex), tx_type=TxTypes.XMR_SWAP_A_LOCK,
vout=vout_pos, txid=bytes.fromhex(txid_hex),
) vout=vout_pos,
)
bid.xmr_a_lock_tx.setState(TxStates.TX_SENT) bid.xmr_a_lock_tx.setState(TxStates.TX_SENT)
bid.setState(BidStates.XMR_SWAP_HAVE_SCRIPT_COIN_SPEND_TX) bid.setState(BidStates.XMR_SWAP_HAVE_SCRIPT_COIN_SPEND_TX)
@ -4582,10 +4588,8 @@ class BasicSwap(BaseApp):
offer, xmr_offer = self.getXmrOfferFromSession(session, bid.offer_id, sent=False) offer, xmr_offer = self.getXmrOfferFromSession(session, bid.offer_id, sent=False)
ensure(offer, 'Offer not found: {}.'.format(bid.offer_id.hex())) ensure(offer, 'Offer not found: {}.'.format(bid.offer_id.hex()))
ensure(xmr_offer, 'XMR offer not found: {}.'.format(bid.offer_id.hex())) ensure(xmr_offer, 'XMR offer not found: {}.'.format(bid.offer_id.hex()))
coin_from = Coins(offer.coin_from) ci_from = self.ci(Coins(offer.coin_from))
coin_to = Coins(offer.coin_to) ci_to = self.ci(Coins(offer.coin_to))
ci_from = self.ci(coin_from)
ci_to = self.ci(coin_to)
if bid.debug_ind == DebugTypes.BID_STOP_AFTER_COIN_A_LOCK: if bid.debug_ind == DebugTypes.BID_STOP_AFTER_COIN_A_LOCK:
self.log.debug('XMR bid %s: Stalling bid for testing: %d.', bid_id.hex(), bid.debug_ind) self.log.debug('XMR bid %s: Stalling bid for testing: %d.', bid_id.hex(), bid.debug_ind)
@ -4949,8 +4953,11 @@ class BasicSwap(BaseApp):
ci_from.verifyCompactSig(xmr_swap.pkal, 'proof key owned for swap', xmr_swap.kal_sig) ci_from.verifyCompactSig(xmr_swap.pkal, 'proof key owned for swap', xmr_swap.kal_sig)
bid.setState(BidStates.XMR_SWAP_HAVE_SCRIPT_COIN_SPEND_TX) if bid.state == BidStates.XMR_SWAP_MSG_SCRIPT_LOCK_TX_SIGS:
bid.setState(BidStates.XMR_SWAP_MSG_SCRIPT_LOCK_SPEND_TX) bid.setState(BidStates.XMR_SWAP_HAVE_SCRIPT_COIN_SPEND_TX)
bid.setState(BidStates.XMR_SWAP_MSG_SCRIPT_LOCK_SPEND_TX)
else:
self.log.warning('processXmrBidLockSpendTx bid {} unexpected state {}'.format(bid_id.hex(), bid.state))
self.saveBid(bid_id, bid, xmr_swap=xmr_swap) self.saveBid(bid_id, bid, xmr_swap=xmr_swap)
except Exception as ex: except Exception as ex:
if self.debug: if self.debug:

View File

@ -419,6 +419,18 @@ class BasicSwapTest(BaseTest):
node1_xmr_after = self.getXmrBalance(js_w1_after) node1_xmr_after = self.getXmrBalance(js_w1_after)
assert (node1_xmr_before - node1_xmr_after < 0.02) assert (node1_xmr_before - node1_xmr_after < 0.02)
def test_05_self_bid(self):
logging.info('---------- Test {} to XMR same client'.format(self.test_coin_from.name))
swap_clients = self.swap_clients
amt_swap = make_int(random.uniform(0.1, 2.0), scale=8, r=1)
rate_swap = make_int(random.uniform(0.2, 20.0), scale=12, r=1)
offer_id = swap_clients[1].postOffer(self.test_coin_from, Coins.XMR, amt_swap, rate_swap, amt_swap, SwapTypes.XMR_SWAP, auto_accept_bids=True)
bid_id = swap_clients[1].postXmrBid(offer_id, amt_swap)
wait_for_bid(test_delay_event, swap_clients[1], bid_id, BidStates.SWAP_COMPLETED, wait_for=180)
class TestBTC(BasicSwapTest): class TestBTC(BasicSwapTest):
__test__ = True __test__ = True