Compare commits

...
Sign in to create a new pull request.

1 commit

Author SHA1 Message Date
Jack Robison
9f5f833d00
headers lru cache 2020-02-03 23:54:08 -05:00

View file

@ -12,6 +12,7 @@ import asyncio
import logging import logging
import itertools import itertools
import collections import collections
from functools import lru_cache
from asyncio import Event, sleep from asyncio import Event, sleep
from collections import defaultdict from collections import defaultdict
@ -837,6 +838,12 @@ class LBRYElectrumX(SessionBase):
self.bp: LBRYBlockProcessor = self.session_mgr.bp self.bp: LBRYBlockProcessor = self.session_mgr.bp
self.db: LBRYLevelDB = self.bp.db self.db: LBRYLevelDB = self.bp.db
@lru_cache(1000)
async def _cached_block_headers(_start_height, _count, _b64, _max_size, _cp_height):
return await self._block_headers(_start_height, _count, _b64, _max_size, _cp_height)
self._cached_block_headers = _cached_block_headers
@classmethod @classmethod
def protocol_min_max_strings(cls): def protocol_min_max_strings(cls):
return [util.version_string(ver) return [util.version_string(ver)
@ -1299,6 +1306,20 @@ class LBRYElectrumX(SessionBase):
height: the header's height""" height: the header's height"""
return await self.block_header(height) return await self.block_header(height)
async def _block_headers(self, start_height, count, b64, max_size, cp_height):
headers, count = await self.db.read_headers(start_height, count)
compressobj = zlib.compressobj(wbits=-15, level=1, memLevel=9)
headers = base64.b64encode(compressobj.compress(headers) + compressobj.flush()).decode() if b64 else headers.hex()
result = {
'base64' if b64 else 'hex': headers,
'count': count,
'max': max_size
}
if count and cp_height:
last_height = start_height + count - 1
result.update(await self._merkle_proof(cp_height, last_height))
return result
async def block_headers(self, start_height, count, cp_height=0, b64=False): async def block_headers(self, start_height, count, cp_height=0, b64=False):
"""Return count concatenated block headers as hex for the main chain; """Return count concatenated block headers as hex for the main chain;
starting at start_height. starting at start_height.
@ -1312,18 +1333,10 @@ class LBRYElectrumX(SessionBase):
max_size = self.MAX_CHUNK_SIZE max_size = self.MAX_CHUNK_SIZE
count = min(count, max_size) count = min(count, max_size)
headers, count = await self.db.read_headers(start_height, count)
compressobj = zlib.compressobj(wbits=-15, level=1, memLevel=9) if count + start_height < self.db.db_height:
headers = base64.b64encode(compressobj.compress(headers) + compressobj.flush()).decode() if b64 else headers.hex() return await self._cached_block_headers(start_height, count, b64, max_size, cp_height)
result = { return await self._block_headers(start_height, count, b64, max_size, cp_height)
'base64' if b64 else 'hex': headers,
'count': count,
'max': max_size
}
if count and cp_height:
last_height = start_height + count - 1
result.update(await self._merkle_proof(cp_height, last_height))
return result
async def block_get_chunk(self, index): async def block_get_chunk(self, index):
"""Return a chunk of block headers as a hexadecimal string. """Return a chunk of block headers as a hexadecimal string.