Save bid in checkBidState for any change.

This commit is contained in:
tecnovert 2019-07-19 16:52:44 +02:00
parent b0f2e0557a
commit 24d4d14ff8
No known key found for this signature in database
GPG Key ID: 13F13651C9CF0D6B
2 changed files with 18 additions and 7 deletions

View File

@ -1,6 +1,7 @@
FROM ubuntu:18.10 FROM ubuntu:18.10
ENV PARTICL_DATADIR="/coindata/particl" \ ENV LANG C.UTF-8 \
PARTICL_DATADIR="/coindata/particl" \
PARTICL_BINDIR="/opt/particl" \ PARTICL_BINDIR="/opt/particl" \
LITECOIN_BINDIR="/opt/litecoin" \ LITECOIN_BINDIR="/opt/litecoin" \
DATADIRS="/coindata" DATADIRS="/coindata"
@ -36,9 +37,6 @@ WORKDIR /home/user
# Expose html port # Expose html port
EXPOSE 12700 EXPOSE 12700
ENV LANG C.UTF-8
VOLUME /coindata VOLUME /coindata
ENTRYPOINT ["basicswap-run", "-datadir=/coindata/basicswap"] ENTRYPOINT ["basicswap-run", "-datadir=/coindata/basicswap"]
CMD

View File

