2016-05-30 15:49:25 -04:00
|
|
|
import json
|
|
|
|
import logging.handlers
|
2017-07-03 11:09:59 -04:00
|
|
|
import sys
|
2016-05-30 15:49:25 -04:00
|
|
|
import os
|
|
|
|
|
2017-07-03 11:09:59 -04:00
|
|
|
from appdirs import user_data_dir
|
2016-05-30 15:49:25 -04:00
|
|
|
from twisted.internet.task import LoopingCall
|
|
|
|
from twisted.internet import reactor
|
|
|
|
|
|
|
|
|
2017-07-03 11:09:59 -04:00
|
|
|
if sys.platform != "darwin":
|
|
|
|
log_dir = os.path.join(os.path.expanduser("~"), ".lbrynet")
|
|
|
|
else:
|
|
|
|
log_dir = user_data_dir("LBRY")
|
|
|
|
|
|
|
|
if not os.path.isdir(log_dir):
|
|
|
|
os.mkdir(log_dir)
|
|
|
|
|
2016-05-30 15:49:25 -04:00
|
|
|
LOG_FILENAME = os.path.join(log_dir, 'lbrynet-daemon.log')
|
|
|
|
|
|
|
|
if os.path.isfile(LOG_FILENAME):
|
|
|
|
f = open(LOG_FILENAME, 'r')
|
|
|
|
PREVIOUS_LOG = len(f.read())
|
|
|
|
f.close()
|
|
|
|
else:
|
|
|
|
PREVIOUS_LOG = 0
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
handler = logging.handlers.RotatingFileHandler(LOG_FILENAME, maxBytes=2097152, backupCount=5)
|
|
|
|
log.addHandler(handler)
|
|
|
|
log.setLevel(logging.INFO)
|
|
|
|
|
|
|
|
|
|
|
|
class Autofetcher(object):
|
|
|
|
"""
|
|
|
|
Download name claims as they occur
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, api):
|
|
|
|
self._api = api
|
|
|
|
self._checker = LoopingCall(self._check_for_new_claims)
|
|
|
|
self.best_block = None
|
|
|
|
|
|
|
|
def start(self):
|
|
|
|
reactor.addSystemEventTrigger('before', 'shutdown', self.stop)
|
|
|
|
self._checker.start(5)
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
log.info("Stopping autofetcher")
|
|
|
|
self._checker.stop()
|
|
|
|
|
|
|
|
def _check_for_new_claims(self):
|
|
|
|
block = self._api.get_best_blockhash()
|
|
|
|
if block != self.best_block:
|
|
|
|
log.info("Checking new block for name claims, block hash: %s" % block)
|
|
|
|
self.best_block = block
|
|
|
|
transactions = self._api.get_block({'blockhash': block})['tx']
|
|
|
|
for t in transactions:
|
|
|
|
c = self._api.get_claims_for_tx({'txid': t})
|
|
|
|
if len(c):
|
|
|
|
for i in c:
|
|
|
|
log.info("Downloading stream for claim txid: %s" % t)
|
|
|
|
self._api.get({'name': t, 'stream_info': json.loads(i['value'])})
|
|
|
|
|
|
|
|
|
|
|
|
def run(api):
|
|
|
|
fetcher = Autofetcher(api)
|
2016-12-13 17:16:12 -06:00
|
|
|
fetcher.start()
|