basicswap_miserver/basicswap/interface/dash.py

95 lines
3.4 KiB
Python
Raw Normal View History

2022-10-20 20:23:25 +00:00
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Copyright (c) 2022 tecnovert
# Distributed under the MIT software license, see the accompanying
# file LICENSE or http://www.opensource.org/licenses/mit-license.php.
from .btc import BTCInterface
from basicswap.chainparams import Coins
2022-11-14 11:54:48 +00:00
from basicswap.util.address import decodeAddress
from mnemonic import Mnemonic
from basicswap.contrib.test_framework.script import (
CScript,
OP_DUP, OP_HASH160, OP_EQUALVERIFY, OP_CHECKSIG
)
2022-10-20 20:23:25 +00:00
class DASHInterface(BTCInterface):
@staticmethod
def coin_type():
return Coins.DASH
2022-12-11 18:31:43 +00:00
def __init__(self, coin_settings, network, swap_client=None):
super().__init__(coin_settings, network, swap_client)
self._wallet_passphrase = ''
2022-12-11 23:30:33 +00:00
self._have_checked_seed = False
2022-12-11 18:31:43 +00:00
def seedToMnemonic(self, key: bytes) -> str:
return Mnemonic('english').to_mnemonic(key)
def initialiseWallet(self, key: bytes):
words = self.seedToMnemonic(key)
2022-12-11 18:31:43 +00:00
mnemonic_passphrase = ''
2023-12-29 13:36:00 +00:00
self.rpc_wallet('upgradetohd', [words, mnemonic_passphrase, self._wallet_passphrase])
2022-12-11 23:30:33 +00:00
self._have_checked_seed = False
if self._wallet_passphrase != '':
self.unlockWallet(self._wallet_passphrase)
def decodeAddress(self, address: str) -> bytes:
2022-11-14 11:54:48 +00:00
return decodeAddress(address)[1:]
def checkExpectedSeed(self, key_hash: str):
try:
2023-12-29 13:36:00 +00:00
rv = self.rpc_wallet('dumphdinfo')
entropy = Mnemonic('english').to_entropy(rv['mnemonic'].split(' '))
entropy_hash = self.getAddressHashFromKey(entropy)[::-1].hex()
2022-12-11 23:30:33 +00:00
self._have_checked_seed = True
return entropy_hash == key_hash
except Exception as e:
self._log.warning('checkExpectedSeed failed: {}'.format(str(e)))
return False
2022-10-20 22:37:45 +00:00
def withdrawCoin(self, value, addr_to, subfee):
params = [addr_to, value, '', '', subfee, False, False, self._conf_target]
2023-12-29 13:36:00 +00:00
return self.rpc_wallet('sendtoaddress', params)
2022-11-15 21:50:36 +00:00
2023-07-05 21:35:25 +00:00
def getSpendableBalance(self) -> int:
2023-12-29 13:36:00 +00:00
return self.make_int(self.rpc_wallet('getwalletinfo')['balance'])
def getScriptForPubkeyHash(self, pkh: bytes) -> bytearray:
# Return P2PKH
return CScript([OP_DUP, OP_HASH160, pkh, OP_EQUALVERIFY, OP_CHECKSIG])
def getBLockSpendTxFee(self, tx, fee_rate: int) -> int:
add_bytes = 107
size = len(tx.serialize_with_witness()) + add_bytes
2023-07-14 07:31:05 +00:00
pay_fee = round(fee_rate * size / 1000)
self._log.info(f'BLockSpendTx fee_rate, size, fee: {fee_rate}, {size}, {pay_fee}.')
return pay_fee
def findTxnByHash(self, txid_hex: str):
# Only works for wallet txns
try:
2023-12-29 13:36:00 +00:00
rv = self.rpc_wallet('gettransaction', [txid_hex])
except Exception as ex:
self._log.debug('findTxnByHash getrawtransaction failed: {}'.format(txid_hex))
return None
if 'confirmations' in rv and rv['confirmations'] >= self.blocks_confirmed:
block_height = self.getBlockHeader(rv['blockhash'])['height']
return {'txid': txid_hex, 'amount': 0, 'height': block_height}
return None
2022-12-11 18:31:43 +00:00
def unlockWallet(self, password: str):
super().unlockWallet(password)
# Store password for initialiseWallet
self._wallet_passphrase = password
2022-12-11 23:30:33 +00:00
if not self._have_checked_seed:
self._sc.checkWalletSeed(self.coin_type())
2022-12-11 18:31:43 +00:00
def lockWallet(self):
super().lockWallet()
self._wallet_passphrase = ''