@ -1416,7 +1416,7 @@ class BasicSwap():
self.log.debug('Submitted participate txn %s to %s chain for bid %s', txid, chainparams[coin_to]['name'], bid_id.hex()) self.log.debug('Submitted participate txn %s to %s chain for bid %s', txid, chainparams[coin_to]['name'], bid_id.hex())
bid.setPTXState(TxStates.TX_SENT) bid.setPTXState(TxStates.TX_SENT)
self.saveBid(bid_id, bid) # bid saved in checkBidState
def addParticipateTxn(self, bid_id, bid, coin_type, txid_hex, vout, tx_height): def addParticipateTxn(self, bid_id, bid, coin_type, txid_hex, vout, tx_height):
bid.participate_txid = bytes.fromhex(txid_hex) bid.participate_txid = bytes.fromhex(txid_hex)
@ -1452,7 +1452,7 @@ class BasicSwap():
# TX_REDEEMED will be set when spend is detected # TX_REDEEMED will be set when spend is detected
# TODO: Wait for depth? # TODO: Wait for depth?
self.saveBid(bid_id, bid) # bid saved in checkBidState
def lookupChainHeight(self, coin_type): def lookupChainHeight(self, coin_type):
return self.callcoinrpc(coin_type, 'getblockchaininfo')['blocks'] return self.callcoinrpc(coin_type, 'getblockchaininfo')['blocks']
@ -1495,6 +1495,7 @@ class BasicSwap():
state = BidStates(bid.state) state = BidStates(bid.state)
self.log.debug('checkBidState %s %s', bid_id.hex(), str(state)) self.log.debug('checkBidState %s %s', bid_id.hex(), str(state))
save_bid = False
coin_from = Coins(offer.coin_from) coin_from = Coins(offer.coin_from)
coin_to = Coins(offer.coin_to) coin_to = Coins(offer.coin_to)
# TODO: Batch calls to scantxoutset # TODO: Batch calls to scantxoutset
@ -1504,6 +1505,7 @@ class BasicSwap():
initiate_txnid_hex = bid.initiate_txid.hex() initiate_txnid_hex = bid.initiate_txid.hex()
p2sh = self.getScriptAddress(coin_from, bid.initiate_script) p2sh = self.getScriptAddress(coin_from, bid.initiate_script)
index = None index = None
last_initiate_txn_conf = bid.initiate_txn_conf
if coin_from == Coins.PART: # Has txindex if coin_from == Coins.PART: # Has txindex
try: try:
initiate_txn = self.callcoinrpc(coin_from, 'getrawtransaction', [initiate_txnid_hex, True]) initiate_txn = self.callcoinrpc(coin_from, 'getrawtransaction', [initiate_txnid_hex, True])
@ -1525,6 +1527,9 @@ class BasicSwap():
bid.initiate_txn_conf = found['n_conf'] bid.initiate_txn_conf = found['n_conf']
index = found['index'] index = found['index']
if bid.initiate_txn_conf != last_initiate_txn_conf:
save_bid = True
if bid.initiate_txn_conf is not None: if bid.initiate_txn_conf is not None:
self.log.debug('initiate_txnid %s confirms %d', initiate_txnid_hex, bid.initiate_txn_conf) self.log.debug('initiate_txnid %s confirms %d', initiate_txnid_hex, bid.initiate_txn_conf)
@ -1535,9 +1540,11 @@ class BasicSwap():
self.coin_clients[coin_from]['watched_outputs'].append((bid_id, initiate_txnid_hex, bid.initiate_txn_n, BidStates.SWAP_INITIATED)) self.coin_clients[coin_from]['watched_outputs'].append((bid_id, initiate_txnid_hex, bid.initiate_txn_n, BidStates.SWAP_INITIATED))
if bid.initiate_txn_state is None or bid.initiate_txn_state < TxStates.TX_SENT: if bid.initiate_txn_state is None or bid.initiate_txn_state < TxStates.TX_SENT:
bid.setITXState(TxStates.TX_SENT) bid.setITXState(TxStates.TX_SENT)
save_bid = True
if bid.initiate_txn_conf >= self.coin_clients[coin_from]['blocks_confirmed']: if bid.initiate_txn_conf >= self.coin_clients[coin_from]['blocks_confirmed']:
self.initiateTxnConfirmed(bid_id, bid, offer) self.initiateTxnConfirmed(bid_id, bid, offer)
save_bid = True
# Bid times out if buyer doesn't see tx in chain within # Bid times out if buyer doesn't see tx in chain within
if bid.state_time + INITIATE_TX_TIMEOUT < int(time.time()): if bid.state_time + INITIATE_TX_TIMEOUT < int(time.time()):
@ -1554,6 +1561,8 @@ class BasicSwap():
found = self.lookupUnspentByAddress(coin_to, addr, assert_amount=bid.amount_to) found = self.lookupUnspentByAddress(coin_to, addr, assert_amount=bid.amount_to)
if found: if found:
if bid.participate_txn_conf != found['n_conf']:
save_bid = True
bid.participate_txn_conf = found['n_conf'] bid.participate_txn_conf = found['n_conf']
index = found['index'] index = found['index']
if bid.participate_txid is None: if bid.participate_txid is None:
@ -1564,12 +1573,13 @@ class BasicSwap():
tx_height = self.lookupChainHeight(coin_to) tx_height = self.lookupChainHeight(coin_to)
self.addParticipateTxn(bid_id, bid, coin_to, found['txid'], found['index'], tx_height) self.addParticipateTxn(bid_id, bid, coin_to, found['txid'], found['index'], tx_height)
bid.setPTXState(TxStates.TX_SENT) bid.setPTXState(TxStates.TX_SENT)
self.saveBid(bid_id, bid) save_bid = True
if bid.participate_txn_conf is not None: if bid.participate_txn_conf is not None:
self.log.debug('participate_txid %s confirms %d', bid.participate_txid.hex(), bid.participate_txn_conf) self.log.debug('participate_txid %s confirms %d', bid.participate_txid.hex(), bid.participate_txn_conf)
if bid.participate_txn_conf >= self.coin_clients[coin_to]['blocks_confirmed']: if bid.participate_txn_conf >= self.coin_clients[coin_to]['blocks_confirmed']:
self.participateTxnConfirmed(bid_id, bid, offer) self.participateTxnConfirmed(bid_id, bid, offer)
save_bid = True
elif state == BidStates.SWAP_PARTICIPATING: elif state == BidStates.SWAP_PARTICIPATING:
# Waiting for initiate txn spend # Waiting for initiate txn spend
pass pass
@ -1585,6 +1595,9 @@ class BasicSwap():
self.saveBid(bid_id, bid) self.saveBid(bid_id, bid)
return True # Mark bid for archiving return True # Mark bid for archiving
if save_bid:
self.saveBid(bid_id, bid)
# Try refund, keep trying until sent tx is spent # Try refund, keep trying until sent tx is spent
if (bid.initiate_txn_state == TxStates.TX_SENT or bid.initiate_txn_state == TxStates.TX_CONFIRMED) \ if (bid.initiate_txn_state == TxStates.TX_SENT or bid.initiate_txn_state == TxStates.TX_CONFIRMED) \
and bid.initiate_txn_refund is not None: and bid.initiate_txn_refund is not None: