Fix xmr self bid.
This commit is contained in:
parent
d08e85e73e
commit
8022ada01f
@ -1,3 +1,3 @@
|
|||||||
name = "basicswap"
|
name = "basicswap"
|
||||||
|
|
||||||
__version__ = "0.11.47"
|
__version__ = "0.11.48"
|
||||||
|
@ -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:
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user