Merge branch 'walletbalancerefresh' into development

This commit is contained in:
Jimmy Kiselak 2016-03-17 21:55:20 -04:00
commit 3b92d12a44

View file

@ -67,6 +67,9 @@ class LBRYWallet(object):
self.stopped = True self.stopped = True
self.manage_running = False self.manage_running = False
self._manage_count = 0
self._balance_refresh_time = 3
self._batch_count = 20
def start(self): def start(self):
@ -93,16 +96,20 @@ class LBRYWallet(object):
self.next_manage_call.cancel() self.next_manage_call.cancel()
self.next_manage_call = None self.next_manage_call = None
d = self.manage() d = self.manage(do_full=True)
d.addErrback(self.log_stop_error) d.addErrback(self.log_stop_error)
d.addCallback(lambda _: self._stop()) d.addCallback(lambda _: self._stop())
d.addErrback(self.log_stop_error) d.addErrback(self.log_stop_error)
return d return d
def manage(self): def manage(self, do_full=False):
log.info("Doing manage") log.info("Doing manage")
self.next_manage_call = None self.next_manage_call = None
have_set_manage_running = [False] have_set_manage_running = [False]
self._manage_count += 1
if self._manage_count % self._batch_count == 0:
self._manage_count = 0
do_full = True
def check_if_manage_running(): def check_if_manage_running():
@ -113,6 +120,8 @@ class LBRYWallet(object):
self.manage_running = True self.manage_running = True
have_set_manage_running[0] = True have_set_manage_running[0] = True
d.callback(True) d.callback(True)
elif do_full is False:
d.callback(False)
else: else:
task.deferLater(reactor, 1, fire_if_not_running) task.deferLater(reactor, 1, fire_if_not_running)
@ -121,20 +130,26 @@ class LBRYWallet(object):
d = check_if_manage_running() d = check_if_manage_running()
d.addCallback(lambda _: self._check_expected_balances()) def do_manage():
if do_full:
d = self._check_expected_balances()
d.addCallback(lambda _: self._send_payments())
else:
d = defer.succeed(True)
d.addCallback(lambda _: self._send_payments()) d.addCallback(lambda _: self.get_balance())
d.addCallback(lambda _: self.get_balance()) def set_wallet_balance(balance):
self.wallet_balance = balance
def set_wallet_balance(balance): d.addCallback(set_wallet_balance)
self.wallet_balance = balance return d
d.addCallback(set_wallet_balance) d.addCallback(lambda should_run: do_manage() if should_run else None)
def set_next_manage_call(): def set_next_manage_call():
if not self.stopped: if not self.stopped:
self.next_manage_call = reactor.callLater(60, self.manage) self.next_manage_call = reactor.callLater(self._balance_refresh_time, self.manage)
d.addCallback(lambda _: set_next_manage_call()) d.addCallback(lambda _: set_next_manage_call())