2020-10-31 20:08:30 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2021-01-10 18:30:07 +00:00
|
|
|
# Copyright (c) 2020-2021 tecnovert
|
2020-10-31 20:08:30 +00:00
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file LICENSE or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
from enum import IntEnum
|
|
|
|
|
2020-10-31 20:08:30 +00:00
|
|
|
from .contrib.test_framework.messages import (
|
|
|
|
CTxOutPart,
|
|
|
|
)
|
2020-12-08 22:05:28 +00:00
|
|
|
from .contrib.test_framework.script import (
|
|
|
|
CScript,
|
|
|
|
OP_DUP, OP_HASH160, OP_EQUALVERIFY, OP_CHECKSIG
|
|
|
|
)
|
2020-10-31 20:08:30 +00:00
|
|
|
|
2021-02-13 22:54:01 +00:00
|
|
|
from .util import encodeStealthAddress
|
|
|
|
from .chainparams import Coins, chainparams
|
2020-10-31 20:08:30 +00:00
|
|
|
from .interface_btc import BTCInterface
|
|
|
|
|
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
class BalanceTypes(IntEnum):
|
|
|
|
PLAIN = 1
|
|
|
|
BLIND = 2
|
|
|
|
ANON = 3
|
|
|
|
|
|
|
|
|
2020-10-31 20:08:30 +00:00
|
|
|
class PARTInterface(BTCInterface):
|
2020-11-15 17:02:46 +00:00
|
|
|
@staticmethod
|
|
|
|
def coin_type():
|
|
|
|
return Coins.PART
|
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
@staticmethod
|
|
|
|
def balance_type():
|
|
|
|
return BalanceTypes.PLAIN
|
|
|
|
|
2020-10-31 20:08:30 +00:00
|
|
|
@staticmethod
|
2021-02-13 22:54:01 +00:00
|
|
|
def witnessScaleFactor() -> int:
|
2020-10-31 20:08:30 +00:00
|
|
|
return 2
|
|
|
|
|
|
|
|
@staticmethod
|
2021-02-13 22:54:01 +00:00
|
|
|
def txVersion() -> int:
|
2020-10-31 20:08:30 +00:00
|
|
|
return 0xa0
|
|
|
|
|
2021-01-02 14:59:34 +00:00
|
|
|
@staticmethod
|
2021-02-13 22:54:01 +00:00
|
|
|
def xmr_swap_alock_spend_tx_vsize() -> int:
|
2021-01-02 14:59:34 +00:00
|
|
|
return 213
|
|
|
|
|
2021-01-29 23:45:24 +00:00
|
|
|
@staticmethod
|
|
|
|
def txoType():
|
|
|
|
return CTxOutPart
|
2020-11-07 11:08:07 +00:00
|
|
|
|
2021-02-13 22:54:01 +00:00
|
|
|
def setDefaults(self) -> None:
|
2021-02-06 22:35:12 +00:00
|
|
|
super().setDefaults()
|
|
|
|
self._anon_tx_ring_size = 8 # TODO: Make option
|
|
|
|
|
2020-12-04 17:06:50 +00:00
|
|
|
def knownWalletSeed(self):
|
|
|
|
# TODO: Double check
|
|
|
|
return True
|
|
|
|
|
2020-11-07 11:08:07 +00:00
|
|
|
def getNewAddress(self, use_segwit):
|
|
|
|
return self.rpc_callback('getnewaddress', ['swap_receive'])
|
2020-11-29 23:05:30 +00:00
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
def getNewStealthAddress(self):
|
|
|
|
return self.rpc_callback('getnewstealthaddress', ['swap_stealth'])
|
|
|
|
|
2020-11-29 23:05:30 +00:00
|
|
|
def haveSpentIndex(self):
|
|
|
|
version = self.getDaemonVersion()
|
|
|
|
index_info = self.rpc_callback('getinsightinfo' if int(str(version)[:2]) > 19 else 'getindexinfo')
|
|
|
|
return index_info['spentindex']
|
2020-12-03 23:46:01 +00:00
|
|
|
|
|
|
|
def initialiseWallet(self, key):
|
|
|
|
raise ValueError('TODO')
|
2020-12-05 11:22:22 +00:00
|
|
|
|
|
|
|
def withdrawCoin(self, value, addr_to, subfee):
|
|
|
|
params = [addr_to, value, '', '', subfee, '', True, self._conf_target]
|
|
|
|
return self.rpc_callback('sendtoaddress', params)
|
2020-12-08 22:05:28 +00:00
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
def sendTypeTo(self, type_from, type_to, value, addr_to, subfee):
|
|
|
|
params = [type_from, type_to,
|
|
|
|
[{'address': addr_to, 'amount': value, 'subfee': subfee}, ],
|
|
|
|
'', '', self._anon_tx_ring_size, 1, False,
|
|
|
|
{'conf_target': self._conf_target}]
|
|
|
|
return self.rpc_callback('sendtypeto', params)
|
|
|
|
|
2020-12-08 22:05:28 +00:00
|
|
|
def getScriptForPubkeyHash(self, pkh):
|
|
|
|
return CScript([OP_DUP, OP_HASH160, pkh, OP_EQUALVERIFY, OP_CHECKSIG])
|
2021-02-06 22:35:12 +00:00
|
|
|
|
2021-02-13 22:54:01 +00:00
|
|
|
def formatStealthAddress(self, scan_pubkey, spend_pubkey):
|
|
|
|
prefix_byte = chainparams[self.coin_type()][self._network]['stealth_key_prefix']
|
|
|
|
|
|
|
|
return encodeStealthAddress(prefix_byte, scan_pubkey, spend_pubkey)
|
|
|
|
|
2021-02-06 22:35:12 +00:00
|
|
|
|
|
|
|
class PARTInterfaceBlind(PARTInterface):
|
|
|
|
@staticmethod
|
|
|
|
def balance_type():
|
|
|
|
return BalanceTypes.BLIND
|
|
|
|
|
|
|
|
|
|
|
|
class PARTInterfaceAnon(PARTInterface):
|
|
|
|
@staticmethod
|
|
|
|
def balance_type():
|
|
|
|
return BalanceTypes.ANON
|
2021-02-11 12:57:54 +00:00
|
|
|
|
|
|
|
def publishBLockTx(self, Kbv, Kbs, output_amount, feerate):
|
2021-02-13 22:54:01 +00:00
|
|
|
sx_addr = self.formatStealthAddress(Kbv, Kbs)
|
|
|
|
self._log.debug('sx_addr: {}'.format(sx_addr))
|
|
|
|
|
|
|
|
# TODO: Fund from other balances
|
|
|
|
params = ['anon', 'anon',
|
|
|
|
[{'address': sx_addr, 'amount': self.format_amount(output_amount)}, ],
|
|
|
|
'', '', self._anon_tx_ring_size, 1, False,
|
|
|
|
{'conf_target': self._conf_target, 'blind_watchonly_visible': True}]
|
|
|
|
|
|
|
|
txid = self.rpc_callback('sendtypeto', params)
|
|
|
|
return bytes.fromhex(txid)
|
2021-02-11 12:57:54 +00:00
|
|
|
|
|
|
|
def findTxB(self, kbv, Kbs, cb_swap_value, cb_block_confirmed, restore_height):
|
|
|
|
raise ValueError('TODO - new core release')
|
|
|
|
|
|
|
|
def spendBLockTx(self, address_to, kbv, kbs, cb_swap_value, b_fee, restore_height):
|
|
|
|
raise ValueError('TODO - new core release')
|