lbry-sdk/lbrynet/wallet/database.py

119 lines
4.3 KiB
Python
Raw Normal View History

2018-07-11 23:18:59 -04:00
from twisted.internet import defer
2018-10-05 09:20:16 -04:00
from torba.basedatabase import BaseDatabase
2018-06-12 11:53:29 -04:00
class WalletDatabase(BaseDatabase):
CREATE_TXO_TABLE = """
create table if not exists txo (
2018-07-14 23:02:19 -04:00
txid text references tx,
txoid text primary key,
address text references pubkey_address,
position integer not null,
amount integer not null,
script blob not null,
is_reserved boolean not null default 0,
2018-07-11 23:18:59 -04:00
2018-07-14 23:02:19 -04:00
claim_id text,
claim_name text,
is_claim boolean not null default 0,
is_update boolean not null default 0,
2018-08-14 16:16:29 -04:00
is_support boolean not null default 0,
2018-08-22 23:47:37 -04:00
is_buy boolean not null default 0,
is_sell boolean not null default 0
);
"""
2018-06-12 11:53:29 -04:00
CREATE_TABLES_QUERY = (
BaseDatabase.CREATE_TX_TABLE +
BaseDatabase.CREATE_PUBKEY_ADDRESS_TABLE +
CREATE_TXO_TABLE +
2018-06-12 11:53:29 -04:00
BaseDatabase.CREATE_TXI_TABLE
)
def txo_to_row(self, tx, address, txo):
row = super().txo_to_row(tx, address, txo)
row.update({
'is_claim': txo.script.is_claim_name,
'is_update': txo.script.is_update_claim,
'is_support': txo.script.is_support_claim,
2018-08-22 23:47:37 -04:00
'is_buy': txo.script.is_buy_claim,
'is_sell': txo.script.is_sell_claim,
})
if txo.script.is_claim_involved:
row['claim_id'] = txo.claim_id
row['claim_name'] = txo.claim_name
return row
2018-07-11 23:18:59 -04:00
2018-10-05 09:02:02 -04:00
@defer.inlineCallbacks
def get_txos(self, **constraints):
my_account = constraints.get('my_account', constraints.get('account', None))
2018-10-05 09:02:02 -04:00
txos = yield super().get_txos(**constraints)
channel_ids = set()
2018-10-05 09:02:02 -04:00
for txo in txos:
if txo.script.is_claim_name or txo.script.is_update_claim:
if 'publisherSignature' in txo.claim_dict:
channel_ids.add(txo.claim_dict['publisherSignature']['certificateId'])
if txo.claim_name.startswith('@') and my_account is not None:
txo.signature = my_account.get_certificate_private_key(txo.ref)
2018-10-05 09:02:02 -04:00
if channel_ids:
2018-10-05 09:02:02 -04:00
channels = {
txo.claim_id: txo for txo in
(yield super().get_utxos(
my_account=my_account,
claim_id__in=channel_ids
2018-10-05 09:02:02 -04:00
))
}
for txo in txos:
if txo.script.is_claim_name or txo.script.is_update_claim:
if 'publisherSignature' in txo.claim_dict:
txo.channel = channels.get(txo.claim_dict['publisherSignature']['certificateId'])
return txos
@staticmethod
def constrain_claims(constraints):
constraints['claim_type__any'] = {'is_claim': 1, 'is_update': 1}
def get_claims(self, **constraints):
self.constrain_claims(constraints)
return self.get_utxos(**constraints)
def get_claims_count(self, **constraints):
self.constrain_claims(constraints)
return self.get_utxo_count(**constraints)
@staticmethod
def constrain_channels(constraints):
if 'claim_name' not in constraints or 'claim_id' not in constraints:
constraints['claim_name__like'] = '@%'
def get_channels(self, **constraints):
self.constrain_channels(constraints)
return self.get_claims(**constraints)
2018-07-11 23:18:59 -04:00
def get_channels_count(self, **constraints):
self.constrain_channels(constraints)
return self.get_claims_count(**constraints)
@defer.inlineCallbacks
def get_certificates(self, private_key_accounts, exclude_without_key=False, **constraints):
channels = yield self.get_channels(**constraints)
2018-07-15 21:54:55 -03:00
certificates = []
2018-07-11 23:18:59 -04:00
if private_key_accounts is not None:
for channel in channels:
if not channel.has_signature:
private_key = None
for account in private_key_accounts:
private_key = account.get_certificate_private_key(channel.ref)
if private_key is not None:
break
if private_key is None and exclude_without_key:
continue
channel.signature = private_key
certificates.append(channel)
return certificates