lbry-sdk/lbry/service/full_node.py

92 lines
3 KiB
Python
Raw Normal View History

2020-05-01 09:33:58 -04:00
import logging
from binascii import hexlify, unhexlify
from typing import List, Dict, Tuple
2020-05-01 09:33:58 -04:00
from lbry.blockchain.lbrycrd import Lbrycrd
from lbry.blockchain.sync import BlockchainSync
from lbry.blockchain.ledger import Ledger
from lbry.blockchain.transaction import Transaction
from .base import Service
log = logging.getLogger(__name__)
class FullNode(Service):
2020-09-16 19:50:51 -04:00
name = "node"
2020-05-01 09:33:58 -04:00
sync: BlockchainSync
2020-06-05 00:35:22 -04:00
def __init__(self, ledger: Ledger, chain: Lbrycrd = None):
super().__init__(ledger)
2020-05-01 09:33:58 -04:00
self.chain = chain or Lbrycrd(ledger)
2020-06-05 00:35:22 -04:00
self.sync = BlockchainSync(self.chain, self.db)
2020-10-16 12:52:57 -04:00
self.sync.on_block.listen(self.generate_addresses)
async def generate_addresses(self, _):
await self.wallets.generate_addresses()
2020-05-01 09:33:58 -04:00
async def start(self):
await self.chain.open()
await super().start()
async def stop(self):
await super().stop()
await self.chain.close()
2020-07-07 10:52:41 -04:00
async def get_status(self):
return 'everything is wonderful'
async def get_block_headers(self, first, last=None):
2020-11-16 12:31:44 -05:00
return await self.db.get_block_headers(first, last)
async def get_address_filters(self, start_height: int, end_height: int = None, granularity: int = 0):
return await self.db.get_filters(
start_height=start_height, end_height=end_height, granularity=granularity
)
# async def get_block_address_filters(self):
2020-07-13 15:45:21 -04:00
# return {
# hexlify(f['block_hash']).decode(): hexlify(f['block_filter']).decode()
# for f in await self.db.get_block_address_filters()
# }
2020-05-01 09:33:58 -04:00
2021-01-11 00:56:15 -05:00
async def search_transactions(self, txids, raw: bool = False):
2020-05-01 09:33:58 -04:00
tx_hashes = [unhexlify(txid)[::-1] for txid in txids]
2021-01-11 00:56:15 -05:00
if raw:
return {
hexlify(tx['tx_hash'][::-1]).decode(): hexlify(tx['raw']).decode()
for tx in await self.db.get_raw_transactions(tx_hash__in=tx_hashes)
}
2020-05-01 09:33:58 -04:00
return {
2021-01-04 10:44:36 -05:00
tx.id: hexlify(tx.raw).decode()
for tx in await self.db.get_transactions(tx_hash__in=tx_hashes)
2020-05-01 09:33:58 -04:00
}
async def broadcast(self, tx):
return await self.chain.send_raw_transaction(hexlify(tx.raw).decode())
async def wait(self, tx: Transaction, height=-1, timeout=1):
pass
2020-08-04 13:49:59 -04:00
async def search_claims(self, accounts, **kwargs):
return await self.db.search_claims(**kwargs)
async def protobuf_search_claims(self, **kwargs):
return await self.db.protobuf_search_claims(**kwargs)
2020-08-10 18:37:21 -04:00
async def search_supports(self, accounts, **kwargs):
return await self.db.search_supports(**kwargs)
2020-07-07 10:52:41 -04:00
async def resolve(self, urls, **kwargs):
2020-08-04 10:41:49 -04:00
return await self.db.resolve(urls, **kwargs)
async def protobuf_resolve(self, urls, **kwargs):
return await self.db.protobuf_resolve(urls, **kwargs)
2020-10-13 14:34:19 -04:00
async def sum_supports(self, claim_hash: bytes, include_channel_content=False, exclude_own_supports=False) \
-> Tuple[List[Dict], int]:
return await self.db.sum_supports(claim_hash, include_channel_content, exclude_own_supports